190浏览
查看: 190|回复: 6

[项目] 【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟

[复制链接]
【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图2

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图1

驴友花雕  中级技神
 楼主|

发表于 2025-4-17 20:13:28

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图1

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2025-4-17 20:15:06

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图1

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2025-4-17 20:16:12

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟

  【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
  实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
  项目之一百零八:ESP32+GC9A01之完整的模拟时钟,包含刻度、指针和动态时间更新

实验开源代码

  1. /*
  2.   【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
  3.   实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
  4.   项目之一百零八:ESP32+GC9A01之完整的模拟时钟,包含刻度、指针和动态时间更新
  5. */
  6.   //       GC9A01---------- ESP32
  7.   //       RST ------------ NC(复位引脚,此处未连接)
  8.   //       CS ------------- D4(片选引脚,连接到ESP32的D4引脚)
  9.   //       DC ------------- D2(数据/命令选择引脚,连接到ESP32的D2引脚)
  10.   //       SDA ------------ D23 (green)(主数据输出引脚,连接到ESP32的D23引脚,绿色线)
  11.   //       SCL ------------ D18 (yellow)(时钟信号引脚,连接到ESP32的D18引脚,黄色线)
  12.   //       GND ------------ GND(接地引脚,连接到ESP32的接地端)
  13.   //       VCC -------------3V3(电源引脚,连接到ESP32的3.3V电源)
  14.   #include <SPI.h>
  15.   #include <TFT_eSPI.h> // 引入 TFT_eSPI 库,用于驱动 TFT 显示屏
  16.   #define TFT_GREY 0x5AEB // 定义灰色作为背景颜色
  17.   TFT_eSPI tft = TFT_eSPI(); // 初始化 TFT 屏幕对象
  18.   // 定义指针的坐标变量
  19.   float sx = 0, sy = 1, mx = 1, my = 0, hx = -1, hy = 0;  // 用于存储时、分、秒针的旋转坐标
  20.   float sdeg=0, mdeg=0, hdeg=0; // 用于存储时、分、秒针的角度
  21.   uint16_t osx=120, osy=120, omx=120, omy=120, ohx=120, ohy=120;  // 旧坐标值,用于擦除指针
  22.   uint16_t x0=0, x1=0, yy0=0, yy1=0; // 刻度线坐标
  23.   uint32_t targetTime = 0;  // 定义时间变量,每秒更新一次
  24.   // 获取编译时间(仅用于初始化时钟)
  25.   static uint8_t conv2d(const char* p); // 预声明转换函数
  26.   uint8_t hh = conv2d(__TIME__);        // 解析当前小时
  27.   uint8_t mm = conv2d(__TIME__ + 3);    // 解析当前分钟
  28.   uint8_t ss = conv2d(__TIME__ + 6);    // 解析当前秒数
  29.   bool initial = true;  // 标记是否为初始化状态
  30.   void setup(void) {
  31.     tft.init();  // 初始化屏幕
  32.     tft.setRotation(0);  // 设置屏幕旋转方向
  33.     tft.fillScreen(TFT_GREY);  // 填充背景颜色
  34.     tft.setTextColor(TFT_WHITE, TFT_GREY);  // 设置文字颜色,背景颜色自动清除旧文字
  35.     // **绘制时钟表盘**
  36.     tft.fillCircle(120, 120, 118, TFT_GREEN);  // 绘制外层绿色圆形
  37.     tft.fillCircle(120, 120, 110, TFT_BLACK);  // 绘制内层黑色圆形(表盘主体)
  38.     // **绘制 12 个刻度线**
  39.     for (int i = 0; i < 360; i += 30) {
  40.         sx = cos((i - 90) * 0.0174532925);  // 计算角度偏移
  41.         sy = sin((i - 90) * 0.0174532925);
  42.         x0 = sx * 114 + 120;  // 外端坐标
  43.         yy0 = sy * 114 + 120;
  44.         x1 = sx * 100 + 120;  // 内端坐标
  45.         yy1 = sy * 100 + 120;
  46.         tft.drawLine(x0, yy0, x1, yy1, TFT_GREEN);  // 绘制绿色刻度线
  47.     }
  48.     // **绘制 60 个分钟标记**
  49.     for (int i = 0; i < 360; i += 6) {
  50.         sx = cos((i - 90) * 0.0174532925);
  51.         sy = sin((i - 90) * 0.0174532925);
  52.         x0 = sx * 102 + 120;
  53.         yy0 = sy * 102 + 120;
  54.         tft.drawPixel(x0, yy0, TFT_WHITE);  // 绘制白色像素点
  55.         // **绘制四个主刻度点**
  56.         if (i == 0 || i == 180) tft.fillCircle(x0, yy0, 2, TFT_WHITE);
  57.         if (i == 90 || i == 270) tft.fillCircle(x0, yy0, 2, TFT_WHITE);
  58.     }
  59.     // **绘制中心点**
  60.     tft.fillCircle(120, 121, 3, TFT_WHITE);
  61.     // **在屏幕底部绘制文字**
  62.     tft.drawCentreString("Time flies", 120, 260, 4);  // 居中显示文字
  63.     targetTime = millis() + 1000;  // 设置目标时间,每秒更新一次
  64.   }
  65.   void loop() {
  66.     // **每秒更新时间**
  67.     if (targetTime < millis()) {
  68.         targetTime += 1000;
  69.         ss++;  // 秒数递增
  70.         if (ss == 60) {
  71.             ss = 0;
  72.             mm++;  // 分钟递增
  73.             if (mm > 59) {
  74.                 mm = 0;
  75.                 hh++;  // 小时递增
  76.                 if (hh > 23) {
  77.                     hh = 0;
  78.                 }
  79.             }
  80.         }
  81.         // **计算指针角度**
  82.         sdeg = ss * 6;  // 秒针:0-59 -> 0-354
  83.         mdeg = mm * 6 + sdeg * 0.01666667;  // 分针:包含秒钟偏移
  84.         hdeg = hh * 30 + mdeg * 0.0833333;  // 时针:包含分钟偏移
  85.         hx = cos((hdeg - 90) * 0.0174532925);
  86.         hy = sin((hdeg - 90) * 0.0174532925);
  87.         mx = cos((mdeg - 90) * 0.0174532925);
  88.         my = sin((mdeg - 90) * 0.0174532925);
  89.         sx = cos((sdeg - 90) * 0.0174532925);
  90.         sy = sin((sdeg - 90) * 0.0174532925);
  91.         // **擦除旧指针**
  92.         if (ss == 0 || initial) {
  93.             initial = false;
  94.             tft.drawLine(ohx, ohy, 120, 121, TFT_BLACK);
  95.             ohx = hx * 62 + 121;
  96.             ohy = hy * 62 + 121;
  97.             tft.drawLine(omx, omy, 120, 121, TFT_BLACK);
  98.             omx = mx * 84 + 120;
  99.             omy = my * 84 + 121;
  100.         }
  101.         // **绘制新指针**
  102.         tft.drawLine(osx, osy, 120, 121, TFT_BLACK);  // 擦除旧秒针
  103.         osx = sx * 90 + 121;
  104.         osy = sy * 90 + 121;
  105.         tft.drawLine(osx, osy, 120, 121, TFT_RED);  // 绘制新秒针
  106.         tft.drawLine(ohx, ohy, 120, 121, TFT_WHITE);  // 绘制时针
  107.         tft.drawLine(omx, omy, 120, 121, TFT_WHITE);  // 绘制分针
  108.         tft.drawLine(osx, osy, 120, 121, TFT_RED);  // 绘制秒针
  109.         // **绘制中心点**
  110.         tft.fillCircle(120, 121, 3, TFT_RED);
  111.     }
  112.   }
  113.   // **字符串转换为数字**
  114.   static uint8_t conv2d(const char* p) {
  115.     uint8_t v = 0;
  116.     if ('0' <= *p && *p <= '9')
  117.         v = *p - '0';
  118.     return 10 * v + *++p - '0';
  119.   }
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2025-4-17 20:18:05

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟

