驴友花雕 发表于 2025-4-14 10:52:24

【花雕学编程】Arduino动手做(249)---GC9A01电量WiFi指示器




驴友花雕 发表于 2025-4-14 11:26:58

【花雕学编程】Arduino动手做(249)---GC9A01电量WiFi指示器




驴友花雕 发表于 2025-4-14 11:32:31

【花雕学编程】Arduino动手做(249)---GC9A01电量WiFi指示器




驴友花雕 发表于 2025-4-14 11:33:47

【花雕学编程】Arduino动手做(249)---GC9A01电量WiFi指示器

【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
项目之八十八:GC9A01园屏之WiFi信号强度与电池电量的状态指示器

实验开源代码

/*
【Arduino】189种传感器模块系列实验(资料代码+仿真编程+图形编程)
实验二百四十九:1.28寸圆形彩色TFT显示屏 高清IPS 模块 240*240 SPI接口GC9A01驱动
项目之八十八:GC9A01园屏之WiFi信号强度与电池电量的状态指示器
*/

//       GC9A01---------- ESP32
//       RST ------------ NC(复位引脚,此处未连接)
//       CS ------------- D4(片选引脚,连接到ESP32的D4引脚)
//       DC ------------- D2(数据/命令选择引脚,连接到ESP32的D2引脚)
//       SDA ------------ D23 (green)(主数据输出引脚,连接到ESP32的D23引脚,绿色线)
//       SCL ------------ D18 (yellow)(时钟信号引脚,连接到ESP32的D18引脚,黄色线)
//       GND ------------ GND(接地引脚,连接到ESP32的接地端)
//       VCC -------------3V3(电源引脚,连接到ESP32的3.3V电源)

// 引入SPI通信库,用于与TFT屏幕进行SPI通信
#include "SPI.h"
// 引入Adafruit图形库,提供图形绘制的基础功能
#include "Adafruit_GFX.h"
// 引入Adafruit GC9A01A屏幕驱动库,用于控制GC9A01A型号的TFT屏幕
#include "Adafruit_GC9A01A.h"

// 定义TFT屏幕的片选引脚
#define TFT_CS 4
// 定义TFT屏幕的数据/命令选择引脚
#define TFT_DC 2
// 定义TFT屏幕的复位引脚,-1表示不使用该引脚
#define TFT_RST -1

// 创建Adafruit_GC9A01A对象,用于控制TFT屏幕
Adafruit_GC9A01A tft = Adafruit_GC9A01A(TFT_CS, TFT_DC, TFT_RST);

// 定义屏幕的宽度
#define SCREEN_WIDTH 240
// 定义屏幕的高度
#define SCREEN_HEIGHT 240
// 定义图标(如电池、WiFi信号图标)的大小
#define ICON_SIZE 50
// 定义显示文本的大小
#define TEXT_SIZE 3
// 定义状态更新的时间间隔,单位为毫秒
#define UPDATE_SPEED 1000

// 定义电池电量变量,初始值为100%
int batteryLevel = 100;
// 定义WiFi信号强度变量,初始值为5
int wifiStrength = 5;

// 初始化函数,在程序开始时执行一次
void setup() {
    // 初始化串口通信,波特率为115200,用于调试信息输出
    Serial.begin(115200);
    // 初始化TFT屏幕
    tft.begin();
    // 设置TFT屏幕的旋转方向为2,即旋转180度
    tft.setRotation(2);
}

// 循环函数,程序开始后会不断循环执行
void loop() {
    // 用黑色填充整个屏幕,清除上一帧的显示内容
    tft.fillScreen(tft.color565(0, 0, 0));

    // 绘制电池图标
    drawBatteryIcon();
    // 绘制WiFi信号图标
    drawWiFiIcon();
    // 显示电池和WiFi的状态数值
    displayStatusText();

    // 更新电池电量和WiFi信号强度
    updateStatus();

    // 延迟一段时间,控制状态更新的速度
    delay(UPDATE_SPEED);
}

