驴友花雕 发表于 昨天 10:12

【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格




驴友花雕 发表于 昨天 10:13

【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格




驴友花雕 发表于 昨天 10:17

【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格




驴友花雕 发表于 昨天 10:18

【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格

【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
项目之一百二十三:ESP32+GC9A01之线条间距在 5-50 之间递增和递减的动态网格

实验开源代码

/*
【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
项目之一百二十三:ESP32+GC9A01之线条间距在 5-50 之间递增和递减的动态网格
*/

//       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>

TFT_eSPI tft = TFT_eSPI();

#define SCREEN_WIDTH 240
#define SCREEN_HEIGHT 240
#define MIN_SPACING 5      // 最小间距
#define MAX_SPACING 50   // 最大间距
#define REFRESH_INTERVAL 500 // 0.5秒刷新一次

int spacing = MIN_SPACING;// 当前间距
bool increasing = true;      // 控制增长或减小
unsigned long lastUpdate = 0;

void setup() {
    tft.init();
    tft.setRotation(1);
    tft.fillScreen(TFT_BLACK);
    randomSeed(analogRead(0));
}

void loop() {
    if (millis() - lastUpdate > REFRESH_INTERVAL) {
      lastUpdate = millis();
      drawRandomGrid();
      updateSpacing();
    }
}

/**
* 绘制随机颜色网格
*/
void drawRandomGrid() {
    tft.fillScreen(TFT_BLACK);

    for (int x = 0; x < SCREEN_WIDTH; x += spacing) {
      tft.drawLine(x, 0, x, SCREEN_HEIGHT, getRandomColor());
    }
    for (int y = 0; y < SCREEN_HEIGHT; y += spacing) {
      tft.drawLine(0, y, SCREEN_WIDTH, y, getRandomColor());
    }
}

/**
* 生成随机颜色(红、绿、蓝)
*/
uint16_t getRandomColor() {
    int r = random(0, 3);
    if (r == 0) return TFT_RED;
    if (r == 1) return TFT_GREEN;
    return TFT_BLUE;
}

/**
* 更新线条间距,实现 5-50 之间循环变化
*/
void updateSpacing() {
    if (increasing) {
      spacing += 5;
      if (spacing >= MAX_SPACING) increasing = false;
    } else {
      spacing -= 5;
      if (spacing <= MIN_SPACING) increasing = true;
    }
}

驴友花雕 发表于 昨天 10:23

【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格

这段代码在 ESP32 的 TFT 显示屏 上绘制动态网格 ,其中线条间距会在 5 到 50 像素 之间循环变化,每 0.5 秒 更新一次,让网格不断收缩和扩展。


核心逻辑1️⃣ 初始化屏幕 → 使用 TFT_eSPI 控制 ESP32 屏幕,设置 方向 和 背景色
2️⃣ 动态变化网格间距 → 通过 updateSpacing() 控制 间距在 5-50 之间递增和递减
3️⃣ 每 0.5 秒刷新网格 → 使用 millis() 进行时间判断,确保刷新过程不会阻塞其他执行
4️⃣ 随机选择线条颜色 → 通过 getRandomColor() 让 每条线随机变为红、绿、蓝
5️⃣ 形成循环动画效果 → 线条间距会 逐渐增加然后减少,反复循环,让网格动态变化


最终效果规则间隔的网格,每 0.5 秒动态调整间距
红、绿、蓝随机组合,颜色不断变化
线条间距在 5-50 之间循环变化,形成动态动画

驴友花雕 发表于 昨天 10:25

【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格

实验场景图动态图







驴友花雕 发表于 昨天 10:27

【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格




驴友花雕 发表于 昨天 10:29

【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格


页: [1]
查看完整版本: 【花雕学编程】Arduino动手做(249)--GC9A01间距变化的网格