SHROOM From Super Mario

by Arnov Sharma in Circuits > Microcontrollers

3176 Views, 42 Favorites, 0 Comments

SHROOM From Super Mario

SHROOM PCB BADGE from super mario Attiny85
23 (25).gif
25 (18).gif
IMG_0633.JPG

Hey what's up guys, this is the SHROOM PCB Badge that is themed after SHROOM from Super Mario.

This wearable Badge is made completely from PCB I got from PCBWAY and is powered by an Attiny85 which is in the SOIC8 Package.

I added three WS2812B LEDs to this badge which are visible from the front side of the board.

These LEDs are placed in an inverted position so their glow will be visible from the front side through the soldermask opening I left in both layers.

This Instructables is gonna be about how I made this project so without further ado let's get started!

Supplies

IMG_0607.JPG

Following were the componenets I used in this build-

  • custom PCB
  • Attiny85
  • WS2812B LEDs
  • 1uf 0805 CAP
  • Brooch pin
  • SMD Coin Cell holder
  • CR2032 cell
  • Attiny programming setup (Arduino nano)
  • SOIC8 Clip

About This Project

lol-super-mario.gif
17 (37).gif

My goal here was to make something related to Super Mario, recently I've been making all sorts of PCBs themed after animes or comic characters but I never made anything related to Super Mario so I decided to make a shroom badge with LEDs so I could wear it or add it to my backpack.

Mario themed badge is currently in development.

Technical Details

IMG_20220417_000847.jpg
AT.jpg
1655-00.jpg

This badge is powered by an Attiny85 which is a low-power Microchip 8-bit AVR® RISC-based microcontroller that combines 8 KB ISP Flash memory, 512B EEPROM, 512B SRAM, six general-purpose I/O lines.

It's a powerful little MCU that can be implemented in any of the basic Arduino projects to shrink the whole setup.

Do check out its datasheet for more details- https://www.microchip.com/en-us/product/ATtiny85

To power the whole setup, I used a CR2032 Coin cell that delivers 3V to the system.

Then there are three WS2812B LEDs that each draw 50mA so 150mA in total which would give us a backup of 1 Hour + as CR2032 has a capacity of 210mAh.

Datasheet for WS2812B LEDs

https://cdn-shop.adafruit.com/datasheets/WS2812B.pdf

Shroom Character

618570.bmp
Image1.jpg

As for the custom PCB that is themed after Shroom, I had to first get an image which has to be imported into my PCB Cad software.

I choose the above black and white image and imported it as a PCB layer.

PCB Design

SHROOM_page-0001 (1).jpg

PCB that I made for this project is a simple board, let me explain why.

Schematic

In the schematic, I placed an Attiny85 that does all the work of controlling three WS2812B LEDs that are connected in Din Dout Config.

Dout of 1st pixel goes to Din of 2nd pixel, Dout of 2nd pixel goes to Din of 3rd pixel, we supply a signal to Din of the first pixel to control all three of them.

Each LED has its 1uf capacitor and then there's a switch that is connected to D4 of the Attiny85.

This whole setup is then powered by a coin cell holder that we up the coin cell into.

After finalizing the schematic, I converted it into a board file and started the editing process.

PCB Board

Capture.PNG

I first imported the Shroom image and use it as a PCB Outline and a few of its details were used to make a silkscreen layer.

All the components that I'm using are SMD ones so I placed them at the backside, I placed LEDs in the circle area.

Why? because I added a soldermask opening in the circle area and now the glow of leds would be visible from the TOP side.

Also, I'm using an inverted custom footprint that I made for these WS2812B LEDs.

We have to solder LEDs upside down instead of soldering them normally.

PCBWAY

01 (59).gif
IMG_0603.JPG
IMG_0604.JPG

After Checking the board for one last time, I sent the Gerber data to PCBWAY for samples.

I received the PCBs in a week which was fast.

I choose RED Soldermask for this project with a white silkscreen.

I've Left openings in the soldermask on both sides, the idea here was that the LEDs which are on the bottom side would be visible from the topside.

The quality of the PCB I received was just awesome.

I have Been using their service for a while and I have to say, it's pretty decent for getting started.

Checkout PCBWAY from here- https://www.pcbway.com/

PCB ASSEMBLY

These are the steps for the main assembly of the Shroom Board

  • Solder paste Dispensing Process
  • Pick & Place Process
  • Hotplate Reflow
  • LED Placement

