Introduction: My Arduino Binary Clock

Hi from Italy
Although many watches are created binary, my project was inspired mainly to this:
http://, very smart and funny.
I tried to improve the design and to add something personal.
I think it's a good result at the end.
The project is not difficult, requires patience, it requires a little knowledge of electronics and the use of Arduino.

Ok, check out the video and if you like it lets start!

Step 1: List of Materials

-n.1 IKEA frame called "Ribba" 13x18 cm
-LED to mark hours and minutes (You have seen the first images of the LEDs that there are different colors, but of course you can change them as you like, now is the reference of the project.):
n.8 green 5 mm
n.3 red 5mm
n.2 yellow 5 mm
-LED to light the words "Hours Minutes"
n.7 white 5mm
-LED to light the numbers 1/2/4/8
n.4 pink 5mm
-LED to light the words "binary clock"
n.4 pink 3 mm
-n.24 Resistor 220 ohm (for 5mm led)
-n.4 Resistor 150 ohm (for 3mm led)
-Cartonboard thicker to make LED holder
(we will Insert the cartonboard between the glass and the bottom of the frame supporting)
-Some acetate (4-5) sheets (for inkjet or laserprint) to create the mask
-a flat wire 26 wire
-3 micro button to set hours and minutes and on/off
-A small piece of prototyping PCB to make the shield (see later)
-Some double strip
-n.1 Arduino Uno/2009 or clone or self made. I've used one Luigino assembled by me
-Power supply 6V 500ma or other Arduino compatible.

Step 2: Goals

At the beginning we try to understand how reading the time, I think it's important to understand the electronic connections.

The first two columns correspond to the hours, the third and fourth to the minutes.

The first column are the units of hours and the second the tens, the same thing for minutes.

For each column must add the corresponding value (displayed on the right with the numbers 1-2-4-8) and reading the following you have the time in 24h format.

It 'very simple, we take the example of the first photo you see above:
-first yellow spot= 10
-3 green spot= 7 (4+2+1)
-first and third red spot= 50 (40+10)
-2 green spot= 5 (4+1)
So , 17:55 ok?

So we have to create a set of LEDs to display the time in this way, the circuit and the program will be managed by Arduino.

The remaining lights (Hours, Minutes, 1/2/3/4, binary clock) are embellishment for the clock (also improve the general understanding) but still managed by Arduino.

Step 3: Schematic

This is the pattern that we must achieve.


All LEDs who rule the time are connected with the cathode (negative -short leg) and a 220 ohm resistor to digital pin, all the anodes (positive-long leg) are connected together with 5v by Arduino. (see photos in the next step)

All LEDs embellishment (words "Hours / Minutes / BinaryClock") are connected in parallel and that all the anodes are connected together with a resistor and goes to the PIN 0 (see photos in the next step), all the cathodes are connected together and go to the GND

The micro buttons are connected to one side to the Analog pin and the other side to GND.

More precisely (see the schematic picture):

units of Minutes

tens of Minutes

units on Hours

tens of Hours

to ARDUINO DIGITAL PIN 0 (all toghether)

As you read above we will have 3 micro button.
1th Button will change minutes, adding one for each time you press it. ANALOG PIN 0
2th Button will change hours, adding one for each time you press it. ANALOG PIN 5
3th Button (optional) will turn ON/OFF the clock LEDs, but keep counting the time. ANALOG PIN 4

Step 4: Lets Start the Constructions

Lets see the pictures in sequence

-Cut the cardboard exactly the same size of the interior of the frame.
-Printed on a sheet of paper the positive mask (as does the attached file), this will help you make the holes in exactly the desired position.
-Attach the sheet printed in a positive view at the center of the frame considering the white passepartout of the IKEA frame.
-Make a hole for each LED you need to installI, i've used a a drill with a bit of 5mm for all LED except those that make up the word "BINARY CLOCK" where i've used a bit of 3 mm.
Always test the operation of the LED before proceeding with the next


-As shown in the picture, bend down the anode and up/bended left the cathode.
-Trip leaving 2-3 mm the cathodes and the 220 ohm resistor and sold it toghether.

-For these LEDs you can find the layout you like best, the important thing, as explained in a previous step, is to cut a portion of the anodes and solder one 220 or 150 ohm (depends the led size) resistor, the goal is to have all the LEDs in parallel connection, all the anodes soldered together, and all the cathodes soldered together.
All the secondary lights are switched on simultaneously.

Write on the cardboard the number of each pin and the words, it will help to sold the wires later

Add some buffles to prevent the light from bleeding between words and number.
Cut the buffles about 1 cm hight, the goal is to have enough space for the wires and the back of the frame.
I've used hot melt glue to do attach these.

Step 5: Connect the Wires

I've used a flat wire of 26 wires removed to an old computer.

You need 23 wires for this project, I chose this solution for comfort but of course you can use a single wire for each pin or group.

Be careful to count in sequence to connect the wires on the right LED, wire 1 on LED1 to Pin 1, wire 2 on LED2 to Pin 2 and so on.

Let the last wire (6) to connect the micro buttons on the left (see in later)

Add some separators with rubber adhesives, cutting them (adjust the height) so that the back of the frame is perfectly suited to the edge (see the pictures later)

Step 6: Insert the Mask

Print the attached picture (negative) on a lucid (acetate) paper with a Laser print (better) or Ink Jet printer .

Cut out the attached picture (negative) leaving 0.5 mm for side and place on the passepartout of the frame with some piece of adhesive tape.
Make the first tests of illuminating LEDs to get the perfect alignment with the mask.

For a better spread of light and have a solid black I have three layers overlapped acetate, at the end I put a layer of gray and a white matt for better light diffusion.

Step 7: Layout

Step 8: Create the Arduino Shield

If you want you can buy a card that is already ready, but it is very simple and useful to make it at home.

Cut a piece of prototyping PCB exactly the width of the pins on the card.

Sold only the strips those that correspond exactly to the pins we're going to use: Pin0 to Pin13- Analog 0-4-5- 5v- GND

The position of the pins can change, depending on the card we're going to use, Arduino, Luigino and so on, but the goal is clear.

Once you have made the shield, you will have more space to sold each wire on the corresponding pin.

Will also be much more convenient to leave the Arduino connected on the back (see later) only by detaching the shield if you do the maintenance in.

Go on!

Step 9: Connect the Micro Buttons

As you have read, the micro button are 3:
-set hours
-set minutes
-set on/off light (but the clock goes on) (optional)

Choose the location of the buttons, personally I preferred the one you see in the picture for a better use and arrangement of internal wires.

The buttons are of 6 mm square, draw a picture in trackbacks for precise positioning.

Drilled in the center with a 4 mm tip of the squares drawn.

Use a little square file and patience, it is better to close that hole too wide, go step by step and try the size.

When the buttons are positioned solder the wires as explained in the previous step

Cover with hot glue the buttons to prevent from leaving the site and protect the solder joints.

Step 10: Place the Arduino

Make four holes on the back of the frame pannel to match up the card, and fastened with screws and little bolts under the frame stand.

Step 11: Upload the Sketch

The method can be different, depending if you use an Arduino (USB), Luigino (I removed the chip and I programmed with another arduino), and so on, but this is another instructables..

Thanks for watching

Step 12:

4th Epilog Challenge

Participated in the
4th Epilog Challenge