Arduino LCD Christmas Tree

by RonFrtek in Circuits > Arduino

222 Views, 1 Favorites, 0 Comments

Arduino LCD Christmas Tree

Arduino LCD Christmas Tree

Make a Christmass Tree Animation with snow, and lights using a TFT ST7735 LCD & Arduino.

Snow and Lights are drawn at random each time,

Watch the Video!

Project file can be downloaded below.

What You Will Need

st7735-.jpg
336-3361370_arduino-uno-r3-png-png-download-arduino-uno.png
VisuinoAdvrtisementElegooV4.jpg
FEGPLRJKK5FQW91.jpg
F19QEZ5KK5FQW90.jpg
  • Arduino UNO (or any other Arduino)
  • ST7735 or ST7789 Display
  • Breadboard
  • Jumper wires
  • Visuino program: Download Visuino

The Circuit

F1FYQVOK1MOHCZT.jpg
FB5QPHVK1MOHCZR.png

Connect:

  • 1.8 TFT Display PIN [LED] to Arduino PIN [3.3 V]
  • 1.8 TFT Display PIN [SCK] to Arduino PIN [13]
  • 1.8 TFT Display PIN [SDA] to Arduino PIN [11]
  • 1.8 TFT Display PIN [A0 or DC] to Arduino PIN [9]
  • 1.8 TFT Display PIN [RESET] to Arduino PIN [8]
  • 1.8 TFT Display PIN [CS] to Arduino PIN [10]
  • 1.8 TFT Display PIN [GND] to Arduino PIN [GND]
  • 1.8 TFT Display PIN [VCC] to Arduino PIN [5V]

NOTE: Some Arduino boards have different SPI pins so make sure you check your board documentation.

Start Visuino, and Select the Arduino UNO Board Type

FMW5CHBKFV47BP9.jpg
F6GRUWLKK5FQWTB.jpg

The Visuino: https://www.visuino.eu also needs to be installed. Download Free version or register for a Free Trial.

Start Visuino as shown in the first picture Click on the "Tools" button on the Arduino component (Picture 1) in Visuino When the dialog appears, select "Arduino UNO" as shown on Picture 2

In Visuino Add & Set Components

2021-12-24_17-35-51.jpg
2021-12-24_17-38-03.jpg
2021-12-24_17-38-49.jpg
2021-12-24_17-39-55.jpg
2021-12-24_17-40-53.jpg
2021-12-24_17-41-36.jpg
2021-12-24_17-42-08.jpg
2021-12-24_17-46-15.jpg
2021-12-24_17-46-01.jpg
2021-12-24_17-44-11.jpg
2021-12-24_17-43-20.jpg
2021-12-24_17-47-54.jpg
2021-12-24_17-51-57.jpg
2021-12-24_17-51-35.jpg
2021-12-24_17-49-40.jpg

Add "TFT Color Display ST7735/ST7789" component

Add 6X "Random Integer Generator" component

Add "Clock Multi Source" component

Add "Repeat Clock" component

Add "Clock Demux(Multiple Output channel Switch)" component

Add "Counter" component

Add "Pulse Generator" component

Select "PulseGenerator1" and in the properties window set Frequency to 0.5

Select "Counter1" and in the properties window set Max>Value to 5 and Min > Value to 0

Select "ClockDemmux1" and in the properties window set Output Pins to 5

Select "RepeatClock1" and in the properties window set "Count" to 10

Select "ClockMultiSource1" and in the properties window set "Count" to 9

Select "RandomIntegerGenerator1" and in the properties window set "Max" to 100 and "Min" to 70

Select "RandomIntegerGenerator2" and in the properties window set "Max" to 100 and "Min" to 70

Select "RandomIntegerGenerator3" and in the properties window set "Max" to 110 and "Min" to 70

Select "RandomIntegerGenerator4" and in the properties window set "Max" to 100 and "Min" to 70

Select "RandomIntegerGenerator5" and in the properties window set "Max" to 160 and "Min" to 0

Select "RandomIntegerGenerator6" and in the properties window set "Max" to 120 and "Min" to 0

Select "Display1" and in the properties window set "Orientation" to goRight and "Type" to dtST7735R_BlackTab <<If you have any other type of the LCD then select that type

In Visuino Set the Display

2021-12-24_17-51-35.jpg
SNow-min.png
2021-12-24_17-57-40.jpg
2021-12-24_18-00-52.jpg
2021-12-24_18-01-24.jpg
2021-12-24_18-12-14.jpg

