news 2026/2/13 23:56:13

ESP32 + SSD1306 OLED 显示中文天气与网络时间(U8g2 + WiFi + NTP 完整实战)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ESP32 + SSD1306 OLED 显示中文天气与网络时间(U8g2 + WiFi + NTP 完整实战)

一、简介

本文基于ESP32 开发板 + SSD1306 128×64 OLED 显示屏,实现一个完整的物联网小项目,功能包括:

  • ESP32 通过I2C 驱动 OLED
  • 使用U8g2 库显示中文(无外置字库)
  • 通过HTTP 请求天气 API 获取实时天气
  • 使用NTP 网络时间协议自动校时
  • OLED 实时显示:日期、时间、城市、温度、天气情况
  • 自动刷新时间,天气数据动态更新

适合作为ESP32 + OLED + 网络通信的综合入门示例。


二、硬件连接说明

1. 接线方式(SSD1306 I2C)

OLED 引脚ESP32 引脚
VCC3V3
GNDGND
SDAGPIO 21
SCLGPIO 22

ESP32 默认 I2C 引脚:
SDA → GPIO21,SCL → GPIO22


三、软件环境与依赖库

1. 开发环境

  • Arduino IDE(或 PlatformIO)
  • ESP32 Board Support Package

2. 需要安装的库

U8g2 ArduinoJson NTPClient

WiFi.hHTTPClient.h为 ESP32 自带库。


四、天气 API 说明

本文使用的天气接口:

http://t.weather.itboy.net/api/weather/city/101010100

特点:

  • 免费
  • 无需 Key
  • 返回 JSON,支持中文
  • 城市通过城市代码区分

五、完整示例代码(已添加中文注释)

⚠️ 以下代码为最终整合版本

  • 中文显示
  • 天气获取
  • NTP 自动更新时间
  • OLED 实时刷新
#include<Wire.h>#include<U8g2lib.h>#include<WiFi.h>#include<HTTPClient.h>#include<ArduinoJson.h>#include<NTPClient.h>#include<WiFiUdp.h>/* ================= WiFi 配置 ================= */constchar*ssid="wifi帐号";constchar*password="Wifi密码";/* ================= 天气 API ================= */String apiUrl="http://t.weather.itboy.net/api/weather/city/101010100";/* ================= OLED 初始化 ================= 使用硬件 I2C,ESP32 默认: SDA -> GPIO21 SCL -> GPIO22 */U8G2_SSD1306_128X64_NONAME_F_HW_I2Cu8g2(U8G2_R0,U8X8_PIN_NONE,SCL,SDA);/* ================= NTP 时间配置 ================= 时区偏移:28800 秒(UTC+8,中国时间) 更新时间间隔:60000 ms */WiFiUDP udp;NTPClienttimeClient(udp,"pool.ntp.org",28800,60000);/* ================= 刷新控制 ================= */unsignedlonglastUpdateTime=0;unsignedlonginterval=1000;// 每秒刷新一次显示/* ================= 天气数据结构体 ================= */structWeatherData{String city;// 城市String temperature;// 温度String weatherType;// 天气类型String timedate;// 日期时间};voidsetup(){Serial.begin(115200);/* -------- 连接 WiFi -------- */WiFi.begin(ssid,password);Serial.print("Connecting to WiFi");while(WiFi.status()!=WL_CONNECTED){delay(1000);Serial.print(".");}Serial.println("\nWiFi Connected");Serial.print("IP Address: ");Serial.println(WiFi.localIP());/* -------- OLED 初始化 -------- */u8g2.begin();u8g2.enableUTF8Print();// 必须开启 UTF-8,否则中文乱码/* -------- 启动 NTP -------- */timeClient.begin();}voidloop(){unsignedlongcurrentMillis=millis();/* 每秒更新一次显示 */if(currentMillis-lastUpdateTime>=interval){lastUpdateTime=currentMillis;// 获取天气数据WeatherData weatherData=getWeatherData();if(weatherData.city!=""){// 更新时间timeClient.update();String currentTime=timeClient.getFormattedTime();// OLED 显示u8g2.clearBuffer();u8g2.setFont(u8g2_font_wqy12_t_gb2312);// 中文字体u8g2.setCursor(0,15);u8g2.print("日期: "+extractDate(weatherData.timedate)+" "+currentTime);u8g2.setCursor(0,30);u8g2.print("城市: "+weatherData.city);u8g2.setCursor(0,45);u8g2.print("温度: "+weatherData.temperature);u8g2.setCursor(0,60);u8g2.print("天气: "+weatherData.weatherType);u8g2.sendBuffer();}}}/* ================= 获取天气数据 ================= */WeatherDatagetWeatherData(){HTTPClient http;WeatherData weatherData;http.begin(apiUrl);inthttpCode=http.GET();if(httpCode==200){String payload=http.getString();Serial.println(payload);DynamicJsonDocumentdoc(1024);DeserializationError error=deserializeJson(doc,payload);if(!error){weatherData.timedate=doc["time"].as<String>();weatherData.city=doc["cityInfo"]["city"].as<String>();weatherData.temperature=doc["data"]["wendu"].as<String>();weatherData.weatherType=doc["data"]["forecast"][0]["type"].as<String>();}}http.end();returnweatherData;}/* ================= 日期格式处理 ================= 输入:YYYY-MM-DD HH:MM:SS 输出:MM-DD */StringextractDate(String fullDate){intspaceIndex=fullDate.indexOf(' ');String datePart=fullDate.substring(0,spaceIndex);returndatePart.substring(5);}

