QR Display Badge

by Makertronics in Circuits > Wearables

5291 Views, 60 Favorites, 0 Comments

QR Display Badge

IMG_1677.JPG
QR Display Badge

QR has become one of the most prominent sources of sharing links among ourselves, whether for social media or any payment link, everything seems one scan away. So, keeping the trend alive, I wanted to create a QR that anyone can wear as a badge and share any link like their portfolio, social media handles, etc. and event change the link anytime with their mobile app.


Supplies

QR Display Badge Supplies.jpg
QR Display Badge Supplies 2.jpg

Components

  • ESP12-E/F
  • SPDT Switch as On/Off Switch
  • ST7789 - 240x240 IPS display
  • 2* 10k Ohm Resistor (SMD 0805)
  • Lipo Battery
  • TP4056 Lipo Charger
  • PCB

Tools / Extra Stuff

  • 3D Printed Parts
  • FTDI or NodeMCU for Programming
  • Double-Sided Tape or Glue Gun
  • Soldering Iron
  • Wires
  • KeyChain/Safety Pin (Optional)

Software

  • Arduino IDE

Circuit Designing

QRDisplayBadge_EagleCAD_Schematic.png
QRDisplayBadge_EagleCAD_Board.png
image3087.png

I used EagleCAD to design the schematic and board for this project.

The microcontroller of choice is ESP8266 in the form of the ESP12-E/F Module. The Display used is ST7789 IPS Display of 240X240 Resolution. The board also includes the pads for programming and power supply, coming out of the TP4056 lipo charge and protection circuit.

PCB Manufacturing

PCB_Order.gif
IMG_1551.JPG
IMG_1545.JPG
IMG_1525.JPG

After creating the schematic and board design, rather than troubling myself with homemade PCBs, I generated the Gerber File (you can download it from this link) and ordered from the quick PCB Prototyping service of PCBWay.com, and within a few days 10 pcs of professional-made PCBs arrived at my home.

PCB Assembly

pcbassembly.gif
pcb diagram.gif
IMG_1591.JPG
IMG_1598.JPG

After receiving PCBs and all the components it's time for the fun part i.e. soldering and assembling.

I started with ESP followed by SMD Resistors and the Switch then soldered the programming wires and the display followed by the lipo battery.

Soldering Display and Batteries

IMG_1597.JPG
IMG_1608.JPG
IMG_1606.JPG

After soldering all the components we can go for the display for which although through-hole pads are provided in the PCB but I still attached the display using wires so as to make assembly in the enclosure easier.

I removed the male Header Pins soldered onto the display and the soldered it will wires.

Thereafter you can connect the lipo battery to the Charge Circuit and then connect the output from the charge circuit to the Power Pads on the PCB.

Also, solder the wires on the programming pads on the back of the PCB which will be used for programming the ESP12 Module.

Programming ESP12-E/F

IMG_1595.JPG
Copy of QRDisplayBadge PCB Diagram 1.jpg

You can find the code on my Github or as a Zip File from this Link.

In the Arduino IDE, we need to install the following Libraries

  • ArduinoJson.h
  • FS.h
  • Adafruit_GFX.h
  • Adafruit_ST7789.h
  • ESP8266WiFi.h
  • ESP8266WebServer.h

The rest of the libraries which are needed for QR Generation are attached in the Zip file and I recommend you to use the same folder hierarchy for proper compilation of the code.

You can use FTDI or NodeMCU to program the ESP12 module, I choose the NodeMCU option as it is easy because we don't require the flash and reset button separately.

To use the NodeMCU option assemble the circuit as shown in the image above and simple connect the NodeMCU using a USB cable.

The ESP will be used as an access point and will host a webpage from which we can control the QR Display(Demo in Step 10) The webpage which is hosted is loaded in the memory of ESP i.e the SPIFFS memory and to load the files into the memory of ESP we need to use the "ESP8266 Sketch Data Upload" option in the Tools section of the Arduino IDE which the board Selected is ESP8266.

If you can't see this option then you need to undergo a few steps which are well explained by Andreas Spiess in this video.

So after you install all the tools needed then you can first load the data by using the ESP8266 Sketch Data Upload option and then upload the code provided

After programming desolders the programming wires.


3D Print Enclosure

IMG_1542.JPG
IMG_1538.JPG
IMG_1541.JPG
IMG_1543.JPG

There are only two parts that need to be 3d Printed

Top Cover

Bottom Cover


Both the parts don't require any support and contain a few short bridges which can be printed with any FDM 3D Printer.

I have also attached the STEP file if you want to tweak any parameter.

Assembly

assembly.gif

This is just an Animation of the assembly for reference purposes.

Attach Display to Top Cover

snap_fit_for_dispplay.gif
IMG_1609.JPG
IMG_1610.JPG
IMG_1613.JPG

In the Top Cover, there are snaps that are made to secure the display to the top part without using any screws or adhesive. Just push the display against it and it will snap into it.

Bottom Cover Assembly

snapfit for body.gif
IMG_1616.JPG
IMG_1615.JPG
IMG_1617.JPG

In the Bottom section, we will install the assembled PCB, TP4056 lipo protection, and charge circuit then we need to add the lipo battery to it and then we can close the top cover using the snaps built into the top part. To secure the Board onto the base I have used two layers of double-sided tape and the same for the TP4056 Charge Module.

You can alternatively use some glue gun to stick the board to the base.

Testing the Features

TestFeatures.gif
assembeled.gif

As all the steps are complete now we can test the features.

To connect to the Badge we need to go to the wifi options and connect to the "ESP_AP" by using the password set in the Arduino code.

Then we need to open the browser and go to "192.168.4.1"

There we can enter the link for which we want to show the QR on the display and also we can configure the four buttons for predefined links so that you will be able to change the QR on display without entering any link.

When we open the main page i.e. "192.168.4.1" the link showing in the field is the one that is currently being shown on the Badge.


Applications

IMG_1681.JPG
IMG_2014.png
IMG_1685.JPG
IMG_1692.JPG
IMG_1695.JPG

Woohoo...you have created a digital QR Display Badge which you can use anywhere by attaching to keychains, backpacks, T-Shirts, Shirts, Trousers, or Blazers and I am sure you can find many more places where you can attach your badge & share any link as QR to the world.


If you made one for your self then do share it below and if you face any issue during building drop me a message, I would love to help as much as I can.