Close
0%
0%

FlipClock

An Arduino-based graphical “flip clock”. Bonus faces because there’s room. Really minimal enclosure.

Public Chat
Similar projects worth following
I'd had the idea for a graphical flip clock for a while (run-length encode half-digit foreground/background data, draw every n-th row to get the look of a tipped split flap) but it was on the back burner. Then I found a pretty nice 3.5” 320x480 colour LCD (ILI948x driver) on a local market website. After implementing the clock I found I had room in the sketch and was inspired by the colourfulness of the LCD, so slapped in some other faces based on code from earlier projects; a cubist clock, a triangle clock and a pong clock.
The LCD is a shield socketed onto a blank intermediate shield with RTC and push-buttons directly attached. The intermediate shield is socketed to a Uno, creating a quite thick "sandwich".

I went with an ultra minimal enclosure, front and back clear acrylic plates.

The main clock display is the day, date and month in smallish flip-style digits across the top of the LCD (landscape mode).  The time is in big digits across the bottom. As a bonus, across the middle there’s a blinking/flipping colon and also a coloured digit indicating the number of days until I need to put out either the rubbish bin (red) or the recycling (yellow). It’s alternate weeks and I keep forgetting (this display is optional).  

The time digits change with a detailed 3-step animation (top flap at 41°, 90° and 131°).  The angles come from skipping every 4th row of the digit data, so it’s acos(3/4)=41°, close enough to 45°!

The LCD inspired me to add in some additional clock “faces”:

CubeClock

The LCD colours are appealing, so I experiment with coloured cubes. The look is based on this font www.dafont.com/kubics-rube.font

Triangle Clock

An adaptation of an eariler project with a triangulated irregular network (TIN) style face, more pretty colours.

PongClock

There was a little program memory left, so I squeezed in a very simple Pong Clock, again using code from an earlier project.

The sketch uses all but around 100 bytes of the Uno’s program storage space.

There are two push-buttons, Set and Adj. Pressing Adj from time display cycles through the faces (including a pseudo-face which randomly cycles through faces). Pressing Set from time display goes to the configuration screen. This uses the flip clock look. As well as setting the date and time it configures the red/yellow bin cycle (or none)

The clocks use a simple automatic DLS adjustment class which takes a table of start/end dates.

The LCD shield uses an ILI948x driver.  As always, the trick is finding some code which successfully initialises the display (including orientation).  The only other interaction is a) setting a “window” on the screen and b) filling it with colour data.

The viewing angle is fairly important, from the wrong angle the display is quite washed out.

This shield has a built-in SD-card reader, but no touch screen.  Fortunately that leaves pins 10,11,12,13 and A5 free. I connected SET/ADJ push-buttons to 10 & A5 and used 11 & 12 as SDA/SCL for a software I2C to the DS3231 real time clock module.

There was a lot of software in this project so when the time came to go from prototype to final assembly I decided to go to the other extreme and keep it as simple and minimalistic.   It starts with a blank stackable shield. This gave me access to the pins I needed for the RTC and the two switches. I mounted all directly to it. The LCD shield goes on top, and Uno underneath to create a quite thick sandwich.  This sandwich would actually have been enough, since it stands up OK. But I decided to add some protection in the form of two laser-cut clear acrylic plates. The Uno is attached to the back plate. The front plate is attached to the back plate with stacks of standoffs.

There is no backlight control and the thing is quite bright. To keep the build simple, there’s no LDR to sense ambient light and dim the display. Instead, there’s a bit of a hack in the sketch to optionally blank it between selected hard-coded hours (eg 7pm-7am). All that does is make the display black, but there’s still a glow - the copper tape is an attempt to reduce this light leakage.  I plan a separate project with an LDR and a relay…

Video

Flickr album (pictures, with captions!)

Flickr Album

Screen shots

Photographing the screen was tricky. I modified the sketch to optionally send the LCD commands and data out the serial port.  I wrote a small Python program to read in a file of the serial output and re-create the image as a PNG.

FlipClock.zip

Zipfile of *original* sketch. Latest is on GitHub

x-zip-compressed - 50.61 kB - 08/16/2019 at 03:13

