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

[项目] 【花雕学编程】Arduino动手做(199)---随机绘制10个图形

[复制链接]
【花雕学编程】Arduino动手做(199)---随机绘制10个图形图3

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图2

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图1

驴友花雕  中级技神
 楼主|

发表于 昨天 12:23

【花雕学编程】Arduino动手做(199)---随机绘制10个图形

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图3

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图1

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 昨天 12:27

【花雕学编程】Arduino动手做(199)---随机绘制10个图形

  【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口
  项目之十一:ESP32 ST7920屏幕之随机绘制10个不同形状(圆形、三角形和矩形)

实验开源代码

  1. #include <Arduino.h>
  2. #include <U8g2lib.h>
  3. #include <SPI.h>
  4. // 使用软件 SPI 适配 ESP32
  5. U8G2_ST7920_128X64_F_SW_SPI u8g2(U8G2_R0, /* Clock=*/ 18, /* Data=*/ 23, /* CS=*/ 16, /* Reset=*/ 17);
  6. int size = 128;   // **初始矩形大小**
  7. int minSize = 10; // **最小矩形大小**
  8. int step = 2;     // **缩小步长**
  9. bool shrinking = true; // **控制递减或递增**
  10. void setup() {
  11.     Serial.begin(115200);
  12.     u8g2.begin();
  13.     u8g2.setPowerSave(0);  // **关闭省电模式**
  14.     u8g2.setContrast(200); // **提高对比度**
  15.     u8g2.setDisplayRotation(U8G2_R2);  // **旋转 180 度**
  16. }
  17. void loop() {
  18.     u8g2.firstPage();
  19.     do {
  20.         int x = (128 - size) / 2 + 1;  // **确保矩形不贴屏幕边缘**
  21.         int y = (64 - size) / 2 + 1;
  22.         u8g2.drawFrame(x, y, size - 2, size - 2);  // **绘制空心矩形**
  23.     } while (u8g2.nextPage());
  24.     // **调整矩形尺寸**
  25.     if (shrinking) {
  26.         size -= step;  // **递减**
  27.         if (size <= minSize) {
  28.             shrinking = false; // **切换为递增**
  29.         }
  30.     } else {
  31.         size += step;  // **递增**
  32.         if (size >= 128) { // **最大值 128,确保完整循环**
  33.             shrinking = true; // **切换为递减**
  34.         }
  35.     }
  36.     delay(50);  // **控制变化速度**
  37. }
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 昨天 12:32

【花雕学编程】Arduino动手做(199)---随机绘制10个图形

简单解读
这段代码在 ST7920 LCD 屏幕 上实现了 随机绘制 10 个图形(圆形、三角形和矩形),核心逻辑如下:

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

2. 随机生成图形
✅ random(0, 3) → 随机选择形状(圆形、矩形或三角形)
✅ random(0, 128) → 随机 X 坐标,确保图形分布均匀
✅ random(0, 64) → 随机 Y 坐标,确保图形不会超出屏幕
✅ random(10, 30) → 随机大小

3. 绘制不同图形
✅ drawCircle(x, y, size); → 绘制圆形
✅ drawFrame(x, y, size, size); → 绘制空心矩形
✅ drawTriangle(x, y, x+size, y+size, x-size, y+size); → 绘制三角形

4. 画面刷新
✅ delay(1000); → 每秒重新生成 10 个新图形
✅ firstPage(); do { ... } while (nextPage()); → 确保显示流畅,无闪烁

这个代码让 ST7920 屏幕不断随机显示 10 个图形,每秒刷新一次。





回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 昨天 12:40

【花雕学编程】Arduino动手做(199)---随机绘制10个图形

实验场景图  动态图

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图1

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图2
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 昨天 12:42

【花雕学编程】Arduino动手做(199)---随机绘制10个图形

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图1

【花雕学编程】Arduino动手做(199)---随机绘制10个图形图2
回复

使用道具 举报

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

本版积分规则

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

硬件清单

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

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

mail