回到首页 返回首页
回到顶部 回到顶部
返回上一页 返回上一页

【花雕学编程】Arduino动手做(199)---ESP32 LCD12864屏之绘制递减边长的同心填充三角形 简单

头像 驴友花雕 2025.05.07 8 0

00 (1).jpg
00 (2).jpg
03.jpg
09.jpg
10 (1).jpg
10-1.jpg

【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口
项目之十:ESP32 ST7920屏幕之之绘制递减边长的同心填充三角形

实验开源代码

代码
/*
  【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口
  项目之十:ESP32  ST7920屏幕之之绘制递减边长的同心填充三角形
*/

#include <Arduino.h>
#include <U8g2lib.h>
#include <SPI.h>

// 使用软件 SPI 适配 ESP32
U8G2_ST7920_128X64_F_SW_SPI u8g2(U8G2_R0, /* Clock=*/ 18, /* Data=*/ 23, /* CS=*/ 16, /* Reset=*/ 17);

int sideLength = 60;  // **初始三角形边长**
int minLength = 10;   // **最小边长**
int step = 2;         // **每次缩小的间隔**
int centerX = 64;     // **屏幕中心 X**
int centerY = 32;     // **屏幕中心 Y**

void setup() {
  Serial.begin(115200);
  u8g2.begin();
  u8g2.setPowerSave(0);  // **关闭省电模式**
  u8g2.setContrast(200); // **提高对比度**
  u8g2.setDisplayRotation(U8G2_R2);  // **旋转 180 度**
}

void loop() {
  u8g2.firstPage();
  do {
    int s = sideLength;
    while (s >= minLength) {
      int x1 = centerX - s / 2;
      int y1 = centerY + s / 2;
      int x2 = centerX + s / 2;
      int y2 = centerY + s / 2;
      int x3 = centerX;
      int y3 = centerY - s / 2;

      u8g2.drawTriangle(x1, y1, x2, y2, x3, y3);  // **绘制空心三角形**
      s -= step;  // **缩小边长**
    }
  } while (u8g2.nextPage());

  sideLength -= step;  // **每次递减边长**

  // **如果缩小到最小值,重新开始**
  if (sideLength < minLength) {
    sideLength = 60;
  }

  delay(100);  //**每0.1秒刷新一次**
}

代码简单解读

这段代码在 ST7920 LCD 屏幕 上实现了 同心空心三角形绘制,核心逻辑如下:

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

2. 递减绘制三角形
✅ sideLength -= step; → 让三角形尺寸逐渐缩小 
✅ while (s >= minLength) → 保证三角形不小于设定的最小值 
✅ if (sideLength < minLength) sideLength = 60; → 到最小尺寸后重置为最大

3. 计算三角形坐标
✅ 计算三角形顶点:

x1 = centerX - s / 2;, y1 = centerY + s / 2; → 左下角顶点

x2 = centerX + s / 2;, y2 = centerY + s / 2; → 右下角顶点

x3 = centerX;, y3 = centerY - s / 2; → 上方顶点 
✅ drawTriangle(x1, y1, x2, y2, x3, y3); → 使用 U8g2 API 绘制空心三角形

4. 画面刷新
✅ delay(500); → 每 500 毫秒更新一次显示 
✅ firstPage(); do { ... } while (nextPage()); → 保证绘制流畅,无闪烁

这段代码让 ST7920 屏幕不断绘制同心空心三角形,从大到小循环展示


实验场景图  动态图

 

11-5 (1).jpg
11-5 (2).jpg
00125----.gif

评论

user-avatar
icon 他的勋章
    展开更多