【花雕学编程】Arduino动手做(199)---ESP32 LCD12864屏之随机位置、随机大小的 6 个空心矩形

在这里插入图片描述

《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 LCD12864屏之随机位置、随机大小的 6 个空心矩形

实验开源代码

/*
  【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)
  实验一百九十九:蓝屏LCD12864液晶屏 带中文字库 带背光12864-5V 并口串口
  项目之九:ESP32 LCD12864屏之随机位置、随机大小的 6 个空心矩形
*/

#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);

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

void loop() {
    u8g2.firstPage();
    do {
        // **随机绘制 6 个空心矩形**
        for (int i = 0; i < 6; i++) {
            int x = random(0, 128 - 20);  // **随机 X 坐标**
            int y = random(0, 64 - 20);   // **随机 Y 坐标**
            int w = random(10, 30);       // **随机宽度**
            int h = random(10, 30);       // **随机高度**
            u8g2.drawFrame(x, y, w, h);   // **绘制空心矩形**
        }
    } while (u8g2.nextPage());

    delay(1000);  // **每 1 秒刷新一次**
}

代码简单解读

这段代码在 ST7920 LCD 屏幕 上实现了 随机位置、随机大小的 6 个空心矩形,核心逻辑如下:

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

  2. 生成随机矩形
    ✅ random(0, 128 - 20) → 随机 X 坐标,确保矩形不会超出屏幕边界
    ✅ random(0, 64 - 20) → 随机 Y 坐标,确保矩形不会超出屏幕边界
    ✅ random(10, 30) → 随机矩形宽度和高度

  3. 绘制空心矩形
    ✅ drawFrame(x, y, w, h); → 绘制矩形边框,不填充内部
    ✅ 持续刷新 → delay(1000); 让矩形每秒重新生成

这段代码让 ST7920 屏幕每秒刷新 6 个随机大小的空心矩形,确保它们不会超出屏幕边界。

实验场景图 动态图

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

驴友花雕

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

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

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

打赏作者

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

抵扣说明:

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

余额充值