Download

  • Mega support etc

    Mark Wilson05/05/2023 at 03:16 0 comments

    UPDATE 5th May 2023:

    The sketch is now on GitHub (https://github.com/funnypolynomial/FlipClock, original remains here as a zip). This includes:

    • Support for Arduino Mega/Mega 2560 (in addition to Uno)
    • Digit wrap is now correct - 10's of minutes going from :59 to :00 won't flash :60
    • Optional blank flap in 12-hour mode. " 307" vs "0307", see ENABLE_BLANK_TENS in Config.h
    • Automatic DLS adjustment is off by default, see ENABLE_AUTO_DLS in Config.h
    • The LCD driver has support for variants the otherwise jumble the screen, see LCD_FIXED_ORIGIN in ILI948x.h

View project log

Enjoy this project?

Share

Discussions

nickxippas wrote 01/07/2025 at 11:48 point

https://www.printables.com/model/492241-arduino-flip-clock

  Are you sure? yes | no

Mark Wilson wrote 01/07/2025 at 21:25 point

Very nice!  Thanks.

  Are you sure? yes | no

FooPlinger wrote 12/09/2024 at 13:32 point

I have used an hw84 for my clock instead of the DS3231.  I find my time is off by 12 minutes just 2 days after powering on.  Anyone else have this issue?  Do you think it is an HW84 issue, or something I have wrong in the wiring?

  Are you sure? yes | no

Mark Wilson wrote 12/09/2024 at 17:58 point

hw84 is a DS3231? It should be really accurate. I don't know what would cause such a massive drift.  Check the supply voltage. Swap it out, maybe a dud?  If the wiring was wrong, I think it wouldn't work at all.

  Are you sure? yes | no

66frangar wrote 11/26/2024 at 13:39 point

Gran proyecto, ¡ENHORABUENA! Muy agradecido por compartirlo. 

Saludos desde España y perdón por mi inglés.

  Are you sure? yes | no

norbert-schrills wrote 10/24/2024 at 19:05 point

Hello Marc Wilson
I would like to change the Flip Clock to a German display.
I have changed the text to German in clock.ccp in lines 177 and 178.
Unfortunately the letters "K" and "Z" are not displayed.
Then in smallchars.ccp I activated the letter K in lines 665 and 1812 and
the letter Z in lines 1127 and 2274.
Now I have a nonsensical display for the day and month.
What else do I need to change??
I am good at hardware, not software.
Please help me.
Thanks
Regards
Norbert Schrills

  Are you sure? yes | no

Mark Wilson wrote 10/24/2024 at 19:14 point

Hi Norbert,

Try changing 

SmallChars.cpp(2372):

const char PROGMEM char_map[]  = "0123456789:ABCDEFGHIJLMNOPRSTUVWY\xFF"; // no KQWXZ
to:
const char PROGMEM char_map[]  = "0123456789:ABCDEFGHIJKLMNOPRSTUVWYZ\xFF"; // no QWX

Mark


  Are you sure? yes | no

norbert-schrills wrote 10/25/2024 at 18:33 point

Hi Marc,
I have entered your modified software in line 2372. Now the letter "K" is displayed correctly.
But for month 12, in german DEZEMBER, DEZ, the letter "Z" is missing and no further operation is possible.
But inClock.ccp it is entered correctly.
What could be the error?
Please help.
Thanks
Regards
Norbert

  Are you sure? yes | no

Mark Wilson wrote 10/26/2024 at 00:11 point

Norbert, there was a bug!  The commented-out small chars (KQXZ, not 'W') were missing a row of encoded data from the upper and lower tables.  I've updated SmallChars.cpp in GitHub.  If you update that file, again un-comment 'K' and 'Z' from the upper and lower tables, and add them to char_map[], you should be good.

M

  Are you sure? yes | no

norbert-schrills wrote 10/26/2024 at 17:18 point

Hello Marc,
I have replaced the changed files and updated them according to your instructions.
Now everything is displayed correctly.
Thank you for your help.
Best regards
Norbert

  Are you sure? yes | no

Mark Wilson wrote 10/27/2024 at 02:21 point

Glad it's working. Thanks for finding the bug!

  Are you sure? yes | no

norbert-schrills wrote 08/17/2024 at 20:42 point

Hello Marc Wilson,
I have copied your instructions for the flip clock and it has a
display on the screen. Unfortunately mirrored from left to right.
Your instructions,
Mark Wilson wrote 04/14/2020 at 06:41 • 1 point
If like Jim (barrow4491) your display is mirrored, alter the two landscape #define MADCTL0x36 lines at the top of ILI948x.cpp. For left-right mirroring, invert b7 of the constants. For up-down mirroring, invert b6.
I did that, but unfortunately without success,
Lines 6 and 8 were changed from #define MADCTL0x36 to #define MADCTLb7x36
What else do I need to change???
Please help me.
My strength is hardware,
not software.
Please help me.
Regards
Norbert Schrills

  Are you sure? yes | no

Mark Wilson wrote 08/18/2024 at 19:14 point

Hi Norbert.  Lines 6 and 8 are not the right ones, as my comment said, you need to change the landscape defines. That's lines 10 & 12, those defines at the top of the file should end with

#elif defined LCD_LANDSCAPE_LEFT
#define MADCTL0x36 B00101000
#else
#define MADCTL0x36 B11101000
#endif 

where bit 7 of the originals has been inverted.  Try that.

Mark

  Are you sure? yes | no

norbert-schrills wrote 08/19/2024 at 16:46 point

Hi Mark,   thanks for the quick reply. I inverted bit 7 in lines 10 and 12.
The flip clock now works perfectly. Thank you for your help.
Best regards,   Norbert

  Are you sure? yes | no

FooPlinger wrote 02/16/2024 at 17:07 point

I have this somewhat together, trying to wire directly to the Uno, but all I can get on the clock is it being set to 12:65.  It never changes, and when I try to set it, those settings are not saved.   Any clue as to what I may be doing wrong here?

  Are you sure? yes | no

Mark Wilson wrote 02/16/2024 at 22:50 point

Not talking to the RTC. What have you tried? I guess check continuity from UNO to 5V and Gnd on RTC, also pins 12 (SCL) and 11 (SDA). Note these are not the built-in I2C pins.  Check your documentation for the RTC, is its address 0x68?

  Are you sure? yes | no

FooPlinger wrote 02/29/2024 at 15:17 point

I moved everything back over to a breadboard, and reconnected, now I have it working. Thank you!

  Are you sure? yes | no

jimkunowsky wrote 12/03/2023 at 23:18 point

In case someone wants to build this fine project and is having trouble finding the correct display I just purchased one from DIYMalls.com  3.5" TFT LCD Display for 2560.  

  Are you sure? yes | no

mleenen wrote 10/19/2023 at 17:41 point

Hi, just a question. I have a 3.5"TFT SPI  480x320 LCD laying here. However the pins are different. Is it possible to connect my LCS using your program/ILI948x.h? My pins are:
VCC, GND, CS, RESET, DC/RS, SDI(MOSI), SCK, LED, SDO(MISO). Plus 5 others for touch and 4 others for SD-card). BTW, very nice programming! Very inspiring.

  Are you sure? yes | no

