Majin Vegeta on a PCB

by Arnov Sharma in Circuits > Arduino

2109 Views, 0 Favorites, 0 Comments

Majin Vegeta on a PCB

28 (1).gif
01 (22).gif
02 (22).gif
03 (22).gif
04 (23).gif
IMG_20210821_231751.jpg

Hey Everyone What's up!

So this is my Majin Vegeta PCB Badge or PCB Art (actually I'm not sure what to call this thing I made)

It's basically a Blinky Board powered by an Attiny13A Microcontroller, 12 LEDs constantly Fades IN and OUT in this setup with the help of 8205S Mosfet Driver IC.

In a nutshell, it's an Over-Engineered Blinky Board with lots of LEDs and an anime character printed on the TOP silkscreen.

Pretty sick right?!

In this Instructables, I'm gonna show you guys how I made this Blinky Board in few easy steps.

Let's get started.

Supplies

Following are the things I used in this built

  • Custom PCB
  • Attiny13A SOIC8 MCU
  • SMD LEDs RED 0603
  • 8205S Mosfet IC
  • 10K 0603 Resistor
  • 1K 0603 Resistor
  • SMD Button
  • THT Switch
  • Solder paste
  • 3D Printed Frame
  • Header Pins
  • USB Micro THT Port
  • Coin Cell holder
  • Coin Cell, CR2032

Prologue

07 (23).gif
nqwry1nqyli51.png
IMG_20210821_231754.jpg

So recently I've been making these cool-looking PCB badges of nerdy stuff from movies and anime!

Like for example, Previously I made a Goku Badge, in which the famous character Goku is doing his Kamehameha chi blast attack, so added LEDs in Kamehameha place and drive those LEDs in a chasing sequence to create an illusion of the Kamehameha and I also made a Flux Capacitor Badge.

https://www.instructables.com/Flux-Capacitor-PCB-B...

https://www.instructables.com/Goku-PCB-Badge/

My point here is that we can make anything into PCB, just visualize and get creative with the idea.

But why make PCB Badge when you can prepare a 3D Printed body of that character?

You see, it's more convenient to make a PCB Badge than making a whole 3D Printed body of XYZ stuff, let me explain why.

Badge shape can be made in PCB Cad software, we can add our character's drawing on the PCB Silkscreen, then place components like LEDs around the drawing. In the end, we generate Gerber data and send it to a PCB manufacturer. That PCB Manucature will produce the Badge professionally and we don't have to do anything except for the unboxing and the assembly process.

By the way, I used PCBWay Service for this PCB Badge this time! more about that in few mins!

Schematic of the PCB

10 (21).gif
SCH_page-0001.jpg
6 (2).gif

Here's the main schematic of the whole PCB which is actually pretty simple.

Attiny13A is connected with an SMT Button and a con6 Header pin which is for programming the microcontroller.

Mosfet IC 8205S Drives all the 12 LEDs and the Attiny13A Controls the Mosfet IC's Gate.

Downloads

PCB Designing Process

03 (22).gif
dragon-ball-super-74-vegeta-provocazione-vera-minaccia-v3-529618.jpg
ddf17i0-8e65c151-dccb-4d45-afd1-b6a45e98723a.bmp
Capture.PNG
IMG_20210821_192940.jpg

To Design this Majin Vegeta PCB

  • I first think about ways that I could add Vegita's face in the PCB and add LEDs on it.
  • I Google-searched a few images and finally choose the image in which a huge M was written on his forehead.

My goal here is to add RED LEDs in this M Shape.

  • we convert this image into a BMP image as my software only imports logos in BMP format which is a standard format for importing image but other software include adding PNG so you can skip this converting process and import your image into the PCB Cad software. (how to do that? well in my OrCAD software, I have to make a logo file first and then add the image into this logo file, later then I can import the logo file into my PCB design. this process is long and your software probably can directly import the image so search around for any imported image option or just google how you can do that in your PCB cad software)
  • Next, we place all the components around the logo or on the logo like in my case, LEDs are on this character's forehead.

  • then we connect tracks and do the general thing which is required in a PCB Designing process. which is to connect tracks one by one.

  • then we have to import the Gerber data and our PCB-making Process is complete!

  • But before sending the PCB File to the manufacturer, open the Gerber data in any PCB Rendering software, your software already has this feature so just see how your PCB will look after getting manufactured.

  • after making sure that everything is fine, we send it to any PCB manufacturer that we like. In my case, I send the Gerber data to PCBWay for samples!

Getting PCBs Ready

30 (1).gif
31 (1).gif
8 (3).gif
IMG_20210821_192956.jpg
Image4.jpg

I will be using a White PCB Soldermask color with a Black Silkscreen. Why? because it will look like a Manga Panel and also, white PCBs look great with black silkscreen.

To get the PCBs Ready, I send the Gerber data to PCBWay for samples!

I received PCBs in a week and the PCBs were nice as expected.

I really like the quality of the white solder mask, also it was a tough job as the silkscreen that I have laid out o this board was not completely symmetrical but PCBWAY did an excellent job of manufacturing this PCB with no error whatsoever.

PCBWay you guys rock, check out PCBWay service for getting great PCB service at less cost.

By the way, yes I have included that famous line in this PCB!

"It's over 9000" haha.

​Assembly Process

IMG_20210821_210128.jpg

The Assembly process of this badge includes four different processes, which are-

  • Solder paste Dispensing
  • Pick and Place Process
  • Hotplate Reflow
  • Adding THT Components

#1 Solderpaste Dispensing

12 (17).gif

The First Step of the assembly process is to dispense or apply solder paste to the pads of each component.

Solder paste if you don't know is basically a semi-liquid mixture of very small solder balls and flux.

I added solder paste to each components pad with help of a solder paste dispensing syringe.

but the right way to do this process is to use a stencil.

#2 Pick and Place Process

14 (12).gif
13 (14).gif

Next, we carefully pick all the components with an ESD tweezer and place them in their assigned place one by one.

this one is a manual process so you have to do this properly, check the alignment and polarity of components so shorting can be avoided in the next process.

#3 Hotplate Reflow Process

15 (13).gif
16 (10).gif
17 (10).gif

After this, I carefully lift the PCB and place it on a reflow hotplate for SMT REFLOW.

Hotplate SMT Reflow is a process of heating the PCB up to the solder paste melting temperature which is usually 170-250°C depending on solder paste Sn-Pb Ratio.

I'm using my DIY Hotplate for this project though, it doesn't have a temperature control feature but it works.

https://www.instructables.com/DIY-SMT-Hotplate-Project/

After a few mins when the solder paste completely melts, we remove the PCB and let it cool down for a moment.

#4 Adding THT Component

20 (9).gif

Next, we add THT Components to the PCB which are USB Port, Coin Cell holder, Header pins, and THT Switch with a soldering iron.

After this, we remove any shorting that might occur during the Hotplate process and that's pretty much the assembly process of this whole board.

Now we flash code into the attiny13 and see the result!

CODE and Flashing Process

05 (21).gif

This is the code that I have used in this project, it's a Switch-based Sketch that has few modes in it.

On the first button press, LEDs will start their fading sequence.

On Second Tap, LEDs will stay in HIGH Mode.

And on Third Tap, LEDs will turn OFF.

Then this whole process will loop.

int switchPin = 4;     //4         
int led1Pin = 0;        //0

int brightness = 0;    // how bright the LED is
int fadeAmount = 5;    // how many points to fade the LED by


int val;                        
int val2;                       
int buttonState;                
int Mode ; //= 0;              

void setup() 
{
pinMode(switchPin, INPUT_PULLUP);    
pinMode(led1Pin, OUTPUT);
buttonState = digitalRead(switchPin); 
}

void loop(){
 
      val = digitalRead(switchPin);      // read input value and store it in val
      delay(10);                         // 10 milliseconds is a good amount of time
      val2 = digitalRead(switchPin);     // read the input again to check for bounces
      
      if (val == val2) {                 // make sure we got 2 consistant readings!
        if (val != buttonState) {          // the button state has changed!
          if (val == HIGH) {                // check if the button is pressed
            if (Mode == 0) {         
              Mode = 1;               
            } else {
                if (Mode == 1) {       
                Mode = 2;           
            } else {
                if (Mode == 2) {     
                Mode = 0;           
            } 
           }
          }
         }
        } 
        buttonState = val;                 // save the new state in our variable
      }

      // Now do whatever the lightMode indicates
      if (Mode == 0) {                       // FLIP FLOP
        digitalWrite(led1Pin, LOW);
      }

      if (Mode == 1) {
        analogWrite(led1Pin, brightness);
        brightness = brightness + fadeAmount;
        if (brightness <= 0 || brightness >= 255) {
    fadeAmount = -fadeAmount;
  }
      }

      if (Mode == 2) {
        digitalWrite(led1Pin, HIGH);
      }
}
      
       <br>

Downloads

Getting Attiny13 Core Installed on Arduino IDE

Image6.jpg

As for the Flashing Process, we cannot directly program ATTINY13 through any USB, I mean there's a method for programming the Attiny straight from the USB port but I'm not doing that.

Instead, I'll be using the ISP flashing method which will utilize the SPI Pins of attiny13A to burn the bootloader in it and then Flash.

But Before starting the Flashing process, we first need to download and install the Attiny13 Core files in Arduino IDE.
https://github.com/MCUdude/MicroCore

Preparing the Arduino As ISP Setup and Final Flashing!

thumb1.jpg
19 (9).gif
21 (8).gif

AVRs chips usually come blank, they need to be set up to be Arduino IDE compatible but to do that you need an AVR programmer do to that, for example, a USBASP.

Fun Fact, you could make your own AVR Programer with an Arduino Uno or a Nano board in a very easy step.

  • Connect your Arduino board with com port and select the following sketch
  • Example>ArduinoISP upload this sketch onto your board
  • After uploading, go to the tools menu and choose the Arduino as ISP option in the programmer section.
  • Now for flashing Attiny13A, we can select the Attiny13A in the Board section.

The programming process uses VCC, GND, and four data pins.

Wire the Attiny13 with Arduino in this way.

  • VCC to VCC
  • GND to GND
  • D10 of Arduino Nano to RST Pin of Attiny13A
  • D11 of Arduino Nano to MOSI
  • D12 of Arduino Nano to MISO
  • D13 of Arduino Nano to SCK of Attiny13A

also right after uploading ISP Sketch to your Arduino, do not forget to add a 10uf Cap between Reset and GND pins of your Arduino board.

Instead of using an Arduino UNO and a breadboard for this job, I will use my DIY Attiny Programmer which I made for flashing the Attiny or Atmega MCUs. which you can check out from here- https://www.instructables.com/Multiple-ATtiny8513...

  • connect the Board to the Arduino as ISP Setup in the above wiring config.
  • choose the right port, right programmer (Arduino as ISP), and hit Burn Bootloader wait for few seconds, you will get done burning the bootloader message.
  • Now Open the sketch that you want to upload to this AttinyGo to the Sketch menu and select Upload using the programmer.
  • And your Sketch will get uploaded onto the attiny13.

3D Printed Frame

23.gif
32.gif
25.gif
27 (2).gif

Now, this PCB itself cannot be mount anywhere, so I design a wall mounting frame.

For Designing the frame, I used Fusion360.

  • I First took measurements of the PCB and the THT components location and their size so I could model the PCB first.
  • then I designed a Base Frame around the PCB that I modeled.
  • In the end, I exported its mesh file (STL FILE) and then 3D Printed it on my ENDER 3 with Black PLA at 10% Infill with a 0.5mm Nozzle.
  • I used Three Truss head 2.8mm Screws to mount the PCB onto the 3D Printed Frame and the project was completed.

As for the Power Source to run this PCB, we can power it directly from USB Port or we can add Coin Cell to this setup. (CR2032 Cell)

Result

28 (1).gif
29 (1).gif
IMG_20210821_231733.jpg
IMG_20210822_092421.jpg

This PCB Badge or Frame is working nicely, Fading is working and the normal ON and OFF feature is working as well.

And I'm pretty happy with the results overall.

With the 3D Printed Frame, I mounted this Setup on a wall with two nails.

Features, Conclusion and Further Improvements

IMG_20210822_223622.jpg
ddf17i0-8e65c151-dccb-4d45-afd1-b6a45e98723a.bmp
11 (20).gif

Here's what I learned so far by making a few of these Fancy PCBs.

  • Silkscreen is not just for labeling parts, it can be used to improve the artistic aspect of any boring PCBs just by adding few shapes or random polka dots or something similar. (geometrical shapes or stuff)
  • White Soldermask with Black Silkscreen is the best combination ever to design great looking PCBs
  • Complex Shapes can be made with PCBs but it's better to design them first in Fusion360 and then use the DWG file or other format to model the PCB shape.
  • try to use less complex images for silkscreen printing, Image should be a black and white image with high details.
  • Double-check the electrical setup before exporting the Netlist for PCB Editor. (because I missed a ground line for two LEDs)

Changes/ alteration and improvements list-

Now, I made one mistake in this PCB, I forget to add a connection between the Negative terminal of two LEDs to the drain of mosfet. because of this, two LEDs didn't turn ON, solution here was simple, I added a small wire to both of the Led's negative terminals and connect them with a nearby drain line.

this corrected the problem but I will be editing this on the PCB Directly in revision 2 of this project.

Anyways, Comment if you need any help! Peace out