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

[项目] 【花雕学编程】Arduino动手做(199)---三行文本向上滚动

[复制链接]
【花雕学编程】Arduino动手做(199)---三行文本向上滚动图2

【花雕学编程】Arduino动手做(199)---三行文本向上滚动图3

【花雕学编程】Arduino动手做(199)---三行文本向上滚动图1

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(199)---三行文本向上滚动

【花雕学编程】Arduino动手做(199)---三行文本向上滚动图3

【花雕学编程】Arduino动手做(199)---三行文本向上滚动图1

【花雕学编程】Arduino动手做(199)---三行文本向上滚动图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(199)---三行文本向上滚动

  【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口
  项目之四:ESP32 LCD12864屏之三行文本循环向上滚动

实验开源代码

  1. /*
  2.   【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  3.   实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口
  4.   项目之四:ESP32 LCD12864屏之三行文本循环向上滚动
  5. */
  6. #include <Arduino.h>
  7. #include <U8g2lib.h>
  8. #include <SPI.h>
  9. // 使用软件 SPI 适配 ESP32
  10. U8G2_ST7920_128X64_F_SW_SPI u8g2(U8G2_R0, /* Clock=*/ 18, /* Data=*/ 23, /* CS=*/ 16, /* Reset=*/ 17);
  11. const char* lines[] = { "Line 1: Hello!", "Line 2: ESP32", "Line 3: Scrolling" };
  12. int yPos = 64; // **初始位置(最下方)**
  13. int lineHeight = 20; // **行间距**
  14. void setup() {
  15.     Serial.begin(115200);
  16.     Serial.println("初始化 ST7920...");
  17.    
  18.     u8g2.begin();
  19.     u8g2.setPowerSave(0);  // **确保屏幕不休眠**
  20.     u8g2.setContrast(200); // **提高对比度**
  21.     u8g2.setDisplayRotation(U8G2_R2);  // **旋转 180 度**
  22.    
  23.     Serial.println("初始化完成");
  24. }
  25. void loop() {
  26.     u8g2.setFont(u8g2_font_ncenB14_tr);
  27.     u8g2.firstPage();
  28.     do {
  29.         for (int i = 0; i < 3; i++) {
  30.             u8g2.setCursor(0, yPos + (i * lineHeight));
  31.             u8g2.print(lines[i]);
  32.         }
  33.     } while (u8g2.nextPage());
  34.     yPos--;  // **让文本向上滚动**
  35.    
  36.     // **如果最上方的文本完全滚出屏幕,重置位置**
  37.     if (yPos < -lineHeight) {
  38.         yPos = 64;
  39.     }
  40.     delay(10);  // **控制滚动速度**
  41. }
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(199)---三行文本向上滚动

代码简单解读

这段代码实现了 三行文本循环向上滚动,核心逻辑如下:

1. 初始化
✅ u8g2.begin(); → 启动 ST7920
✅ u8g2.setPowerSave(0); → 确保屏幕不会休眠
✅ u8g2.setContrast(200); → 调整对比度,让文本更清晰
✅ yPos = 64; → 文本初始位置,从屏幕底部开始滚动

2. 文本滚动
✅ yPos-- → 每次减少 1,让文本向上移动
✅ setCursor(10, yPos + (i * lineHeight)); → 正确排列三行文字
✅ if (yPos < -lineHeight) yPos = 64; → 如果滚动到最上方,重置位置

3. 画面刷新
✅ firstPage(); do { ... } while (nextPage()); → 逐步绘制,避免闪烁
✅ delay(100); → 控制滚动速度,可调整让滚动更快或更慢

这段代码让 三行文本从屏幕底部滚动到顶部,并循环显示。




回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(199)---三行文本向上滚动

实验场景图  动态图

【花雕学编程】Arduino动手做(199)---三行文本向上滚动图1

【花雕学编程】Arduino动手做(199)---三行文本向上滚动图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 3 小时前

【花雕学编程】Arduino动手做(199)---三行文本向上滚动

【花雕学编程】Arduino动手做(199)---三行文本向上滚动图1
回复

使用道具 举报

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

本版积分规则

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

硬件清单

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

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

mail