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

【花雕学编程】Arduino动手做(249)---ESP32+GC9A01之每 2 秒切换一次限速标志显示仿真交通路牌 简单

头像 驴友花雕 2025.04.26 9 0

00 (2).jpg
02.jpg
03.jpg
10 (1).jpg
12.jpg
15.jpg

 【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
 实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
 项目之一百二十九:ESP32+GC9A01之每 2 秒切换一次限速标志显示仿真交通路牌

实验开源代码

 

代码
/*
  【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
  实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
  项目之一百二十九:ESP32+GC9A01之每 2 秒切换一次限速标志显示仿真交通路牌
*/

//       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 REFRESH_INTERVAL 2000 // 每 2 秒刷新一次

const char* speedLimits[] = {"30", "50", "80", "100"}; // 速度限制
int currentIndex = 0;
unsigned long lastUpdate = 0;

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

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

/**
 * 显示限速交通标志
 */
void showSpeedLimit() {
    tft.fillScreen(TFT_BLACK);
    tft.setTextColor(TFT_RED, TFT_WHITE);
    tft.setTextSize(6);

    tft.fillCircle(120, 120, 60, TFT_WHITE);  // 绘制白色限速牌
    tft.drawCircle(120, 120, 65, TFT_RED);    // 加宽红色外圈
    tft.drawCircle(120, 120, 70, TFT_RED);    // 进一步加宽,增加层次感

    tft.setTextDatum(MC_DATUM);
    tft.drawString(speedLimits[currentIndex], 120, 120);  // 显示速度限制

    currentIndex = (currentIndex + 1) % 4; // 轮换显示 30、50、80、100
}

这段代码在 ESP32 TFT 显示屏 上模拟交通指示牌 🚦✨,它能够 每 2 秒切换一次限速标志,让屏幕上的显示仿真真实路牌。

核心逻辑
1️⃣ 使用 fillCircle() 绘制圆形限速标志 → 屏幕上显示 白色限速牌,红色边框 
2️⃣ 使用 drawString() 显示速度限制 → 在圆形中间写上 "30"、"50"、"80"、"100" 
3️⃣ 每 2 秒自动切换 → 使用 millis() 控制时间,使限速牌变化 
4️⃣ 颜色匹配交通指示 → 红色外圈 + 白色背景 + 黑色数字,符合标准路牌样式

最终效果
🚗 屏幕上显示 "限速 30"、"限速 50"… 依次变化 ⏳ 每 2 秒自动更新,让显示更动态 🎨 真实交通标志风格,适用于模拟系统
 

实验场景图  动态图

 

93-1 (1).jpg
93-1 (2).jpg
93-1 (3).jpg
00118--.gif

评论

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