回到首页 返回首页
回到顶部 回到顶部
返回上一页 返回上一页

【花雕学编程】Arduino动手做(238)---ESP32 CYD液晶2.8寸开发板分别用红蓝绿三色循环绘制全屏表格 简单

头像 驴友花雕 2024.11.05 9 0

0.jpg

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中进行开发。

 

00.jpg

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

 

02-4.jpg
02-5.jpg

  【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);  // 画水平线
  }
}

代码解读
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库分别用红、蓝、绿色循环绘制表格。

实验场景图  动态图

 

00015.gif

实验场景图 

 

02-11.jpg

评论

user-avatar
icon 他的勋章
    展开更多