驴友花雕 发表于 2025-4-17 10:43:10

【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形




驴友花雕 发表于 2025-4-17 10:44:37

【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形




驴友花雕 发表于 2025-4-17 10:46:32

【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形




驴友花雕 发表于 2025-4-17 10:48:04

【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形

【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
项目之一百零四:ESP32+GC9A01之点、线、面动态图形的综合绘图测试

实验开源代码

/*
【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
项目之一百零四:ESP32+GC9A01之点、线、面动态图形的综合绘图测试
*/

//       GC9A01---------- ESP32
//       RST ------------ NC(复位引脚,此处未连接)
//       CS ------------- D4(片选引脚,连接到ESP32的D4引脚)
//       DC ------------- D2(数据/命令选择引脚,连接到ESP32的D2引脚)
//       SDA ------------ D23 (green)(主数据输出引脚,连接到ESP32的D23引脚,绿色线)
//       SCL ------------ D18 (yellow)(时钟信号引脚,连接到ESP32的D18引脚,黄色线)
//       GND ------------ GND(接地引脚,连接到ESP32的接地端)
//       VCC -------------3V3(电源引脚,连接到ESP32的3.3V电源)

#include <TFT_eSPI.h>
#include "SPI.h"

#define SCREEN_WIDTH 240
#define SCREEN_HEIGHT 240

TFT_eSPI tft = TFT_eSPI();

void setup() {
    Serial.begin(115200);
    tft.init();
    tft.setRotation(2);
    tft.fillScreen(TFT_BLACK);
}

void drawRandomDots() {
    for (int i = 0; i < 100; i++) {
      int x = random(0, SCREEN_WIDTH);
      int y = random(0, SCREEN_HEIGHT);
      uint16_t color = tft.color565(random(50, 255), random(50, 255), random(50, 255));
      tft.drawPixel(x, y, color);
    }
}

void drawMovingLines() {
    for (int i = 0; i < SCREEN_WIDTH; i += 10) {
      uint16_t color = tft.color565(random(100, 255), random(100, 255), random(100, 255));
      tft.drawLine(i, 0, SCREEN_WIDTH - i, SCREEN_HEIGHT, color);
      delay(20);
    }
}

void drawFilledShapes() {
    for (int i = 0; i < 5; i++) {
      int x = random(30, SCREEN_WIDTH - 30);
      int y = random(30, SCREEN_HEIGHT - 30);
      int size = random(20, 50);
      uint16_t color = tft.color565(random(50, 255), random(50, 255), random(50, 255));

      if (random(0, 2) == 0) {
            tft.fillRect(x, y, size, size, color);
      } else {
            tft.fillCircle(x, y, size / 2, color);
      }
    }
}

void loop() {
    tft.fillScreen(TFT_BLACK);

    drawRandomDots();
    delay(500);

    drawMovingLines();
    delay(500);

    drawFilledShapes();
    delay(500);
}

驴友花雕 发表于 2025-4-17 11:59:08

【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形

这段代码是一个 综合绘图测试,用于检查 ESP32 + TFT_eSPI + GC9A01 显示屏 的点、线、面渲染效果,确保动画流畅。
代码结构

1️⃣ 初始化屏幕

[*]使用 TFT_eSPI 驱动 TFT 显示屏,并设定黑色背景。

2️⃣ 绘制随机点

[*]drawRandomDots() 生成 随机颜色的像素点,测试像素绘制能力。

3️⃣ 绘制动态线条

[*]drawMovingLines() 让 线条沿屏幕移动,检查刷新速度。

4️⃣ 绘制矩形和圆形

[*]drawFilledShapes() 随机填充 矩形和圆形,测试色彩渲染效果。

5️⃣ 循环测试

[*]delay(500); 让 每种测试轮流运行,确保所有绘图功能稳定。



最终效果
屏幕随机生成点阵,测试像素绘制能力
线条不断移动,确保流畅度
矩形和圆形填充,检查颜色渲染
动态刷新,保持稳定性

驴友花雕 发表于 2025-4-17 12:01:17

【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形

实验场景图动态图




驴友花雕 发表于 2025-4-17 12:02:40

【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形




驴友花雕 发表于 2025-4-17 12:03:46

【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形


页: [1]
查看完整版本: 【花雕学编程】Arduino动手做(249)--GC9A01点线面动态图形