驴友花雕 发表于 2024-11-5 15:13:17

【花雕学编程】Arduino动手做(238)--ESP32 CYD全屏动态表格



ESP32-CYD(2432S028)液晶2.8寸屏开发板使用ESP32-WROOM-32模块作为主控,主控是一款双核MCU,集成了Wi-Fi和蓝牙功能,主频可达240MHz,具有520KB的SRAM、448KB的ROM,闪存容量为4MB+4MB,显示分辨率为240x320,采用电阻式触控式屏幕。该模块包括LCD显示器、背光控制电路、触控式屏幕控制电路、扬声器驱动电路、光敏电路和RGB LED控制电路。支持TF卡界面、序列界面、温湿度感测器界面(DHT11界面)和保留的IO口界面,该模块支持在Arduino IDE、ESP IDE、MicroPython和Mixly中进行开发。


驴友花雕 发表于 2024-11-5 15:14:53

【花雕学编程】Arduino动手做(238)--ESP32 CYD全屏动态表格

安装TFT_eSPI和XPT2046_Touchscreen库
网址:
TFT_eSPI库的网址:https://github.com/Bodmer/TFT_eSPI
XPT2046_Touchscreen库的网址: https://github.com/PaulStoffregen/XPT2046_Touchscreen





驴友花雕 发表于 2024-11-5 15:17:19

【花雕学编程】Arduino动手做(238)--ESP32 CYD全屏动态表格

【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验二百三十八:ESP32 CYD开发板WiFi蓝牙2.8寸240*320智能液晶显示屏带触摸屏TFT模块
项目实验之七:ESP32 CYD液晶2.8寸开发板分别用红蓝绿三色循环绘制全屏表格

实验开源代码

/*
【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验二百三十八:ESP32 CYD开发板WiFi蓝牙2.8寸240*320智能液晶显示屏带触摸屏TFT模块
项目实验之七:ESP32 CYD液晶2.8寸开发板分别用红蓝绿三色循环绘制全屏表格
*/

#include <TFT_eSPI.h>// 引入 TFT_eSPI 库

TFT_eSPI tft = TFT_eSPI();// 创建 TFT_eSPI 对象

void setup() {
tft.init();// 初始化 TFT 屏幕
tft.setRotation(1);// 设置屏幕旋转方向,顺时针旋转 90 度
}

void loop() {
drawGrid(TFT_RED);
delay(1000);// 延迟 1 秒

drawGrid(TFT_GREEN);
delay(1000);// 延迟 1 秒

drawGrid(TFT_BLUE);
delay(1000);// 延迟 1 秒
}

void drawGrid(uint16_t color) {
tft.fillScreen(TFT_BLACK);// 清空屏幕,填充黑色

int cols = 5;// 列数
int rows = 5;// 行数
int width = tft.width()/ cols;// 每列的宽度
int height = tft.height()/ rows;// 每行的高度

for (int i = 0; i <= cols; i++) {
    tft.drawLine(i * width, 0, i * width, tft.height(), color);// 画垂直线
}

for (int j = 0; j <= rows; j++) {
    tft.drawLine(0, j * height, tft.width(), j * height, color);// 画水平线
}
}

驴友花雕 发表于 2024-11-5 15:22:06

【花雕学编程】Arduino动手做(238)--ESP32 CYD全屏动态表格

代码解读
1、初始化TFT屏幕:

tft.init();

tft.setRotation(1);
使用TFT_eSPI库初始化TFT屏幕,并通过setRotation(1)将屏幕顺时针旋转90度,确保绘制方向正确。

2、定义表格尺寸:

int cols = 5;

int rows = 5;

int width = tft.width() / cols;

int height = tft.height() / rows;
定义表格的行数和列数,并计算每行和每列的宽度和高度,以确保表格均匀分布在屏幕上。

3、绘制垂直和水平线:

for (int i = 0; i <= cols; i++) {

tft.drawLine(i * width, 0, i * width, tft.height(), color);

}



for (int j = 0; j <= rows; j++) {

tft.drawLine(0, j * height, tft.width(), j * height, color);

}
使用drawLine函数绘制垂直和水平线,形成表格的网格结构。

4、循环变换颜色:

drawGrid(TFT_RED);

delay(1000);

drawGrid(TFT_GREEN);

delay(1000);

drawGrid(TFT_BLUE);

delay(1000);
使用drawGrid函数绘制红、绿、蓝三种颜色的表格,并通过delay函数实现颜色的循环变换。

5、绘制函数的封装:

void drawGrid(uint16_t color) {

tft.fillScreen(TFT_BLACK);

// 绘制表格的代码

}
封装绘制表格的代码在drawGrid函数中,方便颜色的切换和重复调用,提高代码的可读性和维护性。

这个程序展示了如何使用Arduino和TFT_eSPI库分别用红、蓝、绿色循环绘制表格。

驴友花雕 发表于 2024-11-5 15:23:53

【花雕学编程】Arduino动手做(238)--ESP32 CYD全屏动态表格

实验场景图动态图


驴友花雕 发表于 2024-11-5 15:26:09

【花雕学编程】Arduino动手做(238)--ESP32 CYD全屏动态表格

实验场景图


页: [1]
查看完整版本: 【花雕学编程】Arduino动手做(238)--ESP32 CYD全屏动态表格