Because this PCB Doesn't have any Through-hole component, we do have to add LEDs with a soldering iron.

SOLDER PASTE DISPENSING

02 (60).gif

Now the first step is to add solder paste to each components pad one by one.

To Apply solder paste, I'm using a Solderpaste Dispensing Needle with a Wide syringe, and the solder paste I'm using is a regular solder paste consisting of 63% Tin and37% Lead.

Pick & Place Process

03 (56).gif

After applying Solderpaste we move on to the next step which is to add components to their assigned location.

I used an ESD Tweezer to place each component in its place.

Hotplate Reflow

04 (59).gif
05 (56).gif

After the "Pick & Place Process", I carefully lifted the whole circuit board and place it on my DIY SMT Hotplate.

the hotplate heats the PCB from below up to the solder paste melting temp, as soon as the PCB reaches that temp, solder paste melts and all the components get soldered to their pads, we lift the PCB and then place it on a cooler surface for a little bit, to cool down the heat of PCB.

LED Placement

06 (55).gif
07 (59).gif
08 (55).gif
09 (52).gif
10 (59).gif
11 (59).gif

As for the LED placement, I first added solder wire to one pad and then connected the LED pad with it.

The key here is to be quick as overheating the LED pad would affect LED's plastic casing and it may melt.

Then we add solder wire to the remaining pads and redo this process on two more leds.

Flashing the Attiny85

13 (54).gif
15 (48).gif

As for the Flashing Process, we cannot directly program ATTINY85 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 attiny85 to burn the bootloader in it and then Flash.

To connect the Attiny with the programmer, I used my SOIC clip to which we can directly connect the attiny.

Getting Attiny85 Core Installed on Arduino IDE

Before starting the Flashing process, we first need to download and install the Attiny85 Core files in Arduino IDE.

https://github.com/SpenceKonde/ATTinyCore

  • File->Preferences on a PC, or Arduino->Preferences on a Mac, enter the above URL in "Additional Boards Manager URLs
  • Tools -> Boards -> Boards Manager... *If using 1.6.6, close boards manager and re-open it (see below)
  • Select "ATTinyCore by Spence Konde" and click "Install".

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 Attiny85, we can select the Attiny85 in the Board section.

The programming process uses VCC, GND, and four data pins. Three pins connect MISO, MOSI, and SCK between the programming micro and the target micro, the fourth pin from the programming micro goes to the reset pin of the target.

