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

[项目] 【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签

[复制链接]
【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签图2

【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签图1

驴友花雕  中级技神
 楼主|

发表于 9 小时前

【花雕学编程】Arduino动手做(249)--GC9A01滚动电子标价签

【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签图1

【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 9 小时前

【花雕学编程】Arduino动手做(249)--GC9A01滚动电子标价签

【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签图2

【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 9 小时前

【花雕学编程】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 TEXT_HEIGHT 140  // 文本高度
  19. #define SCROLL_SPEED 5  // 滚动速度(像素/步)
  20. #define REFRESH_RATE 50 // 刷新速率(毫秒)
  21. int scrollX = SCREEN_WIDTH;  // 初始滚动位置
  22. String priceTag = "¥ 199.99"; // 价格标签
  23. void setup() {
  24.     tft.init();
  25.     tft.setRotation(2);
  26.     tft.fillScreen(TFT_BLACK);
  27.     tft.setTextColor(TFT_WHITE, TFT_BLACK);
  28.     tft.setTextSize(3);
  29. }
  30. void loop() {
  31.     drawScrollingPrice();
  32.     delay(REFRESH_RATE);
  33. }
  34. /**
  35. * 滚动价格标签
  36. */
  37. void drawScrollingPrice() {
  38.     tft.fillRect(0, SCREEN_HEIGHT - TEXT_HEIGHT, SCREEN_WIDTH, TEXT_HEIGHT, TFT_BLACK);
  39.    
  40.     tft.setCursor(scrollX, SCREEN_HEIGHT - TEXT_HEIGHT);
  41.     tft.print(priceTag);
  42.     scrollX -= SCROLL_SPEED;
  43.     // 价格滚动到最左侧后,重新回到右侧
  44.     if (scrollX < -tft.textWidth(priceTag)) {
  45.         scrollX = SCREEN_WIDTH;
  46.     }
  47. }
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 9 小时前

【花雕学编程】Arduino动手做(249)--GC9A01滚动电子标价签

本帖最后由 驴友花雕 于 2025-4-28 09:06 编辑

代码解读
这段代码在 ESP32 + GC9A01 TFT 显示屏 上实现 动态滚动价格标签,模仿电子价签的显示效果 。

核心逻辑
✅ 滚动文本 → 价格标签从右向左滚动,形成动态效果
✅ 自动循环 → 滚动到最左侧后,重新回到右侧,形成无限循环
✅ 自定义价格 → 价格可以动态更新,支持不同商品价签
✅ 可调滚动速度 → 通过 SCROLL_SPEED 控制滚动速度
✅ 刷新优化 → REFRESH_RATE 控制滚动流畅度

代码解析
1️⃣ 初始化屏幕

  1. tft.init();
  2. tft.setRotation(1);
  3. tft.fillScreen(TFT_BLACK);
  4. tft.setTextColor(TFT_WHITE, TFT_BLACK);
  5. tft.setTextSize(3);
复制代码


设定屏幕方向、填充黑色背景、设置文本颜色和大小。

2️⃣ 价格滚动逻辑

  1. tft.fillRect(0, SCREEN_HEIGHT - TEXT_HEIGHT, SCREEN_WIDTH, TEXT_HEIGHT, TFT_BLACK);
  2. tft.setCursor(scrollX, SCREEN_HEIGHT - TEXT_HEIGHT);
  3. tft.print(priceTag);
  4. scrollX -= SCROLL_SPEED;
  5. if (scrollX < -tft.textWidth(priceTag)) {
  6.     scrollX = SCREEN_WIDTH;
  7. }
复制代码


每次刷新向左移动,直到完全离开屏幕时,重置到右侧,让价格滚动循环显示。

最终视觉效果
屏幕上动态滚动的价格标签
价格标签循环滚动,不断刷新
可以更改价格、调整滚动速度、优化显示效果
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 9 小时前

【花雕学编程】Arduino动手做(249)--GC9A01滚动电子标价签

实验场景图  动态图

【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签图1

【花雕学编程】Arduino动手做(249)--GC9A01滚动的电子价签图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 9 小时前

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