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

[项目] 【花雕学编程】Arduino动手做(199)---空心矩形递减递增

[复制链接]
【花雕学编程】Arduino动手做(199)---空心矩形递减递增图3

【花雕学编程】Arduino动手做(199)---空心矩形递减递增图2

【花雕学编程】Arduino动手做(199)---空心矩形递减递增图1

驴友花雕  中级技神
 楼主|

发表于 前天 13:23

【花雕学编程】Arduino动手做(199)---空心矩形递减递增

【花雕学编程】Arduino动手做(199)---空心矩形递减递增图3

【花雕学编程】Arduino动手做(199)---空心矩形递减递增图1

【花雕学编程】Arduino动手做(199)---空心矩形递减递增图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 前天 13:25

【花雕学编程】Arduino动手做(199)---空心矩形递减递增

  【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口
  项目之十二:ESP32 ST7920屏幕之空心矩形递减递增的循环变化

实验开源代码

  1. /*
  2.   【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  3.   实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口
  4.   项目之十二:ESP32 ST7920屏幕之空心矩形递减递增的循环变化
  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. int width = 128;   // **矩形长边最大 128**
  12. int height = 64;   // **矩形短边最大**
  13. int minSize = 4;  // **最小尺寸**
  14. int step = 1;      // **缩小步长(共 64 段)**
  15. bool shrinking = true; // **控制递减或递增**
  16. void setup() {
  17.     Serial.begin(115200);
  18.     u8g2.begin();
  19.     u8g2.setPowerSave(0);  // **关闭省电模式**
  20.     u8g2.setContrast(200); // **提高对比度**
  21.     u8g2.setDisplayRotation(U8G2_R2);  // **旋转 180 度**
  22. }
  23. void loop() {
  24.     u8g2.firstPage();
  25.     do {
  26.         int x = (128 - width) / 2;  // **确保矩形居中**
  27.         int y = (64 - height) / 2;
  28.         u8g2.drawFrame(x, y, width, height);  // **绘制空心矩形**
  29.     } while (u8g2.nextPage());
  30.     // **调整矩形尺寸**
  31.     if (shrinking) {
  32.         width -= step;  
  33.         height -= step;  
  34.         if (width <= minSize || height <= minSize) {
  35.             shrinking = false; // **切换为递增**
  36.         }
  37.     } else {
  38.         width += step;  
  39.         height += step;  
  40.         if (width >= 128 || height >= 64) { // **恢复最大尺寸**
  41.             shrinking = true; // **切换为递减**
  42.         }
  43.     }
  44.     delay(5);  // **控制变化速度**
  45. }
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 前天 13:28

【花雕学编程】Arduino动手做(199)---空心矩形递减递增

代码简单解读

这段代码在 ST7920 LCD 屏幕 上实现了 空心矩形递减递增的循环变化,核心逻辑如下:

1. 初始化
✅ u8g2.begin(); → 启动 ST7920 屏幕
✅ u8g2.setPowerSave(0); → 确保屏幕不会休眠
✅ u8g2.setContrast(200); → 提高对比度,让图形清晰
✅ u8g2.setDisplayRotation(U8G2_R2); → 让屏幕旋转 180 度

2. 递减 & 递增
✅ size -= 1; → 矩形尺寸递减
✅ if (size <= minSize) shrinking = false; → 达到最小尺寸后改为递增
✅ size += 1; → 矩形尺寸递增
✅ if (size >= 128) shrinking = true; → 达到最大尺寸后改为递减

3. 居中绘制矩形
✅ int x = (128 - size) / 2;, int y = (64 - size) / 2; → 确保矩形始终居中
✅ drawFrame(x, y, size, size); → 绘制空心矩形

4. 画面刷新
✅ delay(50); → 每 50 毫秒更新一次,形成流畅动画
✅ firstPage(); do { ... } while (nextPage()); → 确保显示稳定,不闪烁

这段代码让 ST7920 屏幕循环显示从大到小、再从小到大的矩形变化。





回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 前天 13:30

【花雕学编程】Arduino动手做(199)---空心矩形递减递增

实验场景图  动态图

【花雕学编程】Arduino动手做(199)---空心矩形递减递增图1

【花雕学编程】Arduino动手做(199)---空心矩形递减递增图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 前天 13:33

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