这段代码绘制了一个模拟时钟,并且 实时更新指针位置 来显示当前时间。
代码结构

1️⃣ 初始化屏幕
  • 使用 TFT_eSPI 驱动 GC9A01 显示屏,设定 灰色背景

2️⃣ 绘制时钟表盘
  • fillCircle() 绘制 绿色外圈黑色表盘
  • drawLine() 画 12 个小时刻度,确保时钟准确性。
  • drawPixel() 画 60 个小刻度,增强细节表现。

3️⃣ 计算指针角度
  • 秒针:sdeg = ss * 6,秒数直接映射到角度。
  • 分针:mdeg = mm * 6 + sdeg * 0.01666667,确保秒钟影响分针。
  • 时针:hdeg = hh * 30 + mdeg * 0.0833333,包括分钟偏移。

4️⃣ 指针动态旋转
  • 每秒更新 时针、分针、秒针,并擦除旧位置,确保流畅动画。
  • 红色秒针动态变化,形成真实时钟效果。

5️⃣ 持续刷新
  • millis() 计算时间,每 1 秒更新 指针位置,保持流畅动画。



最终效果
屏幕上显示模拟时钟,时针、分针、秒针动态更新
表盘美观,增强视觉体验
秒针移动流畅,使时间显示真实

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2025-4-17 20:23:29

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟

实验场景图  动态图

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图2

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2025-4-17 20:25:59

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟

【花雕学编程】Arduino动手做(249)--GC9A01完整的模拟时钟图1
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

为本项目制作心愿单
购买心愿单
心愿单 编辑
[[wsData.name]]

硬件清单

  • [[d.name]]
btnicon
我也要做!
点击进入购买页面
上海智位机器人股份有限公司 沪ICP备09038501号-4 备案 沪公网安备31011502402448

© 2013-2025 Comsenz Inc. Powered by Discuz! X3.4 Licensed

mail