Skip to content

ESP32-S3 Parallel 4.0" TFT with Touch

introduction

ESP32-S3 Parallel 4.0 TFT with Touch is a new solution for IoT application, Choose the ESP32-S3, whicn is a execllent performance controllter. Compare with ESP32-S3 4.3 inch IPS display it increase the I2S output. In many IoT scenarios, Audio playing can have a better exhibition effect. by integrating display/ touch/ audio speaker/ Lipo charger, to make this product ideal for applications such as IoT controlling, electronic photo frame, etc.

Module:E32S3RGB40

4inchESP32S3ParallelTFTwithTouch1000x750.jpg

Feature

  • Controller: ESP32-S3-WROOM-1, PCB Antenna, 16MB Flash, 8MB PSRAM,
  • Wireless: Wifi& Bluetooth 5.0
  • LCD: 4.0 inch High Lightness IPS
  • FPS: >50
  • Resolution: 480*480
  • LCD interface: RGB565 +3-wire SPI
  • LCD Driver: ST7701S
  • USB: Dual USB Type-C(one for USB-to-UART and one for native USB)
  • Touch Panel: 5 Points Touch, Capacitive
  • Touch Panel Driver: GT911
  • USB to UART Chip: CP2104
  • Power Supply: USB Type-C 5.0V(4.0V~5.25V)
  • Button: Flash button and reset button
  • Mabee interface: 1 * I2C; 1 * GPIO
  • MicroSD: Yes
  • Type-C Power Delivery: Not Supported
  • Operation temperature: -40℃ to +85℃
  • Speaker(I2S)
  • Lipo battery charger& connector
  • Audio: MAX98357A

Matouch 4.0.jpg

Usage

If you need backlight control, you need to solder R28 whose resistance is 1kΩ(the default is not soldered when leaving the factory), and remove the R29 resistor.

ESP32S3ParallelTFTwithTouch4inch backlight1jpg.jpg

ESP32S3ParallelTFTwithTouch4inch backlight2.jpg

Note that the same version of the libraries and packages are recommended in case of updates make unexpected results. All the projects are based on ESP32-S3. If you didn't install the ESP32 Board SDK, you can follow this tutorial to install it.

Install the "TAMC_GT911" in the Arduino IDE.

Click “Tools> Manager Libraries” to search for and install the 1.0.2 version of TAMC_GT911 library.

GT911.jpg

Select and set the parameter in the Tools menu before uploading the sketch,shows as below:

Note: Different PC has different Serial COM number, select your local serial number

LVGL Demo

The version of the libraries shows as below. It may cause compilation errors if you use different version of the libraries!

esp32s34.0parallelibrary.jpg

1.Download the MF_Lvgl library.

2.Open the sketch>include library> ADD.ZIP library

add.zip.jpg

3.Choose the path of MF_Lvgl and unzip the library.

4.Open the GitHub, click the >>ESP32-S3-Parallel-TFT-with-Touch-4inch/example/LvglWidgets/

5.Download the SD_file and unzip it, copy these files to the microSD card.

6.Verify and upload the sketch.

esp32s34.0parallellvglpicture.jpg

PDQgraphics demo

You can get the screen performance with PDQgraphics demo. Install the GFX_Library_for_Arduino library.

esp32s34.0parallellvglPDQdq.jpg

  • Open the GitHub and click >>example>> PDQgraphicstest.

  • Verify and upload the code. it will display as follows.

esp32s34.0parallellvglpicture pdq.jpg

If you want to know more display effects with ESP32-S3 Parallel 4.0 TFT with Touch, watch the following video.

Bightness control Demo

Notice: Before you can implement this demo, you must solder R28 whose resistance is 1kΩ(the default is not soldered when leaving the factory), and remove the R29 resistor.

Open Bightness control Demo by Arduino.

Use Type-C USB cable to connect the board and PC, note plug the cable to USB-NATIVE interface, and select the development board "ESP32S3 Dev Module" and the port. Wiki2.png

Verify and upload the code. it will display as follows.

Swipe the progress bar and you will see the brightness of the screen change and you can open the Serial Monitor to capture the coordinates of the screen points.

IMG_20240731_085050.jpg

wiki.png

FAQ

You can list your question here or contact techsupport@makerfabs.com for technology support. Detailed descriptions of your question will be helped to solve your question.

  • Q1: Why the display fails to respond sometimes I touch?

  • A1: The touching interface is loose, please reconnect it.

Q2: I get the error "no matching function for call to 'Arduino_ESP32RGBPanel::Arduino_ESP32RGBPanel(int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int)'); ^" when I compile the code, how to solve it? 1.png

A2: Mabe you use the newest ArduinoGFX v1.4.7 not the tested v1.3.1. The oringinal code need to make some changes to support v1.4.7 as below:

#if 0  //for Arduino_GFX_Library v1.3.1
Arduino_ESP32RGBPanel *bus = new Arduino_ESP32RGBPanel(
    1 /* CS */, 12 /* SCK */, 11 /* SDA */,
    45 /* DE */, 4 /* VSYNC */, 5 /* HSYNC */, 21 /* PCLK */,
    39 /* R0 */, 40 /* R1 */, 41 /* R2 */, 42 /* R3 */, 2 /* R4 */,
    0 /* G0/P22 */, 9 /* G1/P23 */, 14 /* G2/P24 */, 47 /* G3/P25 */, 48 /* G4/P26 */, 3 /* G5 */,
    6 /* B0 */, 7 /* B1 */, 15 /* B2 */, 16 /* B3 */, 8 /* B4 */
);

Arduino_ST7701_RGBPanel *gfx = new Arduino_ST7701_RGBPanel(
    bus, GFX_NOT_DEFINED /* RST */, 0 /* rotation */,
    true /* IPS */, 480 /* width */, 480 /* height */,
    st7701_type1_init_operations, sizeof(st7701_type1_init_operations),
    true /* BGR */);
#endif  //end of  for Arduino_GFX_Library v1.3.1

#if 1 //for Arduino_GFX_Library v1.4.7
Arduino_DataBus *bus = new Arduino_SWSPI(
    GFX_NOT_DEFINED /* DC */, 1 /* CS */,
    12 /* SCK */, 11 /* MOSI */, 13 /* MISO */);

Arduino_ESP32RGBPanel *rgbpanel = new Arduino_ESP32RGBPanel(
    45 /* DE */, 4 /* VSYNC */, 5 /* HSYNC */, 21 /* PCLK */,
    39 /* R0 */, 40 /* R1 */, 41 /* R2 */, 42 /* R3 */, 2 /* R4 */,
    0 /* G0 */, 9 /* G1 */, 14 /* G2 */, 47 /* G3 */, 48 /* G4 */, 3 /* G5 */,
    6 /* B0 */, 7 /* B1 */, 15 /* B2 */, 16 /* B3 */, 8 /* B4 */,
    1 /* hsync_polarity */, 10 /* hsync_front_porch */, 8 /* hsync_pulse_width */, 50 /* hsync_back_porch */,
    1 /* vsync_polarity */, 10 /* vsync_front_porch */, 8 /* vsync_pulse_width */, 20 /* vsync_back_porch */);

Arduino_RGB_Display *gfx = new Arduino_RGB_Display(
    480 /* width */, 480 /* height */, rgbpanel, 0 /* rotation */, true /* auto_flush */,
    bus, GFX_NOT_DEFINED /* RST */, st7701_type1_init_operations, sizeof(st7701_type1_init_operations));   
#endif   //End of for Arduino_GFX_Library v1.4.7

Resource