尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

基于 Raspberry Pi Pico 2 C/C++ SDK 的 SGP30 空气质量监测器

基于 Raspberry Pi Pico 2 C/C++ SDK 的 SGP30 空气质量监测器
📅 发布时间:2026/7/6 6:41:01

采用设备

主控:Raspberry Pi Pico 2 (RP2350)

传感器:SGP30(I2C 地址 0x58),检测 eCO₂ 和 TVOC

显示屏:SSD1306 128×64 I2C OLED(地址 0x3C)

接线方式:

Pico 2 引脚连接设备说明
GPIO4SGP30 SDA软件 I2C
GPIO4SGP30 SCL软件 I2C
GPIO4SSD1306 SDA硬件 I2C0
GPIO4SSD1306 SCL硬件 I2C0
3V3(OUT)VCC (两设备)供电
GND

GND (两设备)

共地

两设备均使用 3.3V 供电,共地

程序

一、SGP30 驱动库结构(sgp30.h + sgp30.c)

这两个文件是我从 STM32 的 HAL 库 和 Arduino UNO 的 Adafruit_SGP30 库 移植到 Pico SDK 上的。核心改动是把硬件 I2C 换成了软件模拟,并保留了所有官方命令和 CRC 校验。

头文件 sgp30.h 重点

// 可自定义引脚(默认 GPIO4/5) #define SGP30_SDA_PIN 4 #define SGP30_SCL_PIN 5 // 所有 SGP30 命令码 #define SGP30_CMD_INIT_AIR_QUALITY 0x2003 #define SGP30_CMD_MEASURE_AIR_QUALITY 0x2008 #define SGP30_CMD_SET_HUMIDITY 0x2061 // ... // 数据结构 typedef struct { uint16_t co2; // eCO₂ (ppm) uint16_t tvoc; // TVOC (ppb) uint8_t crc_ok; // 两段 CRC 是否全部通过 } sgp30_data_t; // 公开 API void SGP30_Init(void); uint8_t SGP30_Write(uint8_t cmd_high, uint8_t cmd_low); uint8_t SGP30_Read(sgp30_data_t *data); uint8_t SGP30_SetHumidity(uint16_t abs_humidity); uint8_t SGP30_GetBaseline(uint16_t *eco2, uint16_t *tvoc); uint8_t SGP30_SetBaseline(uint16_t eco2, uint16_t tvoc); uint8_t SGP30_SoftReset(void); uint8_t SGP30_MeasureTest(uint16_t *result); uint8_t SGP30_GetFeatureSet(uint16_t *version); uint8_t SGP30_MeasureRaw(uint16_t *ethanol, uint16_t *h2); uint8_t SGP30_CRC8(const uint8_t *data, uint8_t len);

实现文件 sgp30.c 核心 – 软件 I2C

// 起始条件 static void i2c_start(void) { SDA_HIGH(); SCL_HIGH(); DELAY_US(); SDA_LOW(); DELAY_US(); SCL_LOW(); DELAY_US(); } // 写一个字节 + 等待 ACK static void i2c_write_byte(uint8_t data) { for (int i = 0; i < 8; i++) { (data & 0x80) ? SDA_HIGH() : SDA_LOW(); data <<= 1; DELAY_US(); SCL_HIGH(); DELAY_US(); SCL_LOW(); DELAY_US(); } } // 读一个字节,可选择回复 ACK 或 NACK static uint8_t i2c_read_byte(uint8_t send_ack) { ... }

CRC‑8 校验完全按照 SGP30 数据手册实现(多项式 0x31,初始值 0xFF):

uint8_t SGP30_CRC8(const uint8_t *data, uint8_t len) { uint8_t crc = 0xFF; for (uint8_t i = 0; i < len; i++) { crc ^= data[i]; for (uint8_t j = 0; j < 8; j++) crc = (crc & 0x80) ? (crc << 1) ^ 0x31 : (crc << 1); } return crc; }

二、主程序结构与功能(pico-sgp30.c)

程序结构