FooPlinger wrote 07/11/2023 at 18:52 point

Do you have a link to the exact display you used?  I assume this is the middle 'shield' https://www.jaycar.com.au/duinotech-arduino-compatible-prototyping-shield/p/XC4482?pos=5&queryId=02b3f1df96049b8e72f9027bd29ac685&sort=relevance&searchText=shield

  Are you sure? yes | no

Mark Wilson wrote 07/11/2023 at 19:01 point

XC4482 is the middle shield. I don't have a link to the LCD, it's not Jaycar. Shows up sometimes on TradeMe

  Are you sure? yes | no

nickxippas wrote 04/25/2023 at 10:56 point

https://www.thingiverse.com/thing:5990281

3D housing

  Are you sure? yes | no

Mark Wilson wrote 04/25/2023 at 18:59 point

That looks great, thanks!

  Are you sure? yes | no

itsworthing wrote 09/08/2022 at 17:53 point

Best one I've seen for ages.  I intend to put one in my classic 70's car.

  Are you sure? yes | no

Mark Wilson wrote 09/08/2022 at 21:30 point

Thanks!

  Are you sure? yes | no

Ragoth wrote 01/22/2022 at 01:12 point

The "BEST DIGITAL CLOCK", I have ever seen using Arduino UNO and TFT LCD. Hats off to your design, for your efforts and time.  Thanks for sharing it.

  Are you sure? yes | no

