Skip to content

CrowPanel ESP32 Terminal RGB with MicroPython

Overview


The example tutorial is an environmental monitoring project, demonstrate how to create a UI and use a Humidity&Temperature sensor to obtain the environment temperature and humidity and display it on the screen; and how to control the LED on and off by the buttons on the screen.

In this tutorial, we will show you how to design the UI with SquareLine Studio, and show you how to upload the code with Thonny IDE.

RGB_DEMO

Hardware Preparation


ESP32 Terminal RGB Crowtail-AM2302 Crowtail-LED
CrowPanel-ESP32-Content-T-RGB1 AM2302 CROWTAIL-LED
BUYNOW BUYNOW BUYNOW

Design UI file with SquareLine Studio


Get Started with SquareLine Studio

Please click the card below to learn how to download the SquareLine Studio, and how to export the demo UI file.

GetStartedWithSquareLine

Design UI file with SquareLine Studio

Let's start learning how to create our own UI after getting an initial understanding of SquareLine Studio.

  1. Open the SquareLine Studio and create a project. Select "Desktop"->"Micropython for Unix and other platform".

    SLS-UI-1

  2. Set the name of the project, set the screen resolution to 480*320, set the color depth to 16bit, and keep other default settings. After setting, click CREATE to create the project.

    SLS-UI-2

    • 16-bit color depth: can represent 65,536 colors through RGB 5:6:5 sub-pixel representation, that is, each RGB channel occupies 5 bits and 1 bit (a total of 16 bits) to represent colors.
  3. After creation, enter the following interface with a blank background.

    SLS-UI-3

  4. In the "Assets" area, click "ADD FILE TO ASSETS" to add custom images or icons.

    Please click download to download the custom images used in this tutorial.

    SLS-UI-4

    Note:

    Images only support PNG format. The pixels of the image need to be smaller than the pixel size of the screen used in your project. The size of each image should not exceed 100k, preferably within 30k, to provide a smooth display effect.

  5. Add background.

    Find "Inspector"->"STYLE SETTING", click to expand "STYLE(MAIN)", then click the 2nd "Background". Check the "Bg Image" and select the background image.

    SLS-UI-5

    SLS-UI-6

  6. Add Label widget to display temperature and humidity.

    Click "Label" in the "Widgets" area, and "Label1" will be added to the current Screen.

    SLS-UI-7

    The position and size of the label can be adjusted by dragging the mouse. You can also directly enter numbers in the Inspector→LABEL→Transform to adjust.

    SLS-UI-8

    You can set the font color and other attributes in STYLE SETTING→STYLE(MAIN).

    SLS-UI-9

    Add a Label2 to display the humidity value in the same way. You can also directly right-click the Label1 to duplicate it.

    SLS-UI-10

    Then set different positions for the Label2.

    SLS-UI-11

    Modify the text content to display a default value.

    SLS-UI-18

  7. Add Button widget to control the LED.

    Click "Button" in the "Widgets" area, and "Button1" will be added to the current Screen.

    SLS-UI-12

    The position and size of the label can be adjusted by dragging the mouse. You can also directly enter numbers in the Inspector→BUTTON→Transform to adjust.

    SLS-UI-13

    Add an identification symbol to the button. The button in this tutorial controls the LED switch, so you only need to mark the button "on" and "off". You can add LABEL widgets or add a background images to the button. This tutorial will demonstrate how to add a background image to a button.

    Click the Button1, then find Inspector->STYLE SETTINGS ->STYLE(MAIN) ->Background, and select the image.

    SLS-UI-14

    SLS-UI-15

    In the same way, duplicate a Button widget. And drag it to the corresponding position to modify different background image.

    SLS-UI-16

    SLS-UI-17

    Set the status of the button to identify different states.

    In "Inspector"->"STYLE SETTINGS"->"STATE", set display white background color by DEFAULT and red when on the PRESSED state.

    SLS-UI-19

    SLS-UI-20

    Make the same settings for the "OFF" button.

  8. Add events to buttons.

    Note: Because the button controls the on and off of the LED, we can add any event here to generate the code framework for the button event when exporting the UI file. We will modify the code of the button event to control the LED latter.

    Select the button and click "ADD EVENT".

    SLS-UI-21

    Select "released" as the trigger condition, select a trigger event in "Action". It will be modified in the generated program to achieve the LED control function.

    SLS-UI-22

    Complete the event. Here I choose to change the screen, and the screen to be switched is Screen1.

    SLS-UI-23

    Add event to Button2 (OFF) in the same way.

    SLS-UI-24

  9. Export UI files.

    Click "File" -> "Project Settings" and make settings for the exported file.

    SLS-UI-25

    Set the export path of the file (set the path according to your own file).

    SLS-UI-26

    Fill in lvgl.h in LVGL Include Path. Check "Flat export(exports all files to one folder )".

    Then click "APPLY CHANGES".

    Tips: After selecting the flat export, the output files will be in the same folder, so that the output code does not need to modify the path in the program. If not, the output files will be classified and placed in different folders. The compiler may not be able to recognize different paths, which will cause some trouble. In this case, the user needs to modify it manually, so it is recommended to select all files to be output to the same folder.

    SLS-UI-27

    Export UI files. The exported files will be in the path we set earlier.

    SLS-UI-28

    SLS-UI-29

