当前位置: 首页 > news >正文

ESP-ADF battery_service组件之voltage_monitor子模块详解

目录

  • ESP-ADF battery_service组件之voltage_monitor子模块详解
    • 模块概述
      • 功能特点
      • 工作原理
    • 公共接口
      • 数据类型和结构
        • 事件类型枚举
        • 电压监控参数结构
        • 句柄类型定义
        • 回调函数定义
      • 函数声明
        • 创建电压监控实例
        • 销毁电压监控实例
        • 设置事件回调函数
        • 启动定期电压报告
        • 停止定期电压报告
        • 设置电压报告频率
    • 核心流程分析
      • 电压监控创建流程
      • 电压报告流程
      • 报告控制流程
    • 接口汇总
      • 创建与销毁
      • 事件处理
      • 电压报告控制
      • 事件类型
    • 使用示例

ESP-ADF battery_service组件之voltage_monitor子模块详解

版本信息: v2.7-65-gcf908721

模块概述

电压监控(vol_monitor)是 battery_service 组件的核心子模块,负责实时监控电池电压,并在满足特定条件时向上层应用报告电池状态。该模块提供了灵活的电压监控机制,支持定期报告电压数值、电池电量过低/满电量事件通知等功能,为电池管理提供基础支持。

功能特点

  • 定期采样:根据配置的频率定期读取电池电压
  • 定期报告:支持按指定频率向上层应用报告电池电压值
  • 阈值触发:支持电池电量过低/满电量事件触发通知
  • 可配置性:支持灵活配置采样频率、报告频率和阈值等参数
  • 事件回调:提供事件回调机制,方便上层应用处理电池状态变化

工作原理

电压监控模块通过定时器定期调用用户提供的电压读取函数获取当前电池电压,然后根据配置的报告频率和电压阈值,触发相应的事件回调。模块内部维护电压监控状态,包括读取计数、报告状态、满电量/低电量报告状态等,以确保事件触发的准确性和一致性。

公共接口

数据类型和结构

事件类型枚举
/*** @brief 电池电压监控事件类型*/
typedef enum {VOL_MONITOR_EVENT_FREQ_REPORT,  /*!< 定期电压报告事件 */VOL_MONITOR_EVENT_BAT_FULL,     /*!< 电池满电量事件 */VOL_MONITOR_EVENT_BAT_LOW,      /*!< 电池低电量事件 */
} vol_monitor_event_t;
电压监控参数结构
/*** @brief 电池电压监控配置参数*/
typedef struct {bool (*init)(void *);   /*!< 电压读取初始化函数 */bool (*deinit)(void *); /*!< 电压读取反初始化函数 */int (*vol_get)(void *); /*!< 电压读取接口函数 */void *user_data;        /*!< 回调函数参数 */int read_freq;          /*!< 电压读取频率,单位:秒 */int report_freq;        /*!< 电压报告频率,电压将以(`read_freq` * `report_freq`)间隔进行报告 */int vol_full_threshold; /*!< 满电量电压阈值,单位:mV */int vol_low_threshold;  /*!< 低电量电压阈值,单位:mV */
} vol_monitor_param_t;
句柄类型定义
/*** @brief 电压监控句柄*/
typedef void *vol_monitor_handle_t;
回调函数定义
/*** @brief 回调函数定义*/
typedef void (*vol_monitor_event_cb)(int msg_id, void *data, void *user_ctx);

函数声明