六、关键技术点总结

  1. U8g2 显示中文

    • 必须使用u8g2_font_wqy12_t_gb2312
    • 必须调用enableUTF8Print()
  2. ESP32 网络请求

    • 使用HTTPClient
    • JSON 解析推荐ArduinoJson
  3. 时间自动更新

    • NTPClient 负责时间
    • millis()控制刷新频率,避免阻塞
  4. 性能注意

    • 不建议每秒请求天气 API
    • 可后续改为:天气 10 分钟更新一次,时间每秒更新
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/10 23:04:41

Python + FFmpeg 批量提取视频音频(支持 Windows / macOS / Linux)

在日常开发或音频处理场景中&#xff0c;我们经常需要从大量视频文件中批量提取音频&#xff0c;例如&#xff1a; 从课程视频中提取音频将短视频转为 MP3做语音识别 / 音频分析前处理 本文介绍一种 使用 Python 调用 FFmpeg 的通用方案&#xff0c;同时支持 Windows、macOS …

作者头像 李华
网站建设 2026/2/7 5:27:36

【稀缺技术揭秘】:阿里P9不愿公开的虚拟线程调优日志技巧

第一章&#xff1a;云原生日志虚拟线程处理的演进与挑战随着云原生架构的广泛应用&#xff0c;传统的日志处理机制在高并发、低延迟场景下面临严峻挑战。虚拟线程&#xff08;Virtual Threads&#xff09;作为轻量级线程模型&#xff0c;显著提升了应用的并发能力&#xff0c;但…

作者头像 李华
网站建设 2026/2/4 4:06:34

彻底搞懂虚拟线程与平台线程的内存隔离差异:80%团队都用错了

第一章&#xff1a;虚拟线程内存隔离策略的本质解析虚拟线程作为 Project Loom 的核心特性&#xff0c;旨在提升高并发场景下的系统吞吐量。其轻量级特性使得单个 JVM 可以承载数百万级别的并发任务。然而&#xff0c;在如此高密度的线程环境下&#xff0c;内存隔离策略成为保障…

作者头像 李华
网站建设 2026/2/3 14:33:44

Qwen2.5-0.5B-Instruct性能优化:让对话响应速度提升3倍

Qwen2.5-0.5B-Instruct性能优化&#xff1a;让对话响应速度提升3倍 1. 引言 在边缘计算和资源受限设备上部署大语言模型&#xff08;LLM&#xff09;正成为AI落地的重要方向。Qwen/Qwen2.5-0.5B-Instruct 作为通义千问系列中体积最小、推理最快的小参数模型&#xff0c;凭借其…

作者头像 李华