Double click on the "Display1" and in the Elements window :

  • Drag "Draw Bitmap" to the left side and in the properties window click on the Bitmap three dots button and load the Background Christmas picture (attached here for download)
  • Drag 6x "Draw Ellipse" to the left side
  • Select "Draw Ellipse1" and in the properties window set "Color" to "aclBrown" , "Fill Color" to aclRed ,"Height" to 6 , "Width" to 6, Select "X" and click on the Pin Icon and Select "Integer SinkPin", Select "Y" and click on the Pin Icon and Select "Integer SinkPin"
  • Select "Draw Ellipse2" and in the properties window set "Color" to "aclBlack" , "Fill Color" to aclBlue,"Height" to 6 , "Width" to 6, Select "X" and click on the Pin Icon and Select "Integer SinkPin", Select "Y" and click on the Pin Icon and Select "Integer SinkPin"
  • Select "Draw Ellipse3" and in the properties window set "Color" to "aclWhite" , "Fill Color" to aclWhite,"Height" to 6 , "Width" to 6, Select "X" and click on the Pin Icon and Select "Integer SinkPin", Select "Y" and click on the Pin Icon and Select "Integer SinkPin"
  • Select "Draw Ellipse4" and in the properties window set "Color" to "aclBrown" , "Fill Color" to aclRed ,"Height" to 6 , "Width" to 6, Set "X" to 97, Set "Y" 55
  • Select "Draw Ellipse5" and in the properties window set "Color" to "aclBrown" , "Fill Color" to aclRed ,"Height" to 6 , "Width" to 6, Set "X" to 90, Set "Y" 60
  • Select "Draw Ellipse6" and in the properties window set "Color" to "aclBrown" , "Fill Color" to aclBlue,"Height" to 6 , "Width" to 6, Set "X" to 90, Set "Y" 55

Close the "Elements Window"

In Visuino Connect Components

tree.png
2021-12-24_18-14-09.jpg
2021-12-24_18-14-24.jpg
2021-12-24_18-14-38.jpg
2021-12-24_18-14-54.jpg

  • Connect "PulseGenerator1" pin [Out] to "Counter1" pin [In]
  • Connect "Counter1" pin [Out] to "ClockDemmux1" pin [Select] And "ClockDemmux1" pin [In]
  • Connect "ClockDemmux1" pin [0] to "Display1" > Draw Bitmap1 Pin[Clock]
  • Connect "ClockDemmux1" pin [1] to "RepeatClock1" pin [In]
  • Connect "ClockDemmux1" pin [2] to "Display1" > Draw Ellipse4 Pin[Clock]
  • Connect "ClockDemmux1" pin [3] to "Display1" > Draw Ellipse5 Pin[Clock]
  • Connect "ClockDemmux1" pin [4] to "Display1" > Draw Ellipse6 Pin[Clock]
  • Connect "RepeatClock1" pin [Out] to "ClockMultiSource1" Pin [In]

  • Connect "ClockMultiSource1" pin [0] to "RandomIntegerGenerator1" Pin[Clock]
  • Connect "ClockMultiSource1" pin [1] to "RandomIntegerGenerator2" Pin[Clock]
  • Connect "ClockMultiSource1" pin [2] to "Display1" > Draw Ellipse1 Pin[Clock]

  • Connect "ClockMultiSource1" pin [3] to "RandomIntegerGenerator3" Pin[Clock]
  • Connect "ClockMultiSource1" pin [4] to "RandomIntegerGenerator4" Pin[Clock]
  • Connect "ClockMultiSource1" pin [5] to "Display1" > Draw Ellipse2 Pin[Clock]
  • Connect "ClockMultiSource1" pin [6] to "RandomIntegerGenerator5" Pin[Clock]
  • Connect "ClockMultiSource1" pin [7] to "RandomIntegerGenerator6" Pin[Clock]
  • Connect "ClockMultiSource1" pin [8] to "Display1" > Draw Ellipse3 Pin[Clock]

Generate, Compile, and Upload the Arduino Code

FBR42I2KXBU01YW.jpg

In Visuino, at the bottom click on the "Build" Tab, make sure the correct port is selected, then click on the "Compile/Build and Upload" button.

Play

If you power the Arduino module, the LCD Display will start to show the Christmas Picture, Lights on the tree and the snow will be drawn by a random.

Congratulations! You have completed your project with Visuino. Also attached is the Visuino project, that I created for this Tutorial, you can download it and open it in Visuino: https://www.visuino.eu

Downloads