18浏览
查看: 18|回复: 7

[项目] 【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形

[复制链接]
【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图2

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图1

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图1

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图2

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】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 <TFT_eSPI.h>
  15. TFT_eSPI tft = TFT_eSPI();
  16. #define SCREEN_WIDTH 240
  17. #define SCREEN_HEIGHT 240
  18. #define NUM_CIRCLES 13    // 圆形数量
  19. #define MAX_SIZE 30       // 最大圆形大小
  20. #define MIN_SIZE 10       // 最小圆形大小
  21. #define SIZE_CHANGE_RATE 2 // 每次变化的步长
  22. #define REFRESH_RATE 100    // 刷新速率(毫秒)
  23. #define MOVE_SPEED 3       // 位置变化速度(像素/步)
  24. int circleX[NUM_CIRCLES];
  25. int circleY[NUM_CIRCLES];
  26. int circleSize[NUM_CIRCLES];
  27. uint16_t circleColor[NUM_CIRCLES];
  28. bool growing[NUM_CIRCLES]; // 控制圆形变大/变小
  29. int moveX[NUM_CIRCLES];
  30. int moveY[NUM_CIRCLES];
  31. void setup() {
  32.     tft.init();
  33.     tft.setRotation(1);
  34.     tft.fillScreen(TFT_BLACK);
  35.     randomSeed(analogRead(0));
  36.     for (int i = 0; i < NUM_CIRCLES; i++) {
  37.         circleX[i] = random(20, SCREEN_WIDTH - 20);
  38.         circleY[i] = random(20, SCREEN_HEIGHT - 20);
  39.         circleSize[i] = random(MIN_SIZE, MAX_SIZE);
  40.         circleColor[i] = getRandomColor();
  41.         growing[i] = true;
  42.         moveX[i] = (random(0, 2) == 0) ? -MOVE_SPEED : MOVE_SPEED;
  43.         moveY[i] = (random(0, 2) == 0) ? -MOVE_SPEED : MOVE_SPEED;
  44.     }
  45. }
  46. void loop() {
  47.     updateCircleSize();
  48.     updateCirclePosition();
  49.     drawCircles();
  50.     delay(REFRESH_RATE);
  51. }
  52. /**
  53. * 让圆形大小动态变化
  54. */
  55. void updateCircleSize() {
  56.     for (int i = 0; i < NUM_CIRCLES; i++) {
  57.         if (growing[i]) {
  58.             circleSize[i] += SIZE_CHANGE_RATE;
  59.             if (circleSize[i] >= MAX_SIZE) growing[i] = false;
  60.         } else {
  61.             circleSize[i] -= SIZE_CHANGE_RATE;
  62.             if (circleSize[i] <= MIN_SIZE) growing[i] = true;
  63.         }
  64.     }
  65. }
  66. /**
  67. * 让圆形位置随机变化
  68. */
  69. void updateCirclePosition() {
  70.     for (int i = 0; i < NUM_CIRCLES; i++) {
  71.         circleX[i] += moveX[i];
  72.         circleY[i] += moveY[i];
  73.         // 碰到边界反弹
  74.         if (circleX[i] <= 10 || circleX[i] >= SCREEN_WIDTH - 10) moveX[i] = -moveX[i];
  75.         if (circleY[i] <= 10 || circleY[i] >= SCREEN_HEIGHT - 10) moveY[i] = -moveY[i];
  76.     }
  77. }
  78. /**
  79. * 绘制圆形动画
  80. */
  81. void drawCircles() {
  82.     tft.fillScreen(TFT_BLACK);
  83.     for (int i = 0; i < NUM_CIRCLES; i++) {
  84.         tft.fillCircle(circleX[i], circleY[i], circleSize[i], circleColor[i]);
  85.     }
  86. }
  87. /**
  88. * 生成随机颜色(红、绿、蓝)
  89. */
  90. uint16_t getRandomColor() {
  91.     int r = random(0, 3);
  92.     if (r == 0) return TFT_RED;
  93.     if (r == 1) return TFT_GREEN;
  94.     return TFT_BLUE;
  95. }
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形

简单解读
这段代码在 ESP32 + GC9A01 TFT 显示屏 上实现 动态变化的圆形效果,其中圆形的大小和位置都在不断变化,形成漂浮式动画。


核心逻辑
1️⃣ 随机位置 → 每个圆形的坐标会持续变化,看起来像漂浮移动
2️⃣ 动态大小 → 圆形不断变大变小,形成类似呼吸节奏的变化
3️⃣ 颜色严格限定 → 仅使用红、蓝、绿三种颜色,增强视觉冲击力
4️⃣ 边界检测 → 圆形到达屏幕边缘时会反弹,避免超出显示范围
5️⃣ 刷新优化 → 每 50 毫秒 更新一次,让动画平滑流畅


最终效果
屏幕上有 10 个不同大小的圆形不断漂浮变化
颜色限定,形成更炫酷的视觉体验
每个圆形的大小、位置都随机变化,形成柔和的动态动画

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形

实验场景图  动态图

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图2

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图1

【花雕学编程】Arduino动手做(249)--GC9A01呼吸节奏的圆形图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】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