Wire the Attiny85 with Arduino in the above way. (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-ATtiny8513A...

  • 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 a 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 attiny85.

CODE

money-type.gif
Image20.jpg

this was the code that I used and it's the Neopixel buttoncycler sketch that changes the color and animation of neopixels on the press of a button connected to D4 of the attiny.

#include <Adafruit_NeoPixel.h>

#define BUTTON_PIN   4    // Digital IO pin connected to the button.  This will be
                          // driven with a pull-up resistor so the switch should
                          // pull the pin to ground momentarily.  On a high -> low
                          // transition the button press logic will execute.

#define PIXEL_PIN    0    // Digital IO pin connected to the NeoPixels.

#define PIXEL_COUNT 3

// Parameter 1 = number of pixels in strip,  neopixel stick has 8
// Parameter 2 = pin number (most are valid)
// Parameter 3 = pixel type flags, add together as needed:
//   NEO_RGB     Pixels are wired for RGB bitstream
//   NEO_GRB     Pixels are wired for GRB bitstream, correct for neopixel stick
//   NEO_KHZ400  400 KHz bitstream (e.g. FLORA pixels)
//   NEO_KHZ800  800 KHz bitstream (e.g. High Density LED strip), correct for neopixel stick
Adafruit_NeoPixel strip = Adafruit_NeoPixel(PIXEL_COUNT, PIXEL_PIN, NEO_GRB + NEO_KHZ800);

bool oldState = HIGH;
int showType = 0;

void setup() {
  pinMode(BUTTON_PIN, INPUT_PULLUP);
  strip.begin();
  strip.show(); // Initialize all pixels to 'off'
}

void loop() {
  // Get current button state.
  bool newState = digitalRead(BUTTON_PIN);

  // Check if state changed from high to low (button press).
  if (newState == LOW && oldState == HIGH) {
    // Short delay to debounce button.
    delay(20);
    // Check if button is still low after debounce.
    newState = digitalRead(BUTTON_PIN);
    if (newState == LOW) {
      showType++;
      if (showType > 9)
        showType=0;
      startShow(showType);
    }
  }

  // Set the last button state to the old state.
  oldState = newState;
}

void startShow(int i) {
  switch(i){
    case 0: colorWipe(strip.Color(0, 0, 0), 50);    // Black/off
            break;
    case 1: colorWipe(strip.Color(255, 0, 0), 50);  // Red
            break;
    case 2: colorWipe(strip.Color(0, 255, 0), 50);  // Green
            break;
    case 3: colorWipe(strip.Color(0, 0, 255), 50);  // Blue
            break;
    case 4: theaterChase(strip.Color(127, 127, 127), 50); // White
            break;
    case 5: theaterChase(strip.Color(127,   0,   0), 50); // Red
            break;
    case 6: theaterChase(strip.Color(  0,   0, 127), 50); // Blue
            break;
    case 7: rainbow(20);
            break;
    case 8: rainbowCycle(20);
            break;
    case 9: theaterChaseRainbow(50);
            break;
  }
}

// Fill the dots one after the other with a color
void colorWipe(uint32_t c, uint8_t wait) {
  for(uint16_t i=0; i<strip.numPixels(); i++) {
    strip.setPixelColor(i, c);
    strip.show();
    delay(wait);
  }
}

void rainbow(uint8_t wait) {
  uint16_t i, j;

  for(j=0; j<256; j++) {
    for(i=0; i<strip.numPixels(); i++) {
      strip.setPixelColor(i, Wheel((i+j) & 255));
    }
    strip.show();
    delay(wait);
  }
}

// Slightly different, this makes the rainbow equally distributed throughout
void rainbowCycle(uint8_t wait) {
  uint16_t i, j;

  for(j=0; j<256*5; j++) { // 5 cycles of all colors on wheel
    for(i=0; i< strip.numPixels(); i++) {
      strip.setPixelColor(i, Wheel(((i * 256 / strip.numPixels()) + j) & 255));
    }
    strip.show();
    delay(wait);
  }
}

//Theatre-style crawling lights.
void theaterChase(uint32_t c, uint8_t wait) {
  for (int j=0; j<10; j++) {  //do 10 cycles of chasing
    for (int q=0; q < 3; q++) {
      for (int i=0; i < strip.numPixels(); i=i+3) {
        strip.setPixelColor(i+q, c);    //turn every third pixel on
      }
      strip.show();

      delay(wait);

      for (int i=0; i < strip.numPixels(); i=i+3) {
        strip.setPixelColor(i+q, 0);        //turn every third pixel off
      }
    }
  }
}

//Theatre-style crawling lights with rainbow effect
void theaterChaseRainbow(uint8_t wait) {
  for (int j=0; j < 256; j++) {     // cycle all 256 colors in the wheel
    for (int q=0; q < 3; q++) {
      for (int i=0; i < strip.numPixels(); i=i+3) {
        strip.setPixelColor(i+q, Wheel( (i+j) % 255));    //turn every third pixel on
      }
      strip.show();

      delay(wait);

      for (int i=0; i < strip.numPixels(); i=i+3) {
        strip.setPixelColor(i+q, 0);        //turn every third pixel off
      }
    }
  }
}

// Input a value 0 to 255 to get a color value.
// The colours are a transition r - g - b - back to r.
uint32_t Wheel(byte WheelPos) {
  WheelPos = 255 - WheelPos;
  if(WheelPos < 85) {
    return strip.Color(255 - WheelPos * 3, 0, WheelPos * 3);
  }
  if(WheelPos < 170) {
    WheelPos -= 85;
    return strip.Color(0, WheelPos * 3, 255 - WheelPos * 3);
  }
  WheelPos -= 170;
  return strip.Color(WheelPos * 3, 255 - WheelPos * 3, 0);
}


POWER SOURCE

18 (41).gif

As for the power source for this project, we can power it up with a CR2032 Coin Cell.

RESULT

SHROOM PCB BADGE from super mario Attiny85
17 (43).gif
18 (41).gif
21 (33).gif
24 (22).gif
25 (18).gif

here's the result.

This is it for today, Leave a comment if you guys need any help, and I'll be back with another project soon!