main() ├── stdio_init_all() // USB 串口调试输出 ├── ssd1306_init() // 硬件 I2C 初始化 OLED │ ├── i2c_init(i2c0, 400kHz) │ ├── 发送 OLED 初始化命令序列 │ └── 清屏 + 显示标题 "SGP30 Sensor" ├── SGP30_Init() // 软件 I2C 初始化 SGP30 │ └── 发送 init_air_quality 命令 └── while(1): ├── 发送 measure_air_quality 命令 ├── 读取 6 字节 + CRC 校验 ├── 【预热阶段】(前 15 秒,CO₂=400, TVOC=0) │ ├── OLED 显示倒计时 │ └── 串口打印剩余秒数 └── 【正常运行】 ├── OLED 显示 eCO₂ (ppm) + TVOC (ppb) ├── 若 CRC 错误则额外显示 "CRC FAIL!" ├── 串口打印数据 └── sleep 2 秒

OLED 显示布局(128×64,8 个 page)

Page内容
0

SGP30 Sensor (固定标题)

2

eCO2: 400 ppm (5位右对齐)

4

TVOC: 0 ppb (挥发性有机物浓度)

6

CRC FAIL! (仅出错时显示)

关键代码片段 – 预热检测

SGP30 传感器上电后前 15 秒会强制输出 CO₂=400 ppm、TVOC=0 ppb。主程序利用这一特性:

if (!warmed_up && (now - start_ms) < 15000 && data.co2 == 400 && data.tvoc == 0) { uint32_t elapsed = (now - start_ms) / 1000; snprintf(buf, sizeof(buf), "Warm-up %lus... ", 15 - elapsed); ssd1306_draw_string(2, 0, buf); printf("Warming up... %lu s remaining\n", 15 - elapsed); sleep_ms(1000); continue; }

编译与烧录

1. 前置工具

Raspberry Pi Pico C/C++ SDK​https://github.com/raspberrypi/pico-sdk

ARM GCC 交叉编译器 (arm-none-eabi-gcc)

CMake (≥ 3.13) + Ninja

2. 构建命令

git clone https://github.com/jasonobama/pico-sgp30.git cd pico-sgp30 export PICO_SDK_PATH=/path/to/pico-sdk # 设置 SDK 路径 cmake -B build -G Ninja . cmake --build build

3. 烧录到 Pico 2

  • 按住 BOOTSEL 键,插入 USB

  • 将 pico-sgp30.uf2 拖入弹出的 RPI-RP2 盘符

  • 程序自动运行,OLED 点亮

源码

Raspberry Pi Pico C/C++ SDK​https://github.com/Jasonobama/pico-sgp30.git

相关新闻

  • 2026年正规的永磁专用变频器/上海永磁变频器/变频器/上海永磁变频器控制器厂家选择推荐 - 行业平台推荐
  • 2026年口碑好的吊钩式抛丸机/悬链式吊钩式抛丸机优质厂家推荐榜 - 品牌宣传支持者
  • 从概念到实战:dB、dBm、dBc在无线通信中的精准应用

最新新闻

  • 告别枯燥刷本:FGO自动化脚本终极指南
  • BetterNCM安装器:一键式网易云插件管理终极指南
  • Wand-Enhancer:开源增强工具让游戏修改体验全面升级
  • 如何免费解锁九大网盘高速下载权限:LinkSwift完整使用指南
  • 基于TM4C129ENCZAD与13DOF的高精度定位系统设计
  • 基于multisim的交通信号灯25-25-5控制器设计

日新闻

  • AI智能体安全防护框架AgentGuard:从原理到实战部署指南
  • KMX63与PIC18F26K40硬件组合及低功耗设计实践
  • 基于YOLO13改进的门体检测模型:C3k2模块与PoolingFormer技术解析

周新闻

  • 基于YOLOv12的番茄成熟度智能检测系统开发
  • 终极RimWorld模组管理指南:用RimSort告别模组冲突烦恼
  • AI Agent框架开发:从理论到实践的完整指南

月新闻

  • 2026年6月公司网站搭建最新热门渠道测评:四大低成本/零代码平台对比+避坑
  • 【Linux】Linux arm 编译QT程序,出现expected “}“报错
  • 【MATLAB例程】四基站二维AOA定位与距离辅助增强对比仿真。基于角度观测和测距修正的固定目标平面定位精度分析

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号