一个让ESP32变身智能天气站的炫酷组件
支持高德、心知、和风三种天气API
提供天气信息获取和展示功能
✨ 一个让ESP32变身智能天气站的炫酷组件 ✨
功能特性 | 高德天气 | 心知天气 | 和风天气 |
---|---|---|---|
实时天气 | ✅ | ✅ | ✅ |
温度 | ✅ | ✅ | ✅ |
湿度 | ✅ | ❌ | ✅ |
风向风速 | ✅ | ❌ | ✅ |
风力 | ✅ | ❌ | ✅ |
气压 | ❌ | ❌ | ✅ |
能见度 | ❌ | ❌ | ✅ |
体感温度 | ❌ | ❌ | ✅ |
降水量 | ❌ | ❌ | ✅ |
云量 | ❌ | ❌ | ✅ |
露点温度 | ❌ | ❌ | ✅ |
免费调用次数 | 30 万/日 | 无次数限制 | 1000/日 |
是否需要付费 | 可选 | 可选 | 可选 |
以上数据均为免费服务数据,这里推荐和风天气,虽然免费次数较少,但免费版的服务和付费版是相同的。
要将组件添加到项目中请在IDF终端执行下方命令:
Bash
idf.py add-dependency "ningzixi/weather^1.1.0"
或者直接克隆本仓库到项目components
目录下:
Bash
git clone https://github.com/NingZiXi/weather
高德API: https://lbs.amap.com/api/webservice/guide/create-project/get-key
心知天气API: https://www.seniverse.com/dashboard
和风天气API:和风天气除了获取key外,还需要配置host,具体如下:
C
#include "weather.h"
void app_main() {
//省略联网部分
weather_config_t config = {
.api_key = WEATHER_HEFENG_KEY,
.api_host = WEATHER_HEFENG_HOSE, // 和风天气需要配置host
.city = NULL, // city为NULL自动根据IP地址获取位置,也可以指定城市
// .city = "北京",
.type = WEATHER_HEFENG //可更改为api配置WEATHER_AMAP或WEATHER_XINZHI
};
weather_info_t *info = weather_get(&config);
if (info) {
weather_print_info(info); // 打印天气信息
weather_info_free(info);
}
}
更多API接口请查看weather.h
Plaintext
🌈 WEATHER REPORT ☁️
_ _ _ _____ _____ _____ _____ _____ _____
| | | | __| _ |_ _| | | __| __ |
| | | | __| | | | | | __| -|
|_____|_____|__|__| |_| |__|__|_____|__|__|
📍 位置: 常州
┌───────────────────────────────────────┐
│ ☁️ 天气: 阴 │
│ 🌡️ 温度: 30.0℃ │
│ 🤒 体感: 25.0℃ │
│ 💧 湿度: 21.0% │
│ 🍃 风向: 西南风 │
│ 💨 风力: 5 │
│ 🌬️ 风速: 29.0km/h │
│ ⏲️ 气压: 1004.0hPa │
│ 👁️ 能见度: 26.0km │
│ ☁️ 云量: 99.0% │
│ 💦 露点: 10.0℃ │
└───────────────────────────────────────┘
🕒 更新时间: 2025-04-16T14:18+08:00
本项目采用 MIT 许可证,详情请参阅 LICENSE 文件,本项目仍在完善中,可能会有一些功能尚未完善或存在 Bug。如果您在使用过程中遇到任何问题,请随时联系作者或提交 Issue 来帮助改进本项目!
感谢您使用 ESP32 Weather Component!
如果觉得项目不错,请给个 ⭐ Star 支持一下!
idf.py add-dependency "ningzixi/weather^1.1.0"