Build the Project with Thonny IDE


Download Thonny IDE

  1. Go to the website https://thonny.org/ and download the corresponding software version (here we take the Windows version as an example)

    Thonny-1

  2. Double-click the downloaded exe file to install the software.

    Thonny-2

Upload firmware

  1. Connect the CrowPanel ESP32 HMI with your computer.

  2. Open Thonny IDE and click "Tools"->"Options"->"Interpreter".

    Thonny-3.pngThonny-4.png

  3. Select "MicroPython(ESP32)" for interpreter.

    Thonny-5.png

  4. Select the corresponding serial port(or Try to detect port automatically).

    Thonny-6.png

  5. Click "Install or update MicroPython (esptool)"

    Thonny-7.png

  6. Click the icon with 3 lines, and click "select local MicroPython image...".Select the "lv_micropython.v1.19.1-ili9341-xpt2046.bin" and install.

    Thonny-8.png

    Thonny-9.png

    Please click download to download the bin file.

  7. Waiting for downloading...

    Thonny-10.png

    Thonny-11.png

Edit the code

Please click download to download the code file and libraries.

code

  • The main code is "CrowPanel_ESP32_RGB_3.5.py"
  • The "ui_image.py" is the libraries
  • The ui.by is exported from Squaline Studio and needs to be copied into the main program

Code Explanation

Libraries imported in this example
import lvgl as lv
import lv_utils
import tft_config
import time
import fs_driver
import ft6x36
from machine import Pin, I2C
import machine
import ui_images
import dht

import lvgl as lv: LVGL is an open source embedded system graphics library for creating graphical user interfaces. import lv_utils: Contains some auxiliary functions or tools to simplify the use of LVGL. import tft_config: Imports the TFT (Thin Film Transistor) configuration module. This library contains configuration information specific to TFT display devices. import time: Used for time-related operations, such as delays. import fs_driver: File system driver module, which may be used to access and manage storage devices. import ft6x36: Driver library for the FT6X36 touch controller. The FT6X36 is a touch controller chip for touch screen devices. from machine import Pin, I2C: Imports the Pin and I2C classes from the machine module. Pin is used to control hardware pins, and I2C is used for I2C communication. import machine: The machine module usually contains control over hardware, such as GPIO (General Purpose Input Output) operations. import ui_images: Imports the user interface image module, which may contain image resources for display. import dht: Imports the DHT (Digital Humidity and Temperature) module, which is used to read humidity and temperature data from the DHT series sensors.

Basic Definition