// 绘制电池图标的函数
void drawBatteryIcon() {
    // 绘制电池的外框,矩形的左上角坐标为(70, 40),宽和高为ICON_SIZE,颜色为白色
    tft.drawRect(70, 40, ICON_SIZE, ICON_SIZE, tft.color565(255, 255, 255));
    // 计算电池电量对应的宽度,电池电量每3%对应1个像素宽度
    int batteryWidth = batteryLevel / 3;
    // 绘制电池内部的电量进度条,矩形的左上角坐标为(75, 45),宽度为batteryWidth,高度为ICON_SIZE - 10,颜色为绿色
    tft.fillRect(75, 45, batteryWidth, ICON_SIZE - 10, tft.color565(0, 255, 0));
}

// 绘制WiFi信号图标的函数
void drawWiFiIcon() {
    // 循环绘制WiFi信号的圆圈,根据WiFi信号强度绘制不同数量的圆圈
    for (int i = 0; i < wifiStrength; i++) {
      // 计算每个圆圈的圆心坐标,x坐标为150 + (i * 8),y坐标为65
      // 圆圈的半径为10 + i * 2,颜色为蓝色
      tft.fillCircle(150 + (i * 8), 65, 10 + i * 2, tft.color565(0, 0, 255));
    }
}

// 显示状态数值的函数
void displayStatusText() {
    // 设置文本颜色为白色
    tft.setTextColor(tft.color565(255, 255, 255));
    // 设置文本大小为TEXT_SIZE
    tft.setTextSize(TEXT_SIZE);

    // 设置文本的起始坐标为(10, 106),显示电池电量信息
    tft.setCursor(10, 106);
    tft.print("Battery: ");
    tft.print(batteryLevel);
    tft.print("%");

    // 设置文本的起始坐标为(40, 160),显示WiFi信号强度信息
    tft.setCursor(40, 160);
    tft.print("WiFi: ");
    tft.print(wifiStrength);
    tft.print("/5");
}

// 更新状态的函数
void updateStatus() {
    // 随机减少电池电量,减少的范围为1到4
    batteryLevel -= random(1, 5);
    // 如果电池电量小于等于0,则将电池电量重置为100%
    if (batteryLevel <= 0) batteryLevel = 100;

    // 随机生成WiFi信号强度,范围为1到5
    wifiStrength = random(1, 6);
}   

驴友花雕 发表于 2025-4-14 11:35:16

【花雕学编程】Arduino动手做(249)---GC9A01电量WiFi指示器

这段代码的核心功能是 动态状态指示器,通过图标和数值显示电池电量和 WiFi 信号强度,并随着时间变化进行实时更新。

代码结构1️⃣ 初始化屏幕

[*]使用 Adafruit_GC9A01A 控制 TFT 显示屏,设置黑色背景。

2️⃣ 绘制电池图标

[*]drawRect() 创建 白色矩形外框,表示电池边框。

[*]fillRect() 绘制 绿色充电进度条,随着电量下降而变化。

3️⃣ 绘制 WiFi 信号图标

[*]使用 fillCircle() 生成 多个蓝色圆点,表示 WiFi 信号强度,信号越强圆点越多。

4️⃣ 显示状态数值

[*]print() 实时显示 电池电量百分比 和 WiFi 信号强度,让信息更加直观。

5️⃣ 动态更新数据

[*]batteryLevel 变量 随机下降,模拟电池电量消耗,并在耗尽后重置为满格。

[*]wifiStrength 变量 随机变化,模拟 WiFi 信号的波动。



最终效果屏幕上实时显示电池电量和 WiFi 信号强度
图标和数值不断更新,模拟真实状态变化
黑色背景 + 白色边框 + 绿色/蓝色图标 + 数值显示,提高视觉对比度

驴友花雕 发表于 2025-4-14 11:38:08

【花雕学编程】Arduino动手做(249)---GC9A01电量WiFi指示器

实验场景图动态图




驴友花雕 发表于 2025-4-14 11:40:27

【花雕学编程】Arduino动手做(249)---GC9A01电量WiFi指示器


页: [1]
查看完整版本: 【花雕学编程】Arduino动手做(249)---GC9A01电量WiFi指示器