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

在这里插入图片描述

《Arduino 手册(思路与案例)》栏目介绍:
在电子制作与智能控制的应用领域:广泛涉及了Arduino BLDC、Arduino CNC、Arduino ESP32 SPP、Arduino FreeRTOS、Arduino FOC、Arduino GRBL、Arduino HTTP、Arduino HUB75、Arduino IoT Cloud、Arduino JSON、Arduino LCD、Arduino OLED、Arduino LVGL、Arduino PID 及 Arduino TFT 等方面的相关拓展思路和众多参考案例。本专栏目前博客近2300篇。
https://blog.csdn.net/weixin_41659040/category_12422453.html

37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里准备逐一动手试试多做实验,不管成功与否,都会记录下来——小小的进步或是搞不掂的问题,希望能够抛砖引玉。

【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口

在这里插入图片描述
在这里插入图片描述

显示器 12864 蓝底白字 - 3.3V
这是一个带 LED 背光的带框型 LCD 图形 128x64。ST7920 控制器型 LCD,具有简单的命令界面。该显示器利用非官方的 12864 Arduino 库和 ST7920 芯片,使其成为几乎所有 Arduino 板项目的绝佳选择。LCD 在蓝色 LED 背光背景上提供白色文本,其引脚支持并行和串行接口。它在 3.3V 下工作,并集成了对比度调整软件控制。

在这里插入图片描述

实验模块接线示意图

在这里插入图片描述
【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 屏幕循环显示从大到小、再从小到大的矩形变化。

实验场景图 动态图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

驴友花雕

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值