Set up the hardware interface and initialize the sensor so that the subsequent program can read the temperature and humidity data and control the LCD display.

WIDTH = 480
HEIGHT = 320

sensor = dht.DHT22(Pin(40))
#pin = 40  # GPIO pin nubber
p44 = Pin(44, Pin.OUT)
p44.value(1)

# tft drvier
tft = tft_config.config()

# touch drvier
i2c = I2C(1, scl=Pin(39), sda=Pin(38), freq=400000)

tp = ft6x36.FT6x36(i2c)

lv.init()

if not lv_utils.event_loop.is_running():
    event_loop=lv_utils.event_loop()
    print(event_loop.is_running())

# create a display 0 buffer
disp_buf0 = lv.disp_draw_buf_t()
buf1_0 = bytearray(WIDTH * HEIGHT * 2)
disp_buf0.init(buf1_0, None, len(buf1_0) // lv.color_t.__SIZE__)

# register display driver
disp_drv = lv.disp_drv_t()
disp_drv.init()
disp_drv.draw_buf = disp_buf0
disp_drv.flush_cb = tft.flush
disp_drv.hor_res = WIDTH
disp_drv.ver_res = HEIGHT
# disp_drv.user_data = {"swap": 0}
disp0 = disp_drv.register()
lv.disp_t.set_default(disp0)

# touch driver init
indev_drv = lv.indev_drv_t()
indev_drv.init()
indev_drv.disp = disp0
indev_drv.type = lv.INDEV_TYPE.POINTER
indev_drv.read_cb = tp.lvgl_read
indev = indev_drv.register()

dispp = lv.disp_get_default()
theme = lv.theme_default_init(dispp, lv.palette_main(lv.PALETTE.BLUE), lv.palette_main(lv.PALETTE.RED), False, lv.font_default())
dispp.set_theme(theme)
UI display code

This part copies the code of ui.py generated by Squareline Studio. We need to modify the part that control the button.

From

button-1

to

button-2

Temperature and humidity display

Define a class named TEM_HUM to display temperature and humidity information in the LVGL GUI.

class TEM_HUM():
    def __init__(self, ui_Screen1):
        # Read the temperature and humidity values of the sensor
        global Tem, Hum
        Tem = sensor.dht20_temperature()
        Hum = sensor.dht20_humidity()

        # Update the temperature and humidity display on the UI interface
        ui_Label4.set_text(f"{round(Tem)} °C")  # Update temperature
        ui_Label5.set_text(f"{round(Hum)} %")       # Update humidity

Upload the code

Upload the libraries

ui_image

  1. In the upper left corner of the thonny, enter the path where DHT20.py is located, right-click DHR20.py, and click Upload to/

    Thonny-12.png

  2. Waiting for uploading

  3. The DHT20.py will be added to the MicroPython device column.

    Thonny-14.png

Upload the code

Click the "run" icon to run the main code.

Thonny-17.png

Successfully uploaded.

Thonny-18.png

GPIO Examples

Please click download to download the example code files.

Example 1 LED Blinking

  • Plug the LED module to GPIO-D Port

  • Upload the led.py to board

  • The LED will blink

    led-blink

Example 2 Show the button on the screen

  • Upload the button-1-3.5.py to the board

    button-onscreen

Example 3 Show the dial plate on the screen

  • Upload the biaopan-3.5.py to the board

    biaopan

Example 4 Connect WiFi

  • Open the wifi.py

  • Modify the code to connect your WiFi

       ssid = 'yanfa_software' # change to your network name
       password = 'yanfa-123456' # change to your network password
    
  • Upload the code

    Connect-wifi

Example 5 Initialize SD card

  • Insert the SD card to the card slot

  • Upload the sd.py

    SDCARD

Example 6 Make sounds

  • Upload the buzzer.py
  • The on-board buzzer will make some sounds

Example 7 Serial port initialization

  • Upload uart.py

    uart

Resources