Mark Wilson wrote 01/22/2022 at 02:45 point

Very kind, thanks!

  Are you sure? yes | no

tk11 wrote 07/10/2021 at 06:50 point

superb project, bravo. what a modification for an operation with an arduino mega 2560.thierry

  Are you sure? yes | no

adrian wrote 06/12/2021 at 13:51 point

Mark,

This is a very interesting project and your code is beautifully written - well done.

I wonder if you would share with me how you created the RLE array sequences for each of the large digits, please? I'd like to recreate them to work on 4 (or 6) separate 128x160 TFT displays.

What was the based font you used for the digits?

Many thanks,

... Adrian

  Are you sure? yes | no

Mark Wilson wrote 06/12/2021 at 22:31 point

Thanks!  I whipped up a Visual Studio program which paints each character in turn and scans the pixels to produce the RLE data, and spits out formatted C++ code for the arrays. I used "Arial"/"Arial Monospaced MT" for digits/letters and turned anti-aliasing OFF.

  Are you sure? yes | no

adrian wrote 06/13/2021 at 01:39 point

Many thanks, Mark.

  Are you sure? yes | no

jonbunker wrote 04/25/2021 at 13:56 point

Hi, all you wonderful tinkerers!

I love this project, and it would make a wonderful edition to my massive collection of strange clocks. Unfortunately, I am very ancient and have (hopefully only temporarily?) lost the use of my right arm...

...so... I wondered if somebody could make this for me?

Extremely happy to pay going rate + donate to charity or whatever.

I am in London jonbunker@gmail.com

Thanks in advance! Jon

  Are you sure? yes | no

w5nmr wrote 02/28/2021 at 11:35 point

Hello, super project.

is it possible to synchronize RTC with DCF77? can someone post the code?
Thanks a lot !
translated by Google

  Are you sure? yes | no

rycho2012 wrote 01/12/2021 at 13:42 point

P.S. Workaround for the problem. In SmallChars.cpp file, I put 'X' at the end of both rowData and char_map. In this way I dropped the character 'X' but all others are available.

Regards

  Are you sure? yes | no

rycho2012 wrote 01/11/2021 at 19:46 point

Hi Mark, I copied your project and it works fantastic. I followed all the customization tips you discribed. I also tried to use the full character set in SmallChars.cpp file, unfortunately I can't display the last character. I uncommented all blocked characters rowData and I also extended the character map as follows: const char PROGMEM char_map [] = "0123456789: ABCDEFGHIJKLMNOPQRSTUVWXYZ \ xFF"; // all. 

What else should I change to use the full letter set? 
Best regards, Richard

  Are you sure? yes | no

Mark Wilson wrote 04/14/2020 at 06:41 point

If like Jim (barrow4491) your display is mirrored, alter the two landscape #define MADCTL0x36 lines at the top of ILI948x.cpp.  For left-right mirroring, invert b7 of the constants.  For up-down mirroring, invert b6.

  Are you sure? yes | no

nickxippas wrote 04/18/2023 at 10:39 point

Hi Mark, I copied your project and it works fantastic. I followed all the customization tips you discribed. unfortunately the screen is all scrambled the top is at the bottom and the bottom on the top can you help

  Are you sure? yes | no

Mark Wilson wrote 04/18/2023 at 19:17 point

Scrambled?  You mean the pixels are jumbled up? Or is it just upside-down?

  Are you sure? yes | no

nickxippas wrote 04/18/2023 at 20:38 point

i've sent you a picture top is at the bottom and bottom is at the top

  Are you sure? yes | no

Mark Wilson wrote 05/05/2023 at 03:36 point

The variant nicksippas had is supported in the version on GitHub.  See the LCD_FIXED_ORIGIN define

  Are you sure? yes | no

barrow4491 wrote 04/12/2020 at 06:54 point

Mark all good but the clock is mirror reverse

J

  Are you sure? yes | no

Similar Projects

Does this project spark your interest?

Become a member to follow this project and never miss any updates