创建电压监控实例
/*** @brief     创建电压监控实例** @param[in]  config      指向 'vol_monitor_param_t' 结构的指针** @return*    - NULL:  失败*    - 其他值: 成功*/
vol_monitor_handle_t vol_monitor_create(vol_monitor_param_t *config);
销毁电压监控实例
/*** @brief     销毁电压监控实例** @param[in]  handle      指向 'vol_monitor_handle_t' 结构的指针** @return*    - ESP_OK:  成功*    - 其他值: 失败*/
esp_err_t vol_monitor_destroy(vol_monitor_handle_t handle);
设置事件回调函数
/*** @brief     设置事件回调函数** @param[in]  handle      指向 'vol_monitor_handle_t' 结构的指针* @param[in]  event_cb    用于处理电压监控事件的回调函数* @param[in]  user_ctx    用户数据** @return*    - ESP_OK:  成功*    - 其他值: 失败*/
esp_err_t vol_monitor_set_event_cb(vol_monitor_handle_t handle, vol_monitor_event_cb event_cb, void *user_ctx);
启动定期电压报告
/*** @brief     以配置的频率启动电压报告** @param[in]  handle      指向 'vol_monitor_handle_t' 结构的指针** @return*    - ESP_OK:  成功*    - 其他值: 失败*/
esp_err_t vol_monitor_start_freq_report(vol_monitor_handle_t handle);
停止定期电压报告
/*** @brief     停止定期电压报告** @param[in]  handle      指向 'vol_monitor_handle_t' 结构的指针** @return*    - ESP_OK:  成功*    - 其他值: 失败*/
esp_err_t vol_monitor_stop_freq_report(vol_monitor_handle_t handle);
设置电压报告频率
/*** @brief     设置电压报告频率** @param[in]  handle      指向 'vol_monitor_handle_t' 结构的指针* @param[in]  freq        电压报告频率** @return*    - ESP_OK:  成功*    - 其他值: 失败*/
esp_err_t vol_monitor_set_report_freq(vol_monitor_handle_t handle, int freq);

核心流程分析

电压监控创建流程

应用程序 vol_monitor vol_monitor_create(config) 分配内存资源 vol_monitor_param_check(config) 返回 NULL 初始化监控数据结构 config->>init(user_data) 创建互斥锁 创建定时器 启动定时器 (周期: read_freq) 返回句柄 alt [参数检查失败] [参数检查成功] 应用程序 vol_monitor

电压报告流程

定时器 vol_monitor 应用程序 vol_check_timer_hdlr(vol_monitor) 获取互斥锁 调用 vol_get() 获取电压 更新读取计数 (read_cnt++) 重置计数 (read_cnt = 0) 触发 VOL_MONITOR_EVENT_FREQ_REPORT 事件 alt [满足报告条件 (read_cnt % report_start == 0)] alt [定期报告已启动] 触发 VOL_MONITOR_EVENT_BAT_LOW 事件 设置低电量已报告标志 清除低电量已报告标志 alt [电压 <= 低电量阈值 且 未报告低电量] [电压 > 低电量阈值] alt [低电量检测已启用 (vol_low_threshold != 0)] 触发 VOL_MONITOR_EVENT_BAT_FULL 事件 设置满电量已报告标志 清除满电量已报告标志 alt [电压 >= 满电量阈值 且 未报告满电量] [电压 < 满电量阈值] alt [满电量检测已启用 (vol_full_threshold != 0)] 释放互斥锁 定时器 vol_monitor 应用程序

报告控制流程

应用程序 vol_monitor vol_monitor_start_freq_report(handle) 获取互斥锁 设置 report_start = report_freq 返回 ESP_OK 返回 ESP_FAIL alt [report_freq > 0] [report_freq <= 0] 释放互斥锁 vol_monitor_stop_freq_report(handle) 获取互斥锁 设置 report_start = 0 释放互斥锁 返回 ESP_OK vol_monitor_set_report_freq(handle, freq) 获取互斥锁 更新 report_freq = freq 重置计数器 (read_cnt = 0) 更新 report_start = report_freq 重置计数器 (read_cnt = 0) 停止报告 (report_start = 0) alt [report_freq > 0 且 report_start > 0] [report_freq == 0] 释放互斥锁 返回 ESP_OK alt [启动报告] [停止报告] [设置报告频率] 应用程序 vol_monitor

接口汇总

创建与销毁

函数名功能描述
vol_monitor_create创建电压监控实例
vol_monitor_destroy销毁电压监控实例

事件处理

函数名功能描述
vol_monitor_set_event_cb设置事件回调函数

电压报告控制

函数名功能描述
vol_monitor_start_freq_report启动定期电压报告
vol_monitor_stop_freq_report停止定期电压报告
vol_monitor_set_report_freq设置电压报告频率

