告别万用表!用ESP32和PlatformIO搭建一个简易电压监测器(实时串口绘图)

张开发
2026/4/7 16:52:26 15 分钟阅读

分享文章

告别万用表!用ESP32和PlatformIO搭建一个简易电压监测器(实时串口绘图)
用ESP32打造实时电压监测系统从硬件搭建到数据可视化在物联网和智能硬件开发中电压监测是一个基础但至关重要的功能。无论是电池电量监控、太阳能系统管理还是简单的电子实验实时了解电压变化都能帮助我们更好地理解系统状态。传统上我们会使用万用表进行手动测量但这种方法无法捕捉快速变化的电压信号也不便于长期监测。本文将带你使用ESP32开发板和PlatformIO环境构建一个完整的实时电压监测系统并通过串口绘图器实现数据可视化。1. 硬件准备与电路设计1.1 选择合适的ESP32开发板市面上有多种ESP32开发板可供选择常见的有ESP32 DevKitC最基础的开发板价格实惠NodeMCU-32S带有USB转串口芯片方便调试TTGO T-Display集成显示屏适合需要本地显示的项目对于电压监测项目我们推荐使用带有稳压电路的开发板如ESP32 DevKitC它能提供更稳定的工作电压减少测量误差。1.2 分压电路设计ESP32的ADC输入范围是0-3.3V要测量更高电压我们需要设计分压电路。基本公式为Vout Vin * (R2 / (R1 R2))常用电阻组合输入电压范围R1值R2值分压比0-5V10kΩ10kΩ1:20-12V33kΩ10kΩ1:4.30-24V82kΩ10kΩ1:9.2提示选择电阻时应考虑功耗和精度。1%精度的金属膜电阻能提供更好的测量稳定性。1.3 电路连接注意事项确保分压电路连接正确避免反接损坏ESP32使用面包板或PCB时注意接触良好对于高频信号测量可考虑添加0.1μF电容滤波2. PlatformIO环境配置2.1 安装PlatformIO核心PlatformIO是一个专业的嵌入式开发平台相比Arduino IDE提供了更多高级功能。安装步骤如下安装VS Code如果尚未安装在VS Code扩展商店搜索并安装PlatformIO IDE首次打开时会自动安装核心组件2.2 创建新项目# 在PlatformIO Home界面选择New Project # 输入项目名称如esp32-voltage-monitor # 选择开发板型号如Espressif ESP32 Dev Module # 选择框架为Arduino # 点击Finish创建项目2.3 关键库依赖在platformio.ini中添加必要的库[env:esp32dev] platform espressif32 board esp32dev framework arduino lib_deps espressif/esp32-camera^2.0.0 adafruit/Adafruit GFX Library^1.11.33. 核心代码实现3.1 ADC配置与校准ESP32的ADC需要正确配置才能获得准确测量#include Arduino.h #include esp_adc_cal.h #define ADC_PIN 36 // GPIO36 (VP) #define DEFAULT_VREF 1100 // 默认参考电压(mV) #define NO_OF_SAMPLES 64 // 采样次数 #define ADC_WIDTH ADC_WIDTH_12Bit #define ADC_ATTEN ADC_ATTEN_11db // 最大量程3.3V esp_adc_cal_characteristics_t *adc_chars; void setup() { Serial.begin(115200); // ADC配置 adc1_config_width(ADC_WIDTH); adc1_config_channel_atten(ADC1_CHANNEL_0, ADC_ATTEN); // ADC校准 adc_chars (esp_adc_cal_characteristics_t *)calloc(1, sizeof(esp_adc_cal_characteristics_t)); esp_adc_cal_characterize(ADC_UNIT_1, ADC_ATTEN, ADC_WIDTH, DEFAULT_VREF, adc_chars); }3.2 实时测量与滤波算法为提高测量稳定性我们实现了一个滑动平均滤波器#define FILTER_WINDOW 16 uint32_t filterBuffer[FILTER_WINDOW]; uint8_t filterIndex 0; uint32_t filteredRead() { uint32_t sum 0; // 采集新样本 filterBuffer[filterIndex] adc1_get_raw(ADC1_CHANNEL_0); filterIndex (filterIndex 1) % FILTER_WINDOW; // 计算滑动平均 for(int i0; iFILTER_WINDOW; i) { sum filterBuffer[i]; } return sum / FILTER_WINDOW; }3.3 主循环与数据输出void loop() { uint32_t adc_reading filteredRead(); uint32_t voltage esp_adc_cal_raw_to_voltage(adc_reading, adc_chars); // 串口绘图器格式输出 Serial.print(Voltage:); Serial.println(voltage); // 控制采样率 delay(10); // 约100Hz采样率 }4. 数据可视化与高级应用4.1 PlatformIO串口绘图器使用PlatformIO内置的串口绘图器是一个强大的工具在VS Code中打开PlatformIO终端运行pio device monitor --plotter确保代码输出格式为标签:值的形式4.2 采样率优化技巧不同应用场景需要不同的采样率应用场景推荐采样率适用滤波方式电池电压监测1-10Hz滑动平均电源纹波分析1kHz低通滤波电机电流监测100-500Hz中值滤波4.3 多通道监测扩展要监测多个电压点只需扩展代码#define ADC_CHANNELS 3 const adc1_channel_t adcPins[ADC_CHANNELS] {ADC1_CHANNEL_0, ADC1_CHANNEL_3, ADC1_CHANNEL_6}; void loop() { for(int i0; iADC_CHANNELS; i) { uint32_t reading adc1_get_raw(adcPins[i]); uint32_t voltage esp_adc_cal_raw_to_voltage(reading, adc_chars); Serial.print(CH); Serial.print(i); Serial.print(:); Serial.println(voltage); } delay(10); }4.4 数据记录与分析对于长期监测可以将数据保存到SD卡或上传到云平台#include SD.h void logData(uint32_t voltage) { File dataFile SD.open(/datalog.txt, FILE_APPEND); if(dataFile) { dataFile.print(millis()); dataFile.print(,); dataFile.println(voltage); dataFile.close(); } }5. 实际应用案例5.1 锂电池充放电监测通过监测锂电池电压可以估算剩余电量float estimateLiPoCapacity(uint32_t voltage) { // 3.7V锂聚合物电池放电曲线 if(voltage 4200) return 100.0; if(voltage 4100) return 90.0 (voltage-4100)*0.1; if(voltage 4000) return 80.0 (voltage-4000)*0.1; if(voltage 3900) return 60.0 (voltage-3900)*0.2; if(voltage 3800) return 40.0 (voltage-3800)*0.2; if(voltage 3700) return 20.0 (voltage-3700)*0.2; if(voltage 3600) return 5.0 (voltage-3600)*0.15; return 0.0; }5.2 太阳能系统监控监测太阳能板输出电压和电池电压void monitorSolarSystem() { uint32_t panelVoltage readADC(PANEL_ADC_PIN); uint32_t batteryVoltage readADC(BATTERY_ADC_PIN); Serial.print(Panel:); Serial.print(panelVoltage); Serial.print(,Battery:); Serial.println(batteryVoltage); // 简单的充电控制逻辑 if(panelVoltage batteryVoltage 500) { enableCharging(); } else { disableCharging(); } }5.3 工业设备电源监测对于工业环境需要增加隔离和防护使用光耦或隔离放大器进行电气隔离添加TVS二极管防止浪涌采用4-20mA电流环传输信号// 4-20mA电流环读取 float read4_20mA(uint32_t raw) { // 假设250Ω采样电阻4mA1V20mA5V float voltage raw * 3.3 / 4095.0; // ESP32 ADC分辨率 float current (voltage / 250.0) * 1000; // 转换为mA // 4-20mA对应0-100%量程 if(current 4.0) return 0.0; if(current 20.0) return 100.0; return (current - 4.0) * 6.25; // (100/(20-4)) }在实际项目中我发现ESP32的ADC在长时间工作时会出现微小漂移定期进行零点校准能显著提高测量稳定性。一个简单的校准方法是在系统启动时自动测量已知电压如板载3.3V并计算补偿系数。

更多文章