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

【花雕学编程】Arduino动手做(199)---ESP32 ST7920 屏幕之空心矩形递减递增的循环变化 简单

头像 驴友花雕 2025.05.07 11 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 width = 128;   // **矩形长边最大 128**
int height = 64;   // **矩形短边最大**
int minSize = 4;  // **最小尺寸**
int step = 1;      // **缩小步长(共 64 段)**
bool shrinking = true; // **控制递减或递增**

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

void loop() {
    u8g2.firstPage();
    do {
        int x = (128 - width) / 2;  // **确保矩形居中**
        int y = (64 - height) / 2;
        u8g2.drawFrame(x, y, width, height);  // **绘制空心矩形**
    } while (u8g2.nextPage());

    // **调整矩形尺寸**
    if (shrinking) {
        width -= step;  
        height -= step;  
        if (width <= minSize || height <= minSize) {
            shrinking = false; // **切换为递增**
        }
    } else {
        width += step;  
        height += step;  
        if (width >= 128 || height >= 64) { // **恢复最大尺寸**
            shrinking = true; // **切换为递减**
        }
    }

    delay(5);  // **控制变化速度**
}

代码简单解读

这段代码在 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 屏幕循环显示从大到小、再从小到大的矩形变化。


实验场景图  动态图

 

11-7 (1).jpg
11-7 (2).jpg
00126-.gif

评论

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