事件类型

事件说明
VOL_MONITOR_EVENT_FREQ_REPORT定期电压报告事件
VOL_MONITOR_EVENT_BAT_FULL电池满电量事件
VOL_MONITOR_EVENT_BAT_LOW电池低电量事件

使用示例

下面是一个使用电压监控模块的简单示例:

// 电压读取相关函数实现
static bool adc_init(void *user_data) {// 初始化 ADCreturn true;
}static bool adc_deinit(void *user_data) {// 反初始化 ADCreturn true;
}static int adc_read(void *user_data) {// 读取 ADC 并转换为电压值(mV)return 3800; // 示例值
}// 电压事件回调函数
static void vol_event_cb(int msg_id, void *data, void *user_ctx) {int voltage = (int)data;switch (msg_id) {case VOL_MONITOR_EVENT_FREQ_REPORT:printf("当前电压: %d mV\n", voltage);break;case VOL_MONITOR_EVENT_BAT_FULL:printf("电池已充满: %d mV\n", voltage);break;case VOL_MONITOR_EVENT_BAT_LOW:printf("电池电量低: %d mV\n", voltage);break;default:break;}
}// 主函数
void app_main() {// 配置电压监控vol_monitor_param_t vol_config = {.init = adc_init,.deinit = adc_deinit,.vol_get = adc_read,.user_data = NULL,.read_freq = 5,           // 每5秒读取一次.report_freq = 12,        // 每12次读取报告一次(即60秒).vol_full_threshold = 4100, // 满电量阈值: 4100mV.vol_low_threshold = 3300,  // 低电量阈值: 3300mV};// 创建电压监控vol_monitor_handle_t monitor = vol_monitor_create(&vol_config);if (monitor == NULL) {printf("创建电压监控失败\n");return;}// 设置回调函数vol_monitor_set_event_cb(monitor, vol_event_cb, NULL);// 启动电压报告vol_monitor_start_freq_report(monitor);// ... 应用主循环 ...// 在应用退出时销毁电压监控// vol_monitor_destroy(monitor);
}
http://www.xdnf.cn/news/292483.html

相关文章:

  • 分析rand()和srand()函数的功能
  • 【机器学习-线性回归-5】多元线性回归:概念、原理与实现详解
  • Android控件VideoView用法
  • 工业主义与民主的兴衰:历史逻辑与未来危机
  • 三种石墨烯(Graphene)拉伸模拟方法对比
  • 偷钱包行为检测数据集VOC+YOLO格式922张1类别有增强
  • 密钥管理系统:数据库加密的隐形守护者与安当KSP+TDE创新实践
  • ecat总线6000段定义
  • 关闭ollama开机自启动
  • C语言数据在内存中的存储详解
  • Manus AI: 冲破次元壁,让手写文字跨越语言鸿沟
  • ByteArrayInputStream 类详解
  • 【Hive入门】Hive安全管理与权限控制:用户认证与权限管理深度解析
  • 基于开源AI智能名片链动2+1模式S2B2C商城小程序的流量变现路径创新研究
  • Webug4.0靶场通关笔记15- 第19关文件上传(畸形文件)
  • 《进制转换的终极指南:原理、方法与编程应用》
  • ModuleNotFoundError: No module named ‘triton‘
  • 前端学习基础—VScode环境配置及html基础知识
  • LintCode第766题,LintCode第1141题,LintCode第478题
  • 图片批量处理JPGC 深度测评:智能压缩 + 多线程加速
  • 了解巴纳姆效应
  • 11. 多线程(8) --- 案例:阻塞式队列
  • “Copy-On-Write” (COW)
  • 常用对称加密算法的Python实现及详解
  • 【C语言练习】022. 包含标准库和自定义头文件
  • Dify 快速构建和部署基于LLM的应用程序
  • XZ03_Overleaf使用教程
  • ArchLinux卡死在GRUB命令行模式修复
  • PMP-第四章 项目整合管理(二)
  • springboot应用大批量导出excel产生oom处理措施实践(适用于poieasyexcel)