Marvel and DC Weekly New Comics Release List Tracker
by Kutluhan Aktar in Circuits > Electronics
1393 Views, 10 Favorites, 0 Comments
Marvel and DC Weekly New Comics Release List Tracker
data:image/s3,"s3://crabby-images/1d548/1d5485aa55bc0a32d0dc8f9cdcf0a2c515d6af03" alt="home.jpg"
Display comics release lists of this, next, and previous weeks via Nano 33 IoT and this amazing 🕷 PCB playing Spider-Man theme song :)
Supplies
PCBWay Custom PCB
Arduino Nano 33 IoT
Raspberry Pi 3B+ or 4
Nokia 5110 Screen
Buzzer
Rotary potentiometer
Potentiometer Knob
RGB Diffused Common Cathode
Vibration Motor
6x6 Pushbutton
Resistor 1k ohm
DC Power Connector, Jack
Story
data:image/s3,"s3://crabby-images/49461/494617d7519055db5baa8676323c99352291df11" alt="this_1.jpg"
data:image/s3,"s3://crabby-images/95e6e/95e6eca85f81ab47c54746968f935c9d219eeed0" alt="modes.gif"
I am a huge comic book fan and collect issues of my favorite titles every week. Therefore, I check weekly comics release lists from publishers every week. Even though there are umpteen web and mobile applications to inspect weekly new comics release lists from publishers, I wanted to create an unusual weekly comics release list tracking device with Arduino by which I can scrutinize weekly comics lists in a geeky way :)
First of all, to obtain weekly comics release lists from the ShortBoxed comics API, I developed a web application in PHP running on Raspberry Pi.
Then, I used an Arduino Nano 33 IoT to get comics release lists transferred by the PHP web application and display them with a Nokia 5110 Screen.
After completing wiring on a breadboard and testing the code, I designed a PCB (Comics Release List Tracker) inspired by one of my favorite comic book heroes: Spider-Man. It became a stylish and suitable addition to my comic book collection as an efficient new comics release list tracker with some spectacular features :)
The device shows the comics release list of:
- This Week
- Next Week
- Previous Week
Also, it has these unnecessary yet funny additional features 😃
- Plays the Spider-Man theme song (1967) before showing a list.
- Displays graphics adjusted by a potentiometer.
Huge thanks to PCBWay for sponsoring this project.
Designing and Soldering the Comics Release List Tracker PCB
data:image/s3,"s3://crabby-images/102e2/102e24140078de33b51035aa43eb5798c9aa1bf2" alt="breadboard.jpg"
data:image/s3,"s3://crabby-images/26e2e/26e2ed2cfde9fdb117800489fe963f9002a65f1c" alt="pcb_1.jpg"
data:image/s3,"s3://crabby-images/34145/3414526d09eb21aca1ea80d7ac8a0ec532c9d026" alt="pcb_2.jpg"
data:image/s3,"s3://crabby-images/da114/da114d6f0638fee30cec3e613a77b1c178e4bb9f" alt="pcb_3.jpg"
data:image/s3,"s3://crabby-images/dcbaa/dcbaa202afddad018b31b775c81ce6f2e2805b3c" alt="pcb_4.jpg"
data:image/s3,"s3://crabby-images/a9933/a9933b408a9009780d4e6be4358a744aa99836fb" alt="pcb_5.jpg"
Before prototyping my PCB design, I tested all connections and wiring with the Arduino Nano 33 IoT on the breadboard.
Then, I designed the Comics Release List Tracker PCB by using KiCad. I attached the Gerber file of the PCB below, so if you want, you can order this PCB from PCBWay to create a stylish and fully-functional weekly new comics release list tracker inspired by Spider-Man :)
Click here to inspect and order this PCB directly on PCBWay.
First of all, by using a soldering iron, I attached headers (female), buzzer, potentiometer, vibration motor, 5mm common cathode RGB LED, 6x6 pushbuttons, 1K resistors, and the power jack.
Component list on the PCB:
- A1 (Headers for Arduino Nano 33 IoT)
- S1 (Headers for Nokia 5110 Screen)
- BZ1 (Buzzer)
- RV1 (Potentiometer)
- V1 (Vibration Motor)
- D1 (5mm Common Cathode RGB LED)
- K1, K2, K3, K4, K5 (6x6 Pushbutton)
- R1, R2, R3, R4, R5 (1K Resistor)
- J1 (Power Jack)
Setting Up a LAMP Web Server on Raspberry Pi
data:image/s3,"s3://crabby-images/a241b/a241bcf9ca894a75895abccc5be90f33d64db857" alt="image_3DKp34GCri.jpg"
data:image/s3,"s3://crabby-images/cae81/cae815740fb0978d14cd3b3225819c40b8687266" alt="image_escl2XekOO.jpg"
data:image/s3,"s3://crabby-images/a5ca3/a5ca30718010f50faffd0e93c7a0ad5a275a4e9d" alt="image_nsvMChw2Mq.jpg"
data:image/s3,"s3://crabby-images/01acb/01acb7b08a9be5901aef3abc78276d57dcc26bc5" alt="image_tbXyALSydA.jpg"
data:image/s3,"s3://crabby-images/a3527/a3527885a2771db712dfb5043f798f3d358e2308" alt="image_yqP8SYOmzb.jpg"
If you are a novice in programming with Raspberry Pi, you can inspect well-explained instructions and tutorials on the official Raspberry Pi website.
To go to the official Raspberry Pi setting up tutorial, click here.
⭐ Open a terminal window by selecting Accessories > Terminal from the menu.
⭐ Install the apache2 package by typing the following command into the terminal and pressing Enter:
sudo apt-get install apache2 -y
⭐ To test the server, open Chromium by selecting Internet > Chromium Web Browser from the menu and enter http://localhost.
⭐ If you want, you can use the IP address of your Raspberry Pi as well.
hostname -I
⭐ Install the PHP package with the following command:
⭐ Do not forget to update the Pi.
sudo apt-get update
sudo apt-get install php -y
⭐ To be able to utilize the ShortBoxed comics API, install the php-curl package:
sudo apt-get install php-curl
⭐ Then, restart the apache server to be able to use the installed packages on the localhost:
sudo service apache2 restart
Developing the New Comics Releases Web Application in PHP to Obtain the Weekly Comics Release Lists
data:image/s3,"s3://crabby-images/41145/41145f05302e10158f80fe88d84c125580263397" alt="app_code_1.PNG"
data:image/s3,"s3://crabby-images/20225/20225ea65b2ce53632b46c2f7682b39dbff6f2de" alt="app_code_2.PNG"
This PHP web application is for fetching comics information from the ShortBoxed comics API. The API lets the user retrieve and query comics data in JSON.
API Domain: api.shortboxed.com
Although there are lots of features provided by the API, I used these three features below:
⭐ Returns this week's comics release list:
GET /comics/v1/new
⭐ Returns next week's comics release list:
GET /comics/v1/future
⭐ Returns previous week's comics release list:
GET /comics/v1/previous
The web application consists of one file - index.php. You can download the web application below to install it on your Raspberry Pi - New_Comics_Releases.zip.
💻 index.php
⭐ Define the 'comics' class to print requested comics release lists.
⭐ In the get_this_week_releases() function:
⭐ Get this week's released comics list from the ShortBoxed comics API by using the json_decode() and file_get_contents() functions.
⭐ Print new comics from selected publishers - Marvel Comics and DC Comics.
⭐ Syntax: %publisher, title ****...%date%
⭐ In the get_next_week_releases() function:
⭐ Get next week's comics list from the ShortBoxed comics API by using the json_decode() and file_get_contents() functions.
⭐ Print comics from selected publishers - Marvel Comics and DC Comics.
⭐ Syntax: %publisher, title ****...%date%
⭐ In the get_previous_week_releases() function:
⭐ Get previous week's released comics list from the ShortBoxed comics API by using the json_decode() and file_get_contents() functions.
⭐ Print comics from selected publishers - Marvel Comics and DC Comics.
⭐ Syntax: %publisher, title ****...%date%
⭐ Define a new object for the 'comics' class - releases.
⭐ Print the requested comics release list by the device via a Get request - this week, previous week, or next week.
Setting Up the Web Application on Raspberry Pi
data:image/s3,"s3://crabby-images/e2ef4/e2ef4a18cd68142085716f826d58454e5beea222" alt="app_rasp_1.png"
data:image/s3,"s3://crabby-images/b9903/b9903c12a378daaa0fa705c31d53038e906a99ff" alt="app_rasp_2.png"
data:image/s3,"s3://crabby-images/4233b/4233bb01f54e9bda81efc5213c2eb982e2d7d524" alt="app_working_1.png"
data:image/s3,"s3://crabby-images/fa8dc/fa8dc6830238fb0dd890d3416a6c22db0f2bc016" alt="app_working_2.png"
data:image/s3,"s3://crabby-images/b5ffb/b5ffbabd9368c96a03165d13b09436767588cb0a" alt="app_working_3.png"
data:image/s3,"s3://crabby-images/34f57/34f57661de02cc94fce9bff3d0fa6161e93b81c3" alt="app_working_4.png"
⭐ First of all, extract the New_Comics_Releases.zip folder and move the application folder (New_Comics_Releases) to the apache server (/var/www/html) by using the terminal since the apache server is a protected location.
sudo mv /home/pi/Downloads/New_Comics_Releases /var/www/html/
⭐ Go to the web application:
http://localhost/New_Comics_Releases/
⭐ To test whether the web application obtains requested comics release lists successfully - this week, next week, and previous week:
http://localhost/New_Comics_Releases/?q=this
Setting Up the Arduino Nano 33 IoT
data:image/s3,"s3://crabby-images/980d2/980d21df6b9ff32729f9d794dfb5961aede42a2d" alt="image_1CLLVV1Wmz.jpg"
data:image/s3,"s3://crabby-images/6a2ef/6a2ef5eb6fd6ff49050458781d766560e96d69b0" alt="image_Q1QeCr6Gmc.jpg"
data:image/s3,"s3://crabby-images/2fbaa/2fbaa7d706108bc48256e29f380f18e24cdedacc" alt="code_1.PNG"
data:image/s3,"s3://crabby-images/401dc/401dcaa23fdc032925a3211eef5c3b25005119f7" alt="code_2.PNG"
data:image/s3,"s3://crabby-images/be823/be823a35afdfc5b66292c7dfbe3e367331d1c237" alt="code_3.PNG"
data:image/s3,"s3://crabby-images/dda40/dda40e208b7a102f7e9e93fdd1f44973247a1ef9" alt="code_4.PNG"
data:image/s3,"s3://crabby-images/c724d/c724d1f03d6676db271e396041125a5e87b7cb9f" alt="code_5.PNG"
If you are a novice in programming with the Arduino Nano 33 IoT, follow the steps below to program it with the Arduino IDE.
⭐ Download the required drivers - Arduino SAMD Core - as explained here.
⭐ To be able to connect to the WiFi, download the WiFiNINA library from here.
⭐Download the required libraries to be able to control the modules:
Nokia 5110 Screen | Library
Playing the Spider-Man Theme Song With a Buzzer
data:image/s3,"s3://crabby-images/a17ab/a17ab082cd83cc2de99fd23a96caafef49b71be9" alt="code_6.PNG"
data:image/s3,"s3://crabby-images/d7fc3/d7fc397b3f9914cf9f6343c8f9b90b54a7b37e44" alt="code_7.PNG"
I used an extra file named pitches.h. This file contains all the pitch values for typical notes. For example, NOTE_C4 is middle C. NOTE_FS4 is F sharp, and so forth.
To play the Spider-Man theme song (1967) with a buzzer using the tone() function, I elicited its notes and durations from here.
⭐ In the play_Melody() function:
⭐ Define the notes in the Spider-Man theme song.
⭐ Define durations in the Spider-Man theme song: 4 = quarter note, 8 = eighth note, etc.
⭐ Calculate the length of the melody array.
⭐ To calculate the note duration, take one second divided by the note type. e.g. quarter note = 1000 / 4, eighth note = 1000 / 8, etc.
⭐ To distinguish the notes, set a minimum time between them.
Note's duration + 30%
Connections and Adjustments
data:image/s3,"s3://crabby-images/0305e/0305ef811f2296af87eb453252114514d2c0a75b" alt="finished.jpg"
// Connections
// Arduino Nano 33 IoT :
// Nokia 5110 Screen
// D2 --------------------------- SCK (Clk)
// D3 --------------------------- MOSI (Din)
// D4 --------------------------- DC
// D5 --------------------------- RST
// D6 --------------------------- CS (CE)
// Rotary Potentiometer
// A0 --------------------------- S
// Button (Right)
// A1 --------------------------- S
// Button (Left)
// A2 --------------------------- S
// Button (OK)
// A3 --------------------------- S
// Button (Up)
// A6 --------------------------- S
// Button (Down)
// A7 --------------------------- S
// RGB LEB (RCGB)
// D12 --------------------------- R
// D11 --------------------------- G
// D10 --------------------------- B
// Buzzer
// D8 --------------------------- +
// Vibration Motor
// D9 --------------------------- +
After completing and uploading the code, I attached all required components to the board via headers - the Arduino Nano 33 IoT, the Nokia 5110 Screen, and the potentiometer knob.
Modes and Features
data:image/s3,"s3://crabby-images/56b5c/56b5c3085f5c4ac52cc6eb1f47f8bc578ea0d9e6" alt="this_1.jpg"
data:image/s3,"s3://crabby-images/ca1bf/ca1bfe8a8915ad56329e548a174c727b3993d0de" alt="this_2.jpg"
data:image/s3,"s3://crabby-images/29dca/29dcac51c3a7ea1f0bb34d051d3eb63c91e5261b" alt="this_3.jpg"
data:image/s3,"s3://crabby-images/bf5ad/bf5ad7a07b7876cfc492a8ab9929ab3ba7675503" alt="this_4.jpg"
data:image/s3,"s3://crabby-images/ea403/ea4033cd1a1e530f2d42b5881e4db5987beeeb27" alt="this_5.jpg"
data:image/s3,"s3://crabby-images/fee96/fee96a45ec55825ed107a7a48bb35ea88ccfaceb" alt="pre_1.jpg"
data:image/s3,"s3://crabby-images/0c4ce/0c4cede3d0a0345fcf40ead0a09d79d876131ca1" alt="pre_2.jpg"
data:image/s3,"s3://crabby-images/955c7/955c7d5bd57e58941f63e24ffb4c98ffd9450006" alt="pre_3.jpg"
data:image/s3,"s3://crabby-images/9bf88/9bf8871d6173a64bbd630e2e1fd548c3b09d11e5" alt="pre_4.jpg"
data:image/s3,"s3://crabby-images/f3b98/f3b985dd7cefd4cbcc099fea6e037f0a3ba6a24a" alt="pre_5.jpg"
data:image/s3,"s3://crabby-images/2b81b/2b81b7120938f0b2034899855c64177d75635cf5" alt="next_1.jpg"
data:image/s3,"s3://crabby-images/58c76/58c76e4d613bab43bfdc5202ae6714732eea5b8b" alt="next_2.jpg"
data:image/s3,"s3://crabby-images/2cc93/2cc932b53b1369b83d9e90ec4b0b0fc6479eeda9" alt="next_3.jpg"
data:image/s3,"s3://crabby-images/11d11/11d11db92d3c1ba70f4f298c48b049d2126b824b" alt="next_4.jpg"
data:image/s3,"s3://crabby-images/43f6e/43f6e1802e65a7533c2a2a0af04ae0f4a0aadc3f" alt="next_5.jpg"
🕷🕸 First of all, the device checks for a successful WiFi connection. Then, if connected, it displays the interface (menu).
🕷🕸 The device shows four different modes on the interface:
- A. This Week
- B. Next Week
- C. Previously
- D. Graphics
🕷🕸 The device allows the user to select a mode (option) on the interface via the control buttons:
- Up ➡ Go Up
- Down ➡ Go Down
- OK ➡ Activate
🕷🕸 While selecting a mode on the interface with the Up and Down buttons, the device turns the RGB LED to a different color for each mode and activates the vibration motor to notify the user.
- This Week ➡ Purple
- Next Week ➡ Cyan
- Previously ➡ Yellow
- Graphics ➡ Green
🕷🕸 After activating any modes, the device lets the user return to the interface by pressing the Up or Down button.
📌 A. This Week
🕷🕸 The device plays the Spider-Man theme song (1967).
🕷🕸 The device connects to the web application (New Comics Releases) to retrieve and query this week's comics release list.
🕷🕸 The device displays the fetched comics release list and date, including these publishers:
- Marvel Comics
- DC Comics
- Image Comics (optional)
🕷🕸 The device allows the user to scroll the obtained comics release list by using the Right and Left buttons.
📌 B. Next Week
🕷🕸 The device plays the Spider-Man theme song (1967).
🕷🕸 The device connects to the web application (New Comics Releases) to retrieve and query next week's comics release list.
🕷🕸 The device displays the fetched comics release list and date, including these publishers:
- Marvel Comics
- DC Comics
- Image Comics (optional)
🕷🕸 The device allows the user to scroll the obtained comics release list by using the Right and Left buttons.
📌 C. Previously
🕷🕸 The device plays the Spider-Man theme song (1967).
🕷🕸 The device connects to the web application (New Comics Releases) to retrieve and query the previous week's comics release list.
🕷🕸 The device displays the fetched comics release list and date, including these publishers:
- Marvel Comics
- DC Comics
- Image Comics (optional)
🕷🕸 The device allows the user to scroll the obtained comics release list by using the Right and Left buttons.
📌 D. Graphics
🕷🕸 The device lets the user show different graphics (monochrome images) by adjusting the potentiometer value from 1 to 10 :)
Videos and Conclusion
data:image/s3,"s3://crabby-images/68338/68338539db6550bd9b2dd58f18408bf77ba110d9" alt="Playing Spider-Man Theme Song w/ Buzzer | Marvel and DC Weekly New Comics Release List Tracker"
data:image/s3,"s3://crabby-images/2bb3f/2bb3f0e6d2680484412ebd9ee8d1b4360974c23f" alt="Marvel and DC Weekly New Comics Release List Tracker | Demonstration"
data:image/s3,"s3://crabby-images/40b53/40b53f4c4a40aa8e0380f0a9d7154004dbdfd319" alt="conclusion.jpg"
After completing all steps above, I placed the device in my bookcase as a fitting and stylish decoration, where I store my comic book collection. It works stupendously :)
Schematics
data:image/s3,"s3://crabby-images/5d5a7/5d5a7e651793ed96672408c140835476c8e44f9c" alt="PCB_1.PNG"
data:image/s3,"s3://crabby-images/588d5/588d56b5426423f33f5422ce043fe2d5bd433829" alt="PCB_2.PNG"
data:image/s3,"s3://crabby-images/52060/5206087369ec4163d6412cdf18c44a48d7b95b59" alt="PCB_3.PNG"
data:image/s3,"s3://crabby-images/f83e5/f83e5cf7d9f640aba42b29073aad2d66c621ebbb" alt="PCB_4.PNG"
data:image/s3,"s3://crabby-images/280ac/280ac9278e9b4d7643df7ffea7bd060a0801d6a0" alt="PCB_5.png"
data:image/s3,"s3://crabby-images/a6228/a62281b422694287ce3c1af11ac384a3607e2472" alt="PCB_6.png"