2106 lines
109 KiB
Markdown
2106 lines
109 KiB
Markdown
|
|
激光灭害虫设备 BLE 通信方案
|
|||
|
|
文档版本信息
|
|||
|
|
**版本**: v2.2
|
|||
|
|
**创建日期**: 2025-12-09
|
|||
|
|
**最后更新**: 2026-02-26
|
|||
|
|
**状态**: 当前版本
|
|||
|
|
更改记录
|
|||
|
|
|
|||
|
|
|
|||
|
|
1. 方案概述
|
|||
|
|
1.1 产品背景
|
|||
|
|
激光灭害虫设备是一款智能家居安全设备,通过激光技术精准消灭蚊虫等害虫。由于激光设备存在安全风险,需要严格的用户注册和认证机制。本方案从产品经理和用户角度出发,设计完整的 APP 与设备交互方案,确保安全性和易用性。
|
|||
|
|
1.2 通信架构
|
|||
|
|
|
|||
|
|
**通信链路**:
|
|||
|
|
**APP ****↔**** ****BLE模块**: 通过 BLE 透传模式通信
|
|||
|
|
**BLE模块**** ****↔**** MCU**: 通过 UART9 串口通信
|
|||
|
|
**MCU**: STM32H7 主控制器,处理所有业务逻辑
|
|||
|
|
1.3 通信特点
|
|||
|
|
**透传模式**: BLE 模块工作在透传模式,数据透明传输
|
|||
|
|
**双向通信**: 支持 APP 到设备和设备到 APP 的双向数据传输
|
|||
|
|
**状态监控**: BLE 模块提供 LINK 和 WORK 状态引脚,实时监控连接状态
|
|||
|
|
**安全认证**: 支持用户注册绑定、密码登录、指纹登录等多种认证方式
|
|||
|
|
**OTA ****支持**: 支持BLE对MCU的固件更新
|
|||
|
|
**主动通知**: 设备可主动上报状态变化、错误信息、统计数据等
|
|||
|
|
|
|||
|
|
|
|||
|
|
2. BLE 指令分类表
|
|||
|
|
本表按功能分类展示了所有 BLE 通信指令,便于快速查找和理解指令体系结构。
|
|||
|
|
2.1 设备注册与认证类 (0x01-0x0F)
|
|||
|
|
|
|||
|
|
2.2 系统控制类 (0x10-0x1F)
|
|||
|
|
2.3 外设控制类 (0x20-0x3F)
|
|||
|
|
2.4 害虫消灭控制类 (0x40-0x4F)
|
|||
|
|
2.5 安全设置类 (0x50-0x5F)
|
|||
|
|
2.6 高级管理类 (0x60-0x6F)
|
|||
|
|
2.7 连接管理类 (0x70-0x7F)
|
|||
|
|
2.8 OTA 升级类 (0x80-0x9F)
|
|||
|
|
2.9 状态查询类 (0xA0-0xBF)
|
|||
|
|
|
|||
|
|
|
|||
|
|
3. 设备功能归纳
|
|||
|
|
基于设备实际功能模块,从用户角度归纳 APP 可控制的功能。内部控制细节(如振镜电机参数)对用户隐藏,仅暴露用户友好的接口。
|
|||
|
|
3.1 数据库模块
|
|||
|
|
3.1.1 设备信息
|
|||
|
|
**设备序列号**: 唯一标识设备,用于设备识别和绑定(主要标识符)
|
|||
|
|
**固件信息**: 固件版本号,用于 OTA 升级判断
|
|||
|
|
**设备**** MAC ****地址**: BLE 模块 MAC 地址(通过 BLE 命令从设备端获取,Android/iOS 无法直接获取)
|
|||
|
|
**硬件版本**: 硬件版本信息
|
|||
|
|
**设备名称**: 用户自定义的设备名称(可选)
|
|||
|
|
**说明**:
|
|||
|
|
Android 6.0+ 和 iOS 7+ 出于隐私保护,无法直接获取 BLE 设备的真实 MAC 地址
|
|||
|
|
设备识别主要使用设备序列号
|
|||
|
|
如需 MAC 地址,需通过 BLE 命令(如查询设备信息命令)从设备端获取
|
|||
|
|
3.1.2 人员管理
|
|||
|
|
**用户名**: 用户注册时设置的用户名(最大长度 16 字节)
|
|||
|
|
**用户密码**: 用户设置的登录密码(加密存储,最大长度 16 字节)
|
|||
|
|
**指纹**** ID**: 用户指纹模板 ID(设备端存储,关联用户名)
|
|||
|
|
**绑定关系**: 设备与用户的绑定关系(一个设备可绑定多个用户,最多支持 10 个用户)
|
|||
|
|
**用户权限**: 管理员/普通用户权限区分(可选)
|
|||
|
|
3.2 系统控制
|
|||
|
|
3.2.1 语言设置
|
|||
|
|
**支持语言****: ****英文、中文**
|
|||
|
|
**切换方式****: APP ****设置后同步到设备,影响设备**** LCD ****显示和提示音**
|
|||
|
|
3.2.2 时间管理
|
|||
|
|
**时间设置****: ****设置设备系统时间(年、月、日、时、分、秒)**
|
|||
|
|
**日期显示****: ****设备**** LCD ****显示当前日期**
|
|||
|
|
**时间同步****: APP ****与设备时间同步**
|
|||
|
|
3.2.3 定时任务
|
|||
|
|
**功能说明****: ****在指定时间范围内自动运行指定的设备模式,支持按周重复执行。定时关机功能通过设置运行模式为"待机"实现。**
|
|||
|
|
**任务数量****: ****最多可设置5组定时任务**
|
|||
|
|
**任务参数****:**
|
|||
|
|
**任务ID**: 0-4(对应数组索引),标识不同的定时任务
|
|||
|
|
**开关**控制: 启用/禁用该定时任务(0x00=禁用, 0x01=启用)
|
|||
|
|
**开始**时间: 开始小时(1字节,0-23) + 开始分钟(1字节,0-59)
|
|||
|
|
**结束时间**: 结束小时(1字节,0-23) + 结束分钟(1字节,0-59)
|
|||
|
|
**运行模式**: 待机(0x00)、扫描(0x01)、消杀(0x02)
|
|||
|
|
**待机模式**: 设备进入待机状态,可用于定时关机功能
|
|||
|
|
**扫描模式**: 设备进入扫描检测状态
|
|||
|
|
**消杀模式**: 设备进入消杀工作状态
|
|||
|
|
**重复设置**: 1字节,按位表示星期几重复执行
|
|||
|
|
bit0: 周一 (0x01)
|
|||
|
|
bit1: 周二 (0x02)
|
|||
|
|
bit2: 周三 (0x04)
|
|||
|
|
bit3: 周四 (0x08)
|
|||
|
|
bit4: 周五 (0x10)
|
|||
|
|
bit5: 周六 (0x20)
|
|||
|
|
bit6: 周日 (0x40)
|
|||
|
|
示例:0x3F (0b00111111) 表示周一到周六,0x41 (0b01000001) 表示周一和周日
|
|||
|
|
**自动执行**:
|
|||
|
|
在设定的星期几,到达开始时间后,设备自动切换到指定模式
|
|||
|
|
到达结束时间后,设备自动停止或切换到待机模式
|
|||
|
|
对于待机模式(定时关机),设备进入待机状态并保持到结束时间
|
|||
|
|
**使用场景**:
|
|||
|
|
**定时关机**: 设置运行模式为"待机",在指定时间范围自动进入待机状态(如:每天23:00-06:00自动关机)
|
|||
|
|
**自动化灭虫任务**: 设置运行模式为"消杀",在指定时间范围自动开始灭虫工作(如:工作日20:00-22:00自动消杀)
|
|||
|
|
**定时扫描检测**: 设置运行模式为"扫描",在指定时间范围自动开始扫描检测(如:每天08:00-18:00自动扫描)
|
|||
|
|
**节能管理**: 通过定时任务实现自动化控制,避免长时间工作
|
|||
|
|
3.3 外设控制
|
|||
|
|
3.3.1 LCD 显示屏
|
|||
|
|
**休眠设置**:
|
|||
|
|
**休眠开关**: 开启/关闭 LCD 休眠功能
|
|||
|
|
**休眠时间**: 设置 LCD 无操作后进入休眠的时间(1分钟、5分钟、10分钟、30分钟)
|
|||
|
|
**亮度调节**:
|
|||
|
|
**自适应开关**: 开启/关闭自适应亮度功能(开启时根据环境光自动调节亮度)
|
|||
|
|
**亮度值**: 手动设置亮度等级(10-100%,仅在自适应关闭时有效)
|
|||
|
|
3.3.2 RGB 指示灯
|
|||
|
|
开关控制: 开启/关闭 RGB 指示灯
|
|||
|
|
颜色设置: 设置指示灯颜色(RGB 值)
|
|||
|
|
效果模式: 设置指示灯效果(闪烁、常亮、警示)
|
|||
|
|
3.3.3 WIFI 功能
|
|||
|
|
**开关控制**: 开启/关闭 WIFI 功能(如设备支持)
|
|||
|
|
开关值:0x00=关闭,0x01=开启
|
|||
|
|
**WIFI ****配置**: WIFI SSID 和密码设置
|
|||
|
|
SSID:最多32字节的ASCII字符串,以\0结尾
|
|||
|
|
密码:最多32字节的ASCII字符串,以\0结尾
|
|||
|
|
**数据格式**:
|
|||
|
|
读操作:固定返回65字节(开关1字节 + SSID 32字节 + 密码32字节)
|
|||
|
|
写操作:可变长度,至少1字节(开关),可选包含SSID和密码
|
|||
|
|
3.3.4 BLE 功能
|
|||
|
|
**蓝牙名称**: 设置 BLE 广播名称
|
|||
|
|
**说明**: BLE 功能始终开启,不支持通过 APP 关闭(关闭后无法通信)
|
|||
|
|
3.3.5 多媒体功能
|
|||
|
|
**视频录制**:
|
|||
|
|
**开关控**制: 开启/关闭视频录制功能(0x00=关闭,0x01=开启)
|
|||
|
|
录制时长: 设置单次录制时长(秒),支持3秒、5秒、10秒
|
|||
|
|
**音效设置**:
|
|||
|
|
**开关控制**: 开启/关闭音效(0x00=关闭,0x01=开启)
|
|||
|
|
音效类型: 选择不同的提示音效(5种类型)
|
|||
|
|
0x00 = Hello音效
|
|||
|
|
0x01 = Goodbye音效
|
|||
|
|
0x02 = Test音效
|
|||
|
|
0x03 = BIU音效
|
|||
|
|
0x04 = Main音效
|
|||
|
|
音量**控制**: 设置音量大小(0-15,对应芯片E0-EF共16级)
|
|||
|
|
**数据格式**:
|
|||
|
|
读操作:固定返回5字节(视频录制开关1字节 + 录制时长1字节 + 音效开关1字节 + 音效类型1字节 + 音量1字节)
|
|||
|
|
写操作:可变长度,至少1字节(视频录制开关),可选包含其他字段
|
|||
|
|
3.3.6 补光灯
|
|||
|
|
**功能说明**: 补光灯是外部设备,用于夜间补光,提高检测效果
|
|||
|
|
**开关控制**: 开启/关闭补光灯
|
|||
|
|
**补光类型**:
|
|||
|
|
**红外光**: 用于夜间补光,不影响人眼
|
|||
|
|
白光: 普通白光补光
|
|||
|
|
**光照强度设置**: **设置**补光灯光照强度(低、中、高)
|
|||
|
|
**连接状态监控**:
|
|||
|
|
设备实时检测补光灯连接状态
|
|||
|
|
补光灯连接/断开时主动上报状态
|
|||
|
|
APP 可查询补光灯连接状态
|
|||
|
|
3.3.7 可见光激光器
|
|||
|
|
**功能说明**: 可见光激光器用于提供可见激光指示,辅助瞄准和定位
|
|||
|
|
**开关控制**: 开启/关闭可见光激光器
|
|||
|
|
**使用场景**:
|
|||
|
|
激光瞄准辅助
|
|||
|
|
设备调试和校准
|
|||
|
|
用户可视化激光位置
|
|||
|
|
3.4 害虫消灭控制
|
|||
|
|
3.4.1 角度控制
|
|||
|
|
**扫描角度**: 设置激光扫描角度范围
|
|||
|
|
**数据**格式: 2字节,小端序(低字节在前,高字节在后)
|
|||
|
|
单位: 0.1度
|
|||
|
|
范围: 1-900(对应0.1度-90度)
|
|||
|
|
读操作: 返回当前角度范围设置(2字节)
|
|||
|
|
写操作: 设置角度范围(2字节),设备验证范围后更新数据库
|
|||
|
|
**数据库字段**: db_cfg.pest_ctrl.angle_range(uint16_t,单位:0.1度)
|
|||
|
|
3.4.2 距离控制
|
|||
|
|
**检测距离**: 设置害虫检测距离范围(米)
|
|||
|
|
**瞄准距离**: 设置激光瞄准距离(米)
|
|||
|
|
3.5 安全模块
|
|||
|
|
3.5.1 毫米波雷达
|
|||
|
|
**开关控制**: 开启/关闭毫米波雷达检测(0x00=关闭,0x01=开启)
|
|||
|
|
**灵敏度设置**: 设置人体检测灵敏度
|
|||
|
|
0x00 = 低灵敏度
|
|||
|
|
0x01 = 中灵敏度
|
|||
|
|
0x02 = 高灵敏度
|
|||
|
|
**安全距离**: 设置安全保护距离
|
|||
|
|
**数据格式**: 2字节,小端序(低字节在前,高字节在后)
|
|||
|
|
单位: 0.1米
|
|||
|
|
范围: 1-100(对应0.1米-10米)
|
|||
|
|
**数据格式**:
|
|||
|
|
读操作:返回4字节固定长度数据(开关1字节 + 灵敏度1字节 + 安全距离2字节)
|
|||
|
|
写操作:接收4字节数据(开关1字节 + 灵敏度1字节 + 安全距离2字节)
|
|||
|
|
**数据库字段**: db_cfg.safety.mmw_radar.enable、sensitivity、safe_distance
|
|||
|
|
3.5.2 视觉检测
|
|||
|
|
**开关控制**: 开启/关闭视觉检测功能(0x00=关闭,0x01=开启)
|
|||
|
|
**灵敏度设置**: 设置视觉检测灵敏度
|
|||
|
|
0x00 = 低灵敏度
|
|||
|
|
0x01 = 中灵敏度
|
|||
|
|
0x02 = 高灵敏度
|
|||
|
|
**数据格式**:
|
|||
|
|
读操作:返回2字节固定长度数据(开关1字节 + 灵敏度1字节)
|
|||
|
|
写操作:接收2字节数据(开关1字节 + 灵敏度1字节)
|
|||
|
|
**数据库字段**: db_cfg.safety.vision.enable、sensitivity
|
|||
|
|
**说明**: 摄像头可视范围固定,无需软件设置检测范围
|
|||
|
|
3.5.3 加速度传感器(振动检测)
|
|||
|
|
**功能说明**: 3轴加速度传感器用于检测设备振动状态,确保激光灭虫设备稳定放置
|
|||
|
|
**开关控制**: 开启/关闭加速度传感器检测(0x00=关闭,0x01=开启)
|
|||
|
|
**灵敏度设置**: 设置振动检测灵敏度
|
|||
|
|
0x00 = 低灵敏度
|
|||
|
|
0x01 = 中灵敏度
|
|||
|
|
0x02 = 高灵敏度
|
|||
|
|
**振动阈值**: 设置振动检测阈值
|
|||
|
|
**范围**: 1-255
|
|||
|
|
说明: 超过阈值时触发告警或停止工作
|
|||
|
|
**数据格式(命令0x52**** - ****加速度传感器设置)**:
|
|||
|
|
读操作:返回3字节固定长度数据(开关1字节 + 灵敏度1字节 + 振动阈值1字节)
|
|||
|
|
写操作:接收3字节数据(开关1字节 + 灵敏度1字节 + 振动阈值1字节)
|
|||
|
|
**数据格式(命令0x53**** - ****查询加速度传感器数据)**:
|
|||
|
|
读操作:返回6字节固定长度数据(X轴加速度2字节 + Y轴加速度2字节 + Z轴加速度2字节)
|
|||
|
|
每个轴数据:2字节,小端序,有符号整数(int16_t),单位:mg
|
|||
|
|
数据范围:-32768到32767(对应-32768mg到32767mg)
|
|||
|
|
**数据库字段**: db_cfg.safety.accel.enable、sensitivity、threshold
|
|||
|
|
**实时数据来源**: meas_ctrl.accel.x_mg、y_mg、z_mg(float类型,单位:mg)
|
|||
|
|
**应用场景**:
|
|||
|
|
设备放置稳定性检测
|
|||
|
|
设备被移动或碰撞检测
|
|||
|
|
设备异常振动告警
|
|||
|
|
确保激光精准瞄准(设备不稳定时禁止或暂停激光发射)
|
|||
|
|
实时数据监控(查询X、Y、Z轴加速度值,可通过命令0xA5"查询设备传感器数据"获取)
|
|||
|
|
3.5.4 温度监控
|
|||
|
|
**功能说明**: 监控设备当前温度,防止设备过热损坏
|
|||
|
|
**温度检测**: 实时检测设备温度(单位:摄氏度)
|
|||
|
|
**温度阈值**: 设置温度告警阈值和停止阈值
|
|||
|
|
**超温保护**: 温度超过阈值时自动停止设备工作并上报状态
|
|||
|
|
**温度数据查询**: 通过命令0xA5"查询设备传感器数据"获取当前温度值
|
|||
|
|
**应用场景**:
|
|||
|
|
设备温度实时监控
|
|||
|
|
超温保护(防止设备过热)
|
|||
|
|
温度异常告警
|
|||
|
|
确保设备安全运行
|
|||
|
|
**安全机制**:
|
|||
|
|
温度超过停止阈值时,设备立即停止所有工作
|
|||
|
|
设备主动上报超温状态给 APP(通过通知类型0x02错误状态上报中的温度错误字段)
|
|||
|
|
温度恢复正常后,需要用户确认才能重新启动
|
|||
|
|
3.6 设备状态监控
|
|||
|
|
3.6.1 工作模式
|
|||
|
|
**待机模式**: 设备已启动但未开始工作
|
|||
|
|
**扫描模式**: 设备正在扫描检测害虫
|
|||
|
|
**消杀模式**: 设备正在执行消杀任务
|
|||
|
|
3.6.2 硬件状态
|
|||
|
|
**硬件错误状态查询**: 通过命令0xA1查询各硬件模块的错误状态
|
|||
|
|
温度错误: 0x00=无错误, 0x01=温度过高, 0x02=温度过低
|
|||
|
|
电机错误: 0x00=无错误, 0x01=温度错误, 0x02=反馈错误
|
|||
|
|
激光器错误: 0x00=无错误, 0x01=温度过高, 0x02=电压过低, 0x03=电压过高
|
|||
|
|
视觉错误: 0x00=无错误, 0x01=通信错误
|
|||
|
|
加速度错误: 0x00=无错误, 0x01=通信错误
|
|||
|
|
毫米波雷达错误: 0x00=无错误, 0x01=通信错误
|
|||
|
|
激光雷达错误: 0x00=无错误, 0x01=通信错误
|
|||
|
|
**数据来源**: meas_ctrl.error(测量控制模块的错误状态)
|
|||
|
|
**通信状态**: BLE 连接状态(由 APP 端 BLE SDK 检测,设备端通过硬件 LINK 引脚检测)
|
|||
|
|
3.6.3 统计数据
|
|||
|
|
**统计数据查询**: 通过命令0xA3查询设备工作统计数据和历史日志索引
|
|||
|
|
统计数据: 灭虫数量、总工作时间、今日工作时间、扫描次数、激光发射次数、蚊虫数据数量
|
|||
|
|
datalog日志记录数量。
|
|||
|
|
数据来源: db_cfg.statistics(统计数据)和db_cfg.datalog(日志索引)
|
|||
|
|
传感器异常: 传感器故障或异常
|
|||
|
|
温度异常: 设备温度超过阈值
|
|||
|
|
系统错误: 系统级错误
|
|||
|
|
3.6.4 传感器数据查询
|
|||
|
|
**传感器数据查询**: 通过命令0xA5一次性查询设备温度、3D传感器数据和电容电压
|
|||
|
|
**温度数据**: 2字节,单位:0.1°C(例如250表示25.0°C)
|
|||
|
|
**3D传**感器数据: 6字节,X/Y/Z轴加速度各2字节,单位:mg,有符号整数(范围:-32768到32767)
|
|||
|
|
电容电压: 2字节,单位:0.01V(例如1530表示15.30V)
|
|||
|
|
数据来源:
|
|||
|
|
温度:meas_ctrl.temp(测量控制模块的温度值)
|
|||
|
|
3D传感器:meas_ctrl.accel.x_mg、y_mg、z_mg(测量控制模块的加速度数据)
|
|||
|
|
电容电压:capture_get_laser_gun_dev()->current_voltage(激光器设备的当前电容电压)
|
|||
|
|
**应用场景**:
|
|||
|
|
设备状态实时监控
|
|||
|
|
传感器数据采集
|
|||
|
|
设备健康检查
|
|||
|
|
调试和诊断
|
|||
|
|
3.7 高级管理
|
|||
|
|
3.7.1 恢复出厂设置
|
|||
|
|
**功能说明****: ****清除所有用户设置,恢复设备到出厂状态**
|
|||
|
|
**安全要求****: ****需要管理员权限或特殊认证**
|
|||
|
|
3.8 固件管理
|
|||
|
|
3.8.1 固件更新(OTA)
|
|||
|
|
**版本查询****: ****查询OTA版本信息(命令0x80,返回固件版本、硬件版本、OTA版本)**
|
|||
|
|
**升级检查****: ****检查是否有新版本固件**
|
|||
|
|
**OTA ****升级****: ****通过**** BLE ****进行固件升级**
|
|||
|
|
|
|||
|
|
|
|||
|
|
4. BLE 控制场景分类
|
|||
|
|
基于用户功能模块,将 BLE 控制场景分为以下八大类:
|
|||
|
|
4.1 设备注册与认证类
|
|||
|
|
4.1.1 设备首次注册绑定
|
|||
|
|
**场景描述**: 设备首次开机,用户在 APP 完成注册和安全考试后,将用户信息绑定到设备
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 检测设备未注册状态(通过命令 0x01 查询)
|
|||
|
|
用户在 APP 完成安全考试(APP 端实现,考试内容关于激光安全使用)
|
|||
|
|
用户填写用户名和密码(APP 端验证)
|
|||
|
|
APP 将设备序列号与用户信息绑定关系存储到云端数据库
|
|||
|
|
APP 发送设备注册确认到设备(命令 0x02,仅发送用户名,不发送密码)
|
|||
|
|
设备存储用户名信息(设备端不存储密码)
|
|||
|
|
设备返回绑定成功确认
|
|||
|
|
**使用场景**:
|
|||
|
|
新设备首次使用
|
|||
|
|
设备恢复出厂设置后重新注册
|
|||
|
|
**安全要求**:
|
|||
|
|
设备与用户绑定关系存储在云端(APP数据库)
|
|||
|
|
设备端仅存储用户名,不存储密码
|
|||
|
|
一个设备最多绑定 10 个用户
|
|||
|
|
首次注册后设备进入已注册状态,后续操作需要登录
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.1.2 用户登录认证
|
|||
|
|
**场景描述**: 用户通过 APP 登录设备,验证用户权限
|
|||
|
|
**认证方式**:
|
|||
|
|
**密码登录**: APP 在云端验证用户名和密码,验证通过后发送用户名和解锁状态到设备(命令 0x03),设备接收后解锁
|
|||
|
|
**指纹登录**: 设备本地验证指纹(指纹验证由设备端硬件模块完成,不通过BLE命令)
|
|||
|
|
**典型操作**:
|
|||
|
|
**密码登录流程**:
|
|||
|
|
用户在 APP 输入用户名和密码
|
|||
|
|
APP 在云端验证设备序列号与用户的绑定关系
|
|||
|
|
APP 在云端验证用户名和密码
|
|||
|
|
验证通过后,APP 发送用户名和解锁状态到设备(命令 0x03)
|
|||
|
|
设备接收解锁状态,记录登录时间
|
|||
|
|
设备返回解锁成功确认
|
|||
|
|
**指纹登录使能设置流程**:
|
|||
|
|
用户必须先通过密码登录解锁设备
|
|||
|
|
APP 发送用户名和使能状态到设备(命令 0x04)
|
|||
|
|
设备验证用户名是否存在
|
|||
|
|
设备设置该用户的指纹登录使能状态(finger_id_valid字段)
|
|||
|
|
设备保存设置并返回结果
|
|||
|
|
认证成功后,APP 获得设备控制权限,可执行后续操作
|
|||
|
|
**使用场景**:
|
|||
|
|
每次 APP 连接设备时(已注册设备必须登录)
|
|||
|
|
设备长时间未操作后重新认证(建议超时时间 30 分钟)
|
|||
|
|
**安全要求**:
|
|||
|
|
密码验证在云端完成,设备端不验证密码
|
|||
|
|
设备与用户绑定关系存储在云端,APP通过云端验证绑定关系
|
|||
|
|
连续 5 次登录失败后,APP 端锁定 5 分钟
|
|||
|
|
登录成功后,设备记录登录时间,用于超时判断
|
|||
|
|
**通信流程**:
|
|||
|
|
**密码登录流程**:
|
|||
|
|
|
|||
|
|
**指纹登录使能设置流程**:
|
|||
|
|
|
|||
|
|
4.1.3 指纹录制管理
|
|||
|
|
**场景描述**: 用户在设备上录制指纹,用于后续指纹登录
|
|||
|
|
**典型操作**:
|
|||
|
|
用户必须先通过APP登录(首次录制需密码登录,因为尚未有指纹)
|
|||
|
|
APP 发起指纹录制请求(命令 0x05,指定用户名)
|
|||
|
|
设备检查用户是否已解锁(设备端记录登录状态)
|
|||
|
|
设备验证用户名是否存在
|
|||
|
|
设备确定page_id:
|
|||
|
|
如果用户已有finger_id,使用它重新注册(覆盖旧指纹)
|
|||
|
|
如果用户没有finger_id,分配新的page_id(查找数据库中已使用的最大page_id + 1)
|
|||
|
|
设备检查指纹库是否已满
|
|||
|
|
设备启动指纹注册状态机(异步处理)
|
|||
|
|
设备引导用户按压指纹(循环采集9次)
|
|||
|
|
设备验证指纹质量,合并特征,存储模板
|
|||
|
|
注册成功后,设备自动更新数据库:
|
|||
|
|
设置 finger_id = page_id
|
|||
|
|
设置 finger_id_valid = 1
|
|||
|
|
保存到数据库
|
|||
|
|
设备返回录制结果(成功/失败)
|
|||
|
|
**使用场景**:
|
|||
|
|
用户首次设置指纹登录
|
|||
|
|
重新录制指纹(覆盖旧指纹)
|
|||
|
|
**安全要求**:
|
|||
|
|
必须已通过APP登录(设备已解锁)才能录制指纹
|
|||
|
|
不能有注册正在进行中(同一时间只能有一个注册流程)
|
|||
|
|
指纹数据仅存储在设备端,不传输到 APP
|
|||
|
|
指纹模板与用户名关联,存储到指纹库的指定page_id位置
|
|||
|
|
注册完成后自动更新数据库,无需额外命令
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.1.4 用户权限查询
|
|||
|
|
**场景描述**: 查询设备绑定的用户列表和权限信息
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 从云端查询设备绑定的用户列表(绑定关系在云端)
|
|||
|
|
APP 查询设备端存储的用户名列表(命令 0x07)
|
|||
|
|
设备返回用户名、指纹ID、指纹ID有效标志等信息(设备端仅存储用户名和指纹信息)
|
|||
|
|
**使用场景**:
|
|||
|
|
多用户管理
|
|||
|
|
权限验证
|
|||
|
|
**说明**: 设备与用户的完整绑定关系存储在云端,设备端仅存储用户名列表用于指纹验证
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.1.6 设备分享流程
|
|||
|
|
**场景描述**: 设备所有者(管理员)将设备分享给其他用户,被分享者通过BLE连接设备并完成注册绑定
|
|||
|
|
**典型操作**:
|
|||
|
|
**步骤1:所有者发起分享**:
|
|||
|
|
设备所有者(管理员)在APP中选择"分享设备"功能
|
|||
|
|
APP向云端服务器发送分享请求(设备序列号 + 被分享者手机号/账号)
|
|||
|
|
云端验证所有者权限,生成分享邀请(可选:生成分享邀请码)
|
|||
|
|
云端向被分享者发送分享通知(短信/推送消息)
|
|||
|
|
**步骤2:被分享者接受分享**:
|
|||
|
|
被分享者收到分享通知,打开APP查看分享邀请
|
|||
|
|
APP从云端查询分享邀请状态和设备信息
|
|||
|
|
被分享者确认接受分享
|
|||
|
|
**步骤3:被分享者连接设备并**注册:
|
|||
|
|
被分享者需要**物理靠近设备**(BLE连接需要近距离)
|
|||
|
|
被分享者APP扫描并发现设备(通过设备序列号识别)
|
|||
|
|
被分享者APP发起BLE连接请求
|
|||
|
|
BLE连接建立后,APP查询设备注册状态(命令 0x01)
|
|||
|
|
设备返回已注册状态
|
|||
|
|
被分享者在APP上完成安全考试(APP端实现)
|
|||
|
|
被分享者填写用户名和密码(APP端验证格式)
|
|||
|
|
APP向云端验证分享邀请有效性
|
|||
|
|
云端将设备序列号与新用户绑定(存储到云端数据库)
|
|||
|
|
APP发送设备注册确认到设备(命令 0x02,仅发送用户名)
|
|||
|
|
设备检查用户数量(最多支持10个用户)
|
|||
|
|
设备存储用户名信息(设备端不存储密码)
|
|||
|
|
设备返回注册成功确认
|
|||
|
|
APP向云端确认分享完成
|
|||
|
|
云端通知所有者分享成功
|
|||
|
|
**使用场景**:
|
|||
|
|
家庭成员共享设备
|
|||
|
|
多用户协作使用设备
|
|||
|
|
**安全要求**:
|
|||
|
|
被分享者必须物理靠近设备才能完成BLE配对(安全要求)
|
|||
|
|
被分享者必须完成安全考试才能注册
|
|||
|
|
设备最多支持10个用户,超过限制时注册失败
|
|||
|
|
设备与用户绑定关系存储在云端,设备端仅存储用户名
|
|||
|
|
**重要说明**:
|
|||
|
|
设备分享必须通过BLE本地连接完成,不支持远程分享
|
|||
|
|
被分享者需要在现场才能完成BLE配对和注册
|
|||
|
|
分享流程与首次注册流程相同,都需要通过BLE连接设备
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.2 系统控制类
|
|||
|
|
4.2.1 语言设置
|
|||
|
|
**场景描述**: 设置设备显示语言
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 发送语言设置命令(英文/中文)
|
|||
|
|
设备保存语言设置
|
|||
|
|
设备 LCD 显示更新为对应语言
|
|||
|
|
**使用场景**: 用户个性化设置
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.2.2 时间管理
|
|||
|
|
**场景描述**: 设置和同步设备时间
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 发送时间设置命令(年、月、日、时、分、秒)
|
|||
|
|
设备保存时间设置
|
|||
|
|
APP 查询设备当前时间
|
|||
|
|
**使用场景**: 时间同步、定时功能设置
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.2.3 定时任务设置
|
|||
|
|
**场景描述**: 设置定时任务,在指定时间范围内自动运行指定的设备模式,支持按周重复执行。定时关机功能通过设置运行模式为"待机"实现。
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 添加/修改定时任务(任务ID、开关、开始时间、结束时间、模式、重复设置)
|
|||
|
|
APP 查询所有定时任务列表
|
|||
|
|
APP 删除定时任务(设置开关为关闭)
|
|||
|
|
设备在指定时间范围内自动执行定时任务
|
|||
|
|
**任务参数**:
|
|||
|
|
**任务ID**: 0-4(对应数组索引),最多支持5组定时任务
|
|||
|
|
**开关**: 启用/禁用该定时任务(0x00=禁用, 0x01=启用)
|
|||
|
|
**开始时间**: 开始小时(1字节,0-23) + 开始分钟(1字节,0-59)
|
|||
|
|
**结束时间**: 结束小时(1字节,0-23) + 结束分钟(1字节,0-59)
|
|||
|
|
**运行模式**: 待机(0x00)、扫描(0x01)、消杀(0x02)
|
|||
|
|
**待机**模式**(0x00)**: 设备进入待机状态,可用于定时关机功能
|
|||
|
|
扫描模式(0x01): 设备进入扫描检测状态
|
|||
|
|
消杀模式(0x02): 设备进入消杀工作状态
|
|||
|
|
**重复设置**: 1字节,按位表示星期几重复执行
|
|||
|
|
bit0: 周一 (0x01)
|
|||
|
|
bit1: 周二 (0x02)
|
|||
|
|
bit2: 周三 (0x04)
|
|||
|
|
bit3: 周四 (0x08)
|
|||
|
|
bit4: 周五 (0x10)
|
|||
|
|
bit5: 周六 (0x20)
|
|||
|
|
bit6: 周日 (0x40)
|
|||
|
|
示例:0x3F (0b00111111) 表示周一到周六,0x41 (0b01000001) 表示周一和周日
|
|||
|
|
**使用场景**:
|
|||
|
|
**定时关机**: 设置运行模式为"待机",在指定时间范围自动进入待机状态(如:每天23:00-06:00自动关机)
|
|||
|
|
自动化灭虫任务: 设置运行模式为"消杀",在指定时间范围自动开始灭虫工作(如:工作日20:00-22:00自动消杀)
|
|||
|
|
定时扫描检测: 设置运行模式为"扫描",在指定时间范围自动开始扫描检测(如:每天08:00-18:00自动扫描)
|
|||
|
|
节能管理: 通过定时任务实现自动化控制,避免长时间工作
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.3 外设控制类
|
|||
|
|
4.3.1 LCD 控制
|
|||
|
|
**场景描述**: 设置 LCD 显示屏休眠功能和亮度
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 设置 LCD 休眠开关和休眠时间(命令 0x20)
|
|||
|
|
APP 设置亮度自适应开关和亮度值(命令 0x21)
|
|||
|
|
APP 设置亮度值(10-100%,仅在自适应关闭时有效)
|
|||
|
|
**使用场景**: 节能管理、显示优化
|
|||
|
|
**休眠设置说明**:
|
|||
|
|
**休眠**开关: 0x00=关闭休眠功能,0x01=开启休眠功能
|
|||
|
|
休眠时间: 0x01=1分钟,0x05=5分钟,0x0A=10分钟,0x1E=30分钟
|
|||
|
|
当休眠功能开启时,LCD 在无操作达到设定时间后自动进入休眠状态
|
|||
|
|
休眠状态下 LCD 关闭显示以节省电量,用户操作时自动唤醒
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.3.2 RGB 指示灯控制
|
|||
|
|
**场景描述**: 控制 RGB 指示灯的颜色和效果
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 控制指示灯开关
|
|||
|
|
APP 设置指示灯颜色(RGB 值)
|
|||
|
|
APP 设置指示灯效果(闪烁、常亮、警示)
|
|||
|
|
**使用场景**: 状态指示、个性化设置
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.3.3 WIFI 控制
|
|||
|
|
**场景描述**: 控制 WIFI 功能开关和配置
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询当前 WIFI 配置(读操作)
|
|||
|
|
APP 控制 WIFI 开关(写操作,仅发送开关字节)
|
|||
|
|
APP 配置 WIFI SSID 和密码(写操作,发送开关+SSID+密码)
|
|||
|
|
**使用场景**: 网络连接管理
|
|||
|
|
**数据格式说明**:
|
|||
|
|
**读操作**: 设备返回65字节固定长度数据
|
|||
|
|
字节0:开关状态(0x00=关闭,0x01=开启)
|
|||
|
|
字节1-32:SSID字符串(32字节,ASCII编码)
|
|||
|
|
字节33-64:密码字符串(32字节,ASCII编码)
|
|||
|
|
**写操作**: APP发送可变长度数据
|
|||
|
|
字节0:开关值(0x00=关闭,0x01=开启,必填)
|
|||
|
|
字节1-N:SSID字符串(以\0结尾,最多32字节,可选)
|
|||
|
|
字节N+1-M:密码字符串(以\0结尾,最多32字节,可选)
|
|||
|
|
说明:如果只更新开关,只需发送1字节;如果更新SSID,发送开关+SSID;如果同时更新SSID和密码,发送完整数据
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.3.4 BLE 控制
|
|||
|
|
**场景描述**: 设置 BLE 广播名称
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 设置 BLE 广播名称
|
|||
|
|
**使用场景**: 蓝牙管理、设备识别
|
|||
|
|
**说明**:
|
|||
|
|
BLE 功能始终开启,不支持通过 APP 关闭(关闭后无法与 APP 通信)
|
|||
|
|
Android/iOS 无法直接获取 BLE MAC 地址,设备识别主要使用设备序列号
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.3.5 多媒体控制
|
|||
|
|
**场景描述**: 控制视频录制和音效设置
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询当前多媒体配置(读操作)
|
|||
|
|
APP 控制视频录制开关(写操作,仅发送开关字节)
|
|||
|
|
APP 设置录制时长(写操作,发送开关+时长)
|
|||
|
|
APP 控制音效开关(写操作,发送视频录制相关字段+音效开关)
|
|||
|
|
APP 选择音效类型和音量(写操作,发送完整数据)
|
|||
|
|
**使用场景**: 功能配置
|
|||
|
|
**数据格式说明**:
|
|||
|
|
**读操作**: 设备返回5字节固定长度数据
|
|||
|
|
字节0:视频录制开关(0x00=关闭,0x01=开启)
|
|||
|
|
字节1:录制时长(1字节,0x03=3秒, 0x05=5秒, 0x0A=10秒)
|
|||
|
|
字节2:音效开关(0x00=关闭,0x01=开启)
|
|||
|
|
字节3:音效类型(0x00=Hello, 0x01=Goodbye, 0x02=Test, 0x03=BIU, 0x04=Main)
|
|||
|
|
字节4:音量(0-15,对应芯片E0-EF共16级)
|
|||
|
|
**写操作**: APP发送可变长度数据
|
|||
|
|
字节0:视频录制开关(0x00=关闭,0x01=开启,必填)
|
|||
|
|
字节1:录制时长(1字节,可选,0x03=3秒, 0x05=5秒, 0x0A=10秒)
|
|||
|
|
字节2:音效开关(0x00=关闭,0x01=开启,可选)
|
|||
|
|
字节3:音效类型(0x00-0x04,可选)
|
|||
|
|
字节4:音量(0-15,可选)
|
|||
|
|
说明:如果只更新视频录制开关,只需发送1字节;如果更新录制时长,发送开关+时长(2字节);如果同时更新音效,发送完整数据(5字节)
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.3.6 补光灯控制
|
|||
|
|
**场景描述**: 控制补光灯开关、类型和光照强度,监控补光灯连接状态
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 控制补光灯开关
|
|||
|
|
APP 选择补光类型(红外光/白光)
|
|||
|
|
APP 设置补光光照强度(低/中/高)
|
|||
|
|
APP 查询补光灯连接状态
|
|||
|
|
设备检测到补光灯连接/断开时主动上报状态
|
|||
|
|
**使用场景**:
|
|||
|
|
夜间补光、检测优化
|
|||
|
|
补光灯设备管理
|
|||
|
|
连接状态监控
|
|||
|
|
**连接状态**:
|
|||
|
|
补光灯连接时,设备主动上报连接状态(通知类型 0x09)
|
|||
|
|
补光灯断开时,设备主动上报断开状态
|
|||
|
|
APP 可随时查询补光灯连接状态
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.3.7 可见光激光器控制
|
|||
|
|
**场景描述**: 控制可见光激光器开关
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 控制可见光激光器开关
|
|||
|
|
APP 查询可见光激光器状态
|
|||
|
|
**使用场景**:
|
|||
|
|
激光瞄准辅助
|
|||
|
|
设备调试和校准
|
|||
|
|
用户可视化激光位置
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.4 害虫消灭控制类
|
|||
|
|
4.4.1 角度控制
|
|||
|
|
**场景描述**: 设置激光扫描角度范围
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询当前角度范围设置(读操作)
|
|||
|
|
APP 设置扫描角度范围(写操作,发送2字节角度值)
|
|||
|
|
**使用场景**: 扫描范围调整
|
|||
|
|
**数据格式说明**:
|
|||
|
|
**读操作**: 设备返回2字节固定长度数据
|
|||
|
|
字节0-1:角度范围(2字节,小端序,单位:0.1度,范围:1-900)
|
|||
|
|
**写操作**: APP发送2字节数据
|
|||
|
|
字节0-1:角度范围(2字节,小端序,单位:0.1度,范围:1-900)
|
|||
|
|
说明:设备会验证角度范围是否在有效范围内(1-900),超出范围将返回参数错误
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.4.2 距离控制
|
|||
|
|
**场景描述**: 设置害虫检测和瞄准距离
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 设置检测距离范围(米)
|
|||
|
|
APP 设置瞄准距离(米)
|
|||
|
|
**使用场景**: 检测范围优化
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.5 安全设置类
|
|||
|
|
4.5.1 毫米波雷达设置
|
|||
|
|
**场景描述**: 配置毫米波雷达检测参数
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询当前毫米波雷达设置(读操作)
|
|||
|
|
APP 控制毫米波雷达开关(写操作)
|
|||
|
|
APP 设置检测灵敏度(低/中/高)
|
|||
|
|
APP 设置安全保护距离
|
|||
|
|
**使用场景**: 人体检测、安全保护
|
|||
|
|
**数据格式说明**:
|
|||
|
|
**读操作**: 设备返回4字节固定长度数据
|
|||
|
|
字节0:开关(0x00=关闭,0x01=开启)
|
|||
|
|
字节1:灵敏度(0x00=低,0x01=中,0x02=高)
|
|||
|
|
字节2-3:安全距离(2字节,小端序,单位:0.1米,范围:1-100)
|
|||
|
|
**写操作**: APP发送4字节数据
|
|||
|
|
字节0:开关(0x00=关闭,0x01=开启)
|
|||
|
|
字节1:灵敏度(0x00=低,0x01=中,0x02=高)
|
|||
|
|
字节2-3:安全距离(2字节,小端序,单位:0.1米,范围:1-100)
|
|||
|
|
说明:设备会验证所有参数的有效性,超出范围将返回参数错误
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.5.2 视觉检测设置
|
|||
|
|
**场景描述**: 配置视觉检测参数
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询当前视觉检测设置(读操作)
|
|||
|
|
APP 控制视觉检测开关(写操作)
|
|||
|
|
APP 设置检测灵敏度(低/中/高)
|
|||
|
|
**使用场景**: 安全检测、目标识别
|
|||
|
|
**说明**: 摄像头可视范围固定,无需软件设置检测范围
|
|||
|
|
**数据格式说明**:
|
|||
|
|
**读操作**: 设备返回2字节固定长度数据
|
|||
|
|
字节0:开关(0x00=关闭,0x01=开启)
|
|||
|
|
字节1:灵敏度(0x00=低,0x01=中,0x02=高)
|
|||
|
|
**写操作**: APP发送2字节数据
|
|||
|
|
字节0:开关(0x00=关闭,0x01=开启)
|
|||
|
|
字节1:灵敏度(0x00=低,0x01=中,0x02=高)
|
|||
|
|
说明:设备会验证所有参数的有效性,超出范围将返回参数错误
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.5.3 加速度传感器设置
|
|||
|
|
**场景描述**: 配置3轴加速度传感器参数,用于检测设备振动状态
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询当前加速度传感器设置(命令0x52,读操作)
|
|||
|
|
APP 控制加速度传感器开关(命令0x52,写操作)
|
|||
|
|
APP 设置振动检测灵敏度(低/中/高)
|
|||
|
|
APP 设置振动检测阈值
|
|||
|
|
APP 查询加速度传感器实时数据(命令0x53,读操作)
|
|||
|
|
**使用场景**:
|
|||
|
|
设备稳定性检测(确保设备稳定放置)
|
|||
|
|
设备移动检测(检测设备是否被移动)
|
|||
|
|
异常振动告警(检测设备异常振动)
|
|||
|
|
安全保护(设备不稳定时禁止或暂停激光发射)
|
|||
|
|
实时数据监控(查询X、Y、Z轴加速度值)
|
|||
|
|
**安全要求**:
|
|||
|
|
检测到设备不稳定时,设备自动停止激光发射
|
|||
|
|
设备稳定后,需要用户确认才能重新启动
|
|||
|
|
振动数据实时监控,超过阈值立即响应
|
|||
|
|
**查询加速度传感器数据(命令0x53)**:
|
|||
|
|
**数据格式说明**:
|
|||
|
|
**读操作**: 设备返回6字节固定长度数据
|
|||
|
|
字节0-1:X轴加速度(2字节,小端序,有符号整数int16_t,单位:mg)
|
|||
|
|
字节2-3:Y轴加速度(2字节,小端序,有符号整数int16_t,单位:mg)
|
|||
|
|
字节4-5:Z轴加速度(2字节,小端序,有符号整数int16_t,单位:mg)
|
|||
|
|
数据范围:-32768到32767(对应-32768mg到32767mg)
|
|||
|
|
说明:数据格式为小端序(低字节在前,高字节在后),有符号整数
|
|||
|
|
**数据格式说明(命令0x52**** - ****加速度传感器设置)**:
|
|||
|
|
**读操作**: 设备返回3字节固定长度数据
|
|||
|
|
字节0:开关(0x00=关闭,0x01=开启)
|
|||
|
|
字节1:灵敏度(0x00=低,0x01=中,0x02=高)
|
|||
|
|
字节2:振动阈值(1-255)
|
|||
|
|
**写操作**: APP发送3字节数据
|
|||
|
|
字节0:开关(0x00=关闭,0x01=开启)
|
|||
|
|
字节1:灵敏度(0x00=低,0x01=中,0x02=高)
|
|||
|
|
字节2:振动阈值(1-255)
|
|||
|
|
说明:设备会验证所有参数的有效性,超出范围将返回参数错误
|
|||
|
|
**数据格式说明(命令0x53**** - ****查询加速度传感器数据)**:
|
|||
|
|
**读操作**: 设备返回6字节固定长度数据
|
|||
|
|
字节0-1:X轴加速度(2字节,小端序,有符号整数int16_t,单位:mg)
|
|||
|
|
字节2-3:Y轴加速度(2字节,小端序,有符号整数int16_t,单位:mg)
|
|||
|
|
字节4-5:Z轴加速度(2字节,小端序,有符号整数int16_t,单位:mg)
|
|||
|
|
数据范围:-32768到32767(对应-32768mg到32767mg)
|
|||
|
|
说明:数据格式为小端序(低字节在前,高字节在后),有符号整数,数据来源于meas_ctrl.accel
|
|||
|
|
**通信流程(命令0x52**** - ****加速度传感器设置)**:
|
|||
|
|
|
|||
|
|
**通信流程(命令0x53**** - ****查询加速度传感器数据)**:
|
|||
|
|
|
|||
|
|
**实时监控流程**:
|
|||
|
|
|
|||
|
|
4.5.4 温度监控设置
|
|||
|
|
**场景描述**: 配置温度监控参数,监控设备温度状态
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 设置温度告警阈值
|
|||
|
|
APP 设置温度停止阈值
|
|||
|
|
APP 查询温度数据(通过命令0xA5"查询设备传感器数据"获取温度值)
|
|||
|
|
**使用场景**:
|
|||
|
|
设备温度实时监控
|
|||
|
|
超温保护设置
|
|||
|
|
温度异常告警
|
|||
|
|
设备安全运行保障
|
|||
|
|
**安全要求**:
|
|||
|
|
温度超过停止阈值时,设备自动停止工作
|
|||
|
|
温度超过告警阈值时,设备主动上报告警(通过通知类型 0x02 错误状态上报中的温度错误字段)
|
|||
|
|
温度恢复正常后,需要用户确认才能重新启动
|
|||
|
|
温度数据实时监控,超过阈值立即响应
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.6 高级管理类
|
|||
|
|
4.6.1 恢复出厂设置
|
|||
|
|
**场景描述**: 清除所有用户设置,恢复设备到出厂状态
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 发送恢复出厂设置命令(需要管理员权限)
|
|||
|
|
设备清除所有用户数据、绑定关系、参数设置
|
|||
|
|
设备返回恢复完成确认
|
|||
|
|
**使用场景**:
|
|||
|
|
设备故障恢复
|
|||
|
|
设备转售前清理
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.6.2 设备信息查询
|
|||
|
|
**场景描述**: 查询设备基本信息
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询设备序列号
|
|||
|
|
APP 查询OTA版本信息(命令0x80)
|
|||
|
|
APP 查询硬件版本
|
|||
|
|
APP 查询设备 MAC 地址
|
|||
|
|
**使用场景**: 设备识别、版本管理
|
|||
|
|
**说明**:
|
|||
|
|
Android 6.0+ 和 iOS 7+ 无法直接获取 BLE 设备的真实 MAC 地址
|
|||
|
|
设备识别主要使用设备序列号
|
|||
|
|
MAC 地址需通过查询设备信息命令(0xA2)从设备端获取
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.7 OTA 升级类
|
|||
|
|
4.7.1 OTA版本信息查询
|
|||
|
|
**场景描述**: 查询设备当前固件版本、硬件版本和OTA版本信息
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询OTA版本信息(命令0x80),返回12字节版本信息(固件版本4 + 硬件版本4 + OTA版本4)
|
|||
|
|
设备返回版本信息(固件版本、硬件版本、OTA版本)
|
|||
|
|
或者 APP 查询设备信息(命令0xA2),从返回数据中提取版本信息
|
|||
|
|
**使用场景**: 版本检查、升级判断、OTA升级前版本验证
|
|||
|
|
**说明**:
|
|||
|
|
命令0x80专门用于OTA升级场景,返回12字节版本信息(固件版本4 + 硬件版本4 + OTA版本4)
|
|||
|
|
命令0xA2返回完整的设备信息(76字节),包含版本信息和其他设备信息
|
|||
|
|
数据来源:db_cfg.device_info(与命令0xA2的版本信息字段一致)
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.7.2 固件升级
|
|||
|
|
**场景描述**: 通过 BLE 进行设备固件升级
|
|||
|
|
**操作流程**:
|
|||
|
|
APP 查询OTA版本信息(命令0x80),检查是否需要升级
|
|||
|
|
APP 发送升级开始命令(命令0x81),发送版本号、固件大小和CRC16校验和
|
|||
|
|
设备擦除1MB SPI Flash区域(地址0x100000),写入文件头(版本号、固件大小、CRC16占位为0),保存期望的CRC16
|
|||
|
|
APP 分包传输固件数据(命令0x82),设备写入Flash并实时计算CRC16
|
|||
|
|
当所有数据接收完成时,设备比较计算的CRC16与期望的CRC16,如果匹配则设置force_boot=1(有效),否则设置force_boot=0(无效)
|
|||
|
|
APP 发送结束传输命令(命令0x83),发送总大小
|
|||
|
|
设备验证接收数据大小,保存CRC16到文件头,更新数据库OTA版本和force_boot标志,返回成功
|
|||
|
|
**使用场景**: 功能更新、Bug 修复
|
|||
|
|
**Flash存储格式**:
|
|||
|
|
存储位置:SPI Flash地址0x100000,大小1MB
|
|||
|
|
文件头(10字节):版本号(4) + 固件大小(4) + CRC16(2)
|
|||
|
|
文件体:固件数据(从地址0x10000A开始)
|
|||
|
|
数据格式:所有多字节数据采用小端序
|
|||
|
|
**说明**: 升级进度由 APP 端和设备端各自计算,无需查询命令。APP 端根据已发送数据包和总数据量计算进度,设备端根据已接收数据包和总数据量计算进度。
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.8 设备状态监控类
|
|||
|
|
4.8.1 工作模式查询
|
|||
|
|
**场景描述**: 查询设备当前工作模式
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询设备工作模式(命令 0xA0)
|
|||
|
|
设备返回模式信息(待机/扫描/消杀)
|
|||
|
|
**模式说明**:
|
|||
|
|
**待机模式**** (0x00)**: 设备已启动但未开始工作
|
|||
|
|
**扫描模式**** (0x01)**: 设备正在扫描检测害虫
|
|||
|
|
**消杀模式**** (0x02)**: 设备正在执行消杀任务
|
|||
|
|
**数据格式**:
|
|||
|
|
**读操作**: 返回1字节
|
|||
|
|
字节0:工作模式值(0x00=待机, 0x01=扫描, 0x02=消杀)
|
|||
|
|
**写操作**: 不支持
|
|||
|
|
**数据来源**: 从数据库 db_cfg.system.work_mode 读取当前工作模式设置
|
|||
|
|
**使用场景**: 设备状态监控、工作流程判断
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.8.2 硬件状态查询
|
|||
|
|
**场景描述**: 查询设备各硬件模块的错误状态
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询硬件状态(命令 0xA1,读操作)
|
|||
|
|
设备返回7字节硬件错误状态
|
|||
|
|
**数据格式**:
|
|||
|
|
字节0 - 温度错误: 0x00=无错误, 0x01=温度过高, 0x02=温度过低
|
|||
|
|
字节1 - 电机错误: 0x00=无错误, 0x01=温度错误, 0x02=反馈错误
|
|||
|
|
字节2 - 激光器错误: 0x00=无错误, 0x01=温度过高, 0x02=电压过低, 0x03=电压过高
|
|||
|
|
字节3 - 视觉错误: 0x00=无错误, 0x01=通信错误
|
|||
|
|
字节4 - 加速度错误: 0x00=无错误, 0x01=通信错误
|
|||
|
|
字节5 - 毫米波雷达错误: 0x00=无错误, 0x01=通信错误
|
|||
|
|
字节6 - 激光雷达错误: 0x00=无错误, 0x01=通信错误
|
|||
|
|
**数据来源**: meas_ctrl.error(测量控制模块的错误状态)
|
|||
|
|
**使用场景**: 故障诊断、设备维护、实时监控
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.8.3 统计数据查询
|
|||
|
|
**场景描述**: 查询设备工作统计数据和历史日志索引信息
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询统计数据(命令 0xA3,读操作)
|
|||
|
|
设备返回统计数据(灭虫数量、工作时间、扫描次数等)和datalog日志索引信息
|
|||
|
|
**统计数据说明**:
|
|||
|
|
灭虫数量: 累计灭虫总数(uint32_t)
|
|||
|
|
总工作时间: 设备累计工作时间(uint32_t,单位:秒)
|
|||
|
|
今日工作时间: 今日累计工作时间(uint32_t,单位:秒)
|
|||
|
|
扫描次数: 累计扫描次数(uint32_t)
|
|||
|
|
激光发射次数: 累计激光发射次数(uint32_t)
|
|||
|
|
蚊虫数据数量: 扫描到、杀了的蚊子总数(uint32_t)
|
|||
|
|
本地数据记录数量;
|
|||
|
|
**数据来源**: db_cfg.statistics(统计数据)和db_cfg.datalog(日志索引)
|
|||
|
|
**使用场景**: 数据统计、历史数据查询、设备性能分析
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.8.4 蚊虫数据查询
|
|||
|
|
**场景描述**: 从SPI Flash读取指定索引范围的蚊虫数据
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 设置索引范围(命令 0xA4,写操作)
|
|||
|
|
设备返回成功响应,然后通过通知机制发送每条数据
|
|||
|
|
APP 接收通知数据包,解析并显示蚊虫数据
|
|||
|
|
**索引范围设置**:
|
|||
|
|
**指定范围**: start_index(4字节) + end_index(4字节)
|
|||
|
|
**读取全部**: start_index=0xFFFFFFFF,自动设置为0到kill_count-1
|
|||
|
|
**数据格式**:
|
|||
|
|
通知数据包: 索引(4字节) + 蚊虫数据(18字节)
|
|||
|
|
蚊虫数据: 角度(*1000度,int32_t,支持负数,例如90000表示90.000度,-22500表示-22.500度) + 距离(毫米) + 大小(毫米) + 时间(年月日时分秒) + 保留字段
|
|||
|
|
**发送间隔**: 每条数据间隔10ms
|
|||
|
|
**数据来源**: SPI Flash(从SPI_FLASH_MOSQUITO_DATA_ADDR开始存储)
|
|||
|
|
**使用场景**: 历史数据查询、数据分析、数据导出
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.8.5 查询设备传感器数据
|
|||
|
|
**场景描述**: 一次性查询设备温度、3D传感器数据和电容电压
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 查询设备传感器数据(命令 0xA5)
|
|||
|
|
设备返回10字节传感器数据(温度、X/Y/Z轴加速度、电容电压)
|
|||
|
|
APP 解析并显示传感器数据
|
|||
|
|
**使用场景**:
|
|||
|
|
设备状态实时监控
|
|||
|
|
传感器数据采集
|
|||
|
|
设备健康检查
|
|||
|
|
调试和诊断
|
|||
|
|
**通信流程**:
|
|||
|
|
|
|||
|
|
4.8.6 状态变化通知
|
|||
|
|
**场景描述**: 设备状态变化时主动通知 APP
|
|||
|
|
**典型操作**:
|
|||
|
|
设备检测到状态变化(工作状态、硬件状态等)
|
|||
|
|
设备主动发送状态通知(通知类型 0x01)
|
|||
|
|
APP 接收并显示状态变化
|
|||
|
|
**使用场景**: 实时状态监控、异常告警
|
|||
|
|
4.9 连接管理类
|
|||
|
|
4.9.1 断开连接
|
|||
|
|
**场景描述**: 主动断开 BLE 连接
|
|||
|
|
**典型操作**:
|
|||
|
|
APP 发送断开连接命令(命令 0x70)
|
|||
|
|
设备断开 BLE 连接
|
|||
|
|
APP 端 BLE SDK 检测到连接断开,更新设备状态
|
|||
|
|
**使用场景**: 用户主动断开、设备切换、多用户切换
|
|||
|
|
**通信流程**:
|
|||
|
|
**设备连接流程**:
|
|||
|
|
|
|||
|
|
4.9.2 多用户连接管理
|
|||
|
|
**场景描述**: 多个设备使用者同时在设备边上时,BLE连接管理策略
|
|||
|
|
**BLE连接限制**:
|
|||
|
|
点对点连接: BLE是点对点连接协议,同一时间设备只能连接一个手机
|
|||
|
|
连接独占: 当一个手机已连接设备时,其他手机无法连接
|
|||
|
|
连接冲突: 多个手机同时尝试连接时,设备只能接受一个连接请求
|
|||
|
|
**连接策略**:
|
|||
|
|
**推荐方案:先连接者优先**** + ****主动断开机制**
|
|||
|
|
**先连接者优先**:
|
|||
|
|
第一个成功连接设备的手机获得连接权限
|
|||
|
|
其他手机连接请求被拒绝
|
|||
|
|
已连接的用户可以正常使用设备(登录、控制、查询等)
|
|||
|
|
**主动断开机制**:
|
|||
|
|
当前连接用户可以通过命令 0x70 主动断开连接
|
|||
|
|
APP提供"断开连接"按钮,方便用户主动断开
|
|||
|
|
断开后,设备释放连接资源,其他用户可以连接
|
|||
|
|
**连接状态提示**:
|
|||
|
|
尝试连接但设备已被占用时,APP显示"设备已被其他用户连接,请等待或联系当前用户断开连接"
|
|||
|
|
当前连接用户APP显示"设备已连接"状态
|
|||
|
|
其他用户APP显示"设备已被占用"状态
|
|||
|
|
**连接冲突处理流程**:
|
|||
|
|
|
|||
|
|
**可选优化策略**:
|
|||
|
|
**超时自动断开**:
|
|||
|
|
连接空闲超过一定时间(如30分钟)自动断开
|
|||
|
|
释放连接资源,方便其他用户连接
|
|||
|
|
需要用户重新连接和登录
|
|||
|
|
**管理员优先连接**:
|
|||
|
|
管理员用户连接时,可请求当前用户断开(需用户确认)
|
|||
|
|
管理员连接请求优先级更高
|
|||
|
|
需要用户确认机制,避免强制断开
|
|||
|
|
**信号强度优先**:
|
|||
|
|
多个连接请求时,选择信号强度(RSSI值)最强的手机
|
|||
|
|
适用于多个用户同时在场的情况
|
|||
|
|
需要BLE模块支持多连接请求处理
|
|||
|
|
**实现要点**:
|
|||
|
|
**设备端**:
|
|||
|
|
通过LINK引脚检测连接状态(高电平=已连接)
|
|||
|
|
连接建立时,记录连接状态
|
|||
|
|
连接断开时,释放连接资源
|
|||
|
|
拒绝新的连接请求(如果已有连接)
|
|||
|
|
**APP端**:
|
|||
|
|
通过BLE SDK回调检测连接状态
|
|||
|
|
连接失败时,显示友好的错误提示
|
|||
|
|
提供"断开连接"按钮,方便用户主动断开
|
|||
|
|
显示连接状态(已连接/未连接/连接中)
|
|||
|
|
**使用场景**:
|
|||
|
|
多个家庭成员同时在场,需要切换用户控制设备
|
|||
|
|
设备管理员需要临时接管设备控制权
|
|||
|
|
用户离开设备后,其他用户可以连接使用
|
|||
|
|
**注意事项**:
|
|||
|
|
BLE连接是独占的,同一时间只能有一个手机连接
|
|||
|
|
切换用户需要当前用户主动断开连接
|
|||
|
|
远程用户无法通过WiFi抢占BLE连接(BLE和WiFi是独立的通信通道)
|
|||
|
|
|
|||
|
|
5. OTA 升级功能
|
|||
|
|
5.1 OTA 功能概述
|
|||
|
|
OTA(Over-The-Air)升级功能允许通过 BLE 无线方式更新设备固件,无需物理连接,大大提升了设备维护和功能更新的便利性。用户可以通过 APP 方便地升级设备固件,获得新功能和 Bug 修复。
|
|||
|
|
5.2 OTA 升级架构
|
|||
|
|
|
|||
|
|
5.3 OTA 升级流程
|
|||
|
|
5.3.1 升级前准备
|
|||
|
|
**版本检查**: APP 使用命令0x80查询设备OTA版本信息(固件版本、硬件版本、OTA版本)
|
|||
|
|
**兼容性验证**: 验证升级包与设备硬件兼容
|
|||
|
|
**存储空间检查**: 确认 Flash 有足够空间
|
|||
|
|
**用户确认**: 用户确认是否进行升级
|
|||
|
|
**进入升级模式**: 设备进入升级模式,停止正常工作
|
|||
|
|
5.3.2 固件传输
|
|||
|
|
**开始升级(命令0x81)**:
|
|||
|
|
APP发送版本号(4字节) + 固件大小(4字节) + CRC16校验和(2字节)
|
|||
|
|
设备擦除1MB SPI Flash区域(地址0x100000,256个扇区,每个4KB)
|
|||
|
|
设备写入文件头:版本号(4) + 固件大小(4) + CRC16占位(2) = 10字节
|
|||
|
|
文件头CRC16字段初始化为0,等待后续验证通过后更新
|
|||
|
|
设备保存期望的CRC16到状态跟踪结构,用于后续实时校验
|
|||
|
|
**分包传输(命令0x82)**:
|
|||
|
|
将固件包分成多个数据包(建议 20-244 字节/包,适配 BLE MTU)
|
|||
|
|
每个数据包格式:数据包序号(2字节) + 数据(N字节)
|
|||
|
|
设备将数据顺序写入Flash(从地址0x10000A开始)
|
|||
|
|
设备实时计算并累积CRC16(CRC16-CCITT算法,多项式0x1021,初始值0xFFFF)
|
|||
|
|
当所有数据接收完成时(received_size >= firmware_size),设备比较计算的CRC16与期望的CRC16
|
|||
|
|
CRC16匹配:设置force_boot=1(固件有效),标记在database的device_info.force_boot中
|
|||
|
|
CRC16不匹配:设置force_boot=0(固件无效),标记在database的device_info.force_boot中
|
|||
|
|
设备返回成功响应,上位机继续发送下一帧
|
|||
|
|
设备跟踪已接收数据大小和当前写入地址
|
|||
|
|
**结束传输(命令0x83)**:
|
|||
|
|
APP发送总大小(4字节)
|
|||
|
|
设备验证接收数据大小是否匹配
|
|||
|
|
设备保存CRC16到文件头(偏移8字节处)
|
|||
|
|
设备更新数据库OTA版本(db_cfg.device_info.ota_version = 固件版本号)
|
|||
|
|
设备更新数据库force_boot标志(db_cfg.device_info.force_boot,已在0x82中设置)
|
|||
|
|
设备保存数据库
|
|||
|
|
设备清除OTA升级状态
|
|||
|
|
设备返回成功响应
|
|||
|
|
注意:CRC16校验已在0x82命令中完成,这里只验证大小并保存CRC16到文件头
|
|||
|
|
**进度反馈**: 设备实时跟踪接收进度,APP端根据已发送数据包和总数据量计算进度
|
|||
|
|
5.3.3 固件存储格式
|
|||
|
|
**Flash存储格式**:
|
|||
|
|
存储位置:SPI Flash地址0x100000,大小1MB
|
|||
|
|
文件头(10字节,地址0x100000-0x100009):
|
|||
|
|
字节0-3:版本号(uint32_t,4字节小端序)
|
|||
|
|
字节4-7:固件大小(uint32_t,4字节小端序,单位:字节)
|
|||
|
|
字节8-9:CRC16(uint16_t,2字节小端序)
|
|||
|
|
文件体(从地址0x10000A开始):固件数据(Bin格式)
|
|||
|
|
5.3.4 升级后处理
|
|||
|
|
**设置启动标志**: 在 Bootloader 中设置新固件启动标志
|
|||
|
|
**系统复位**: 复位系统进入 Bootloader
|
|||
|
|
**固件启动**: Bootloader 加载并启动新固件
|
|||
|
|
**启动验证**: 验证新固件是否正常启动
|
|||
|
|
**升级确认**: APP 重新连接设备,确认升级成功
|
|||
|
|
5.4 OTA 安全机制
|
|||
|
|
**固件签名**: 升级包包含数字签名,防止恶意固件
|
|||
|
|
**版本验证**: 只允许升级到更高版本或指定版本
|
|||
|
|
**回滚机制**: 升级失败时自动回滚到原固件
|
|||
|
|
**双重备份**: 保留原固件备份,确保升级安全
|
|||
|
|
**权限验证**: 升级操作需要用户登录认证
|
|||
|
|
5.5 OTA 升级命令
|
|||
|
|
(详细命令格式将在通信协议文档中定义)
|
|||
|
|
OTA_VERSION_QUERY (0x80): 查询OTA版本信息(返回固件版本、硬件版本、OTA版本)
|
|||
|
|
OTA_START (0x81): 开始升级(接收版本号4 + 大小4 + CRC16 2,擦除Flash,写入文件头,保存期望的CRC16)
|
|||
|
|
OTA_DATA (0x82): 传输固件数据包(接收序号2 + 数据N,写入Flash,实时计算CRC16,当所有数据接收完成时比较CRC16并设置force_boot标志)
|
|||
|
|
OTA_END (0x83): 结束传输(接收总大小4,验证接收数据大小,保存CRC16到文件头,更新数据库OTA版本和force_boot标志)
|
|||
|
|
OTA_VERIFY (0x84): 校验固件(已废弃,功能已合并到0x82,在数据接收时实时校验)
|
|||
|
|
OTA_CANCEL (0x85): 取消升级(清除OTA状态)
|
|||
|
|
**说明**:
|
|||
|
|
升级进度由 APP 端和设备端各自计算,无需查询命令。
|
|||
|
|
**Flash存储格式**:
|
|||
|
|
存储位置:SPI Flash地址0x100000(1MB起始地址),大小1MB
|
|||
|
|
文件头(10字节):版本号(4) + 固件大小(4) + CRC16(2)
|
|||
|
|
文件体:固件数据(从地址0x10000A开始)
|
|||
|
|
CRC16算法:CRC16-CCITT(多项式0x1021,初始值0xFFFF)
|
|||
|
|
|
|||
|
|
|
|||
|
|
6. 通信协议框架
|
|||
|
|
6.1 协议结构
|
|||
|
|
优化后的协议结构如下:
|
|||
|
|
**协议优势**:
|
|||
|
|
**统一结构**: 所有命令采用统一的数据包结构,便于解析和处理
|
|||
|
|
**操作分离**: 读/写操作明确分离,简化命令设计
|
|||
|
|
**长度标识**: 明确的数据长度字段,支持可变长度数据
|
|||
|
|
**完整性校验**: 16位 CRC 校验,确保数据传输完整性
|
|||
|
|
**扩展性强**: 命令码空间充足,便于后续功能扩展
|
|||
|
|
6.2 命令分类
|
|||
|
|
采用分组命令码分配策略,便于管理和扩展:
|
|||
|
|
6.2.1 设备注册与认证类 (0x01-0x0F)
|
|||
|
|
6.2.2 系统控制类 (0x10-0x1F)
|
|||
|
|
6.2.3 外设控制类 (0x20-0x3F)
|
|||
|
|
6.2.4 害虫消灭控制类 (0x40-0x4F)
|
|||
|
|
6.2.5 安全设置类 (0x50-0x5F)
|
|||
|
|
6.2.6 高级管理类 (0x60-0x6F)
|
|||
|
|
6.2.7 连接管理类 (0x70-0x7F)
|
|||
|
|
|
|||
|
|
6.2.8 OTA 升级类 (0x80-0x9F)
|
|||
|
|
OTA 命令采用固定长度和可变长度结合:
|
|||
|
|
**说明**:
|
|||
|
|
升级进度由 APP 端和设备端各自计算,无需查询命令。APP 端根据已发送数据包和总数据量计算进度,设备端根据已接收数据包和总数据量计算进度。
|
|||
|
|
**CRC16校验流程**:
|
|||
|
|
在0x81命令时,上位机发送期望的CRC16校验值
|
|||
|
|
在0x82命令传输数据时,设备实时计算并累积CRC16
|
|||
|
|
当所有数据接收完成时,设备比较计算的CRC16与期望的CRC16
|
|||
|
|
如果CRC16匹配,设置force_boot=1(固件有效);否则设置force_boot=0(固件无效)
|
|||
|
|
force_boot标志保存在database的device_info.force_boot变量中,用于Bootloader判断是否启动新固件
|
|||
|
|
**Flash存储格式**:
|
|||
|
|
存储位置:SPI Flash地址0x100000(1MB起始地址),大小1MB
|
|||
|
|
文件头(10字节,地址0x100000-0x100009):
|
|||
|
|
字节0-3:版本号(uint32_t,4字节小端序)
|
|||
|
|
字节4-7:固件大小(uint32_t,4字节小端序,单位:字节)
|
|||
|
|
字节8-9:CRC16(uint16_t,2字节小端序)
|
|||
|
|
文件体(从地址0x10000A开始):固件数据(Bin格式)
|
|||
|
|
数据格式:所有多字节数据采用小端序(低字节在前)
|
|||
|
|
CRC16算法:CRC16-CCITT(多项式0x1021,初始值0xFFFF)
|
|||
|
|
|
|||
|
|
|
|||
|
|
6.2.9 状态查询类 (0xA0-0xBF)
|
|||
|
|
6.2.10 保留/扩展 (0xC0-0xFF)
|
|||
|
|
**0xC0-0xDF**: 保留用于未来功能扩展
|
|||
|
|
**0xE0-0xEF**: 设备特定命令
|
|||
|
|
**0xF0-0xFF**: 调试和测试命令
|
|||
|
|
6.3 响应格式
|
|||
|
|
6.3.1 读操作响应
|
|||
|
|
**成功响应**:
|
|||
|
|
**错误响应**:
|
|||
|
|
6.3.2 写操作响应
|
|||
|
|
**成功响应**:
|
|||
|
|
**错误响应**:
|
|||
|
|
6.3.3 设备主动通知
|
|||
|
|
**状态通知**:
|
|||
|
|
**通知类型**:
|
|||
|
|
0x01: 设备状态变化(工作模式变化等)
|
|||
|
|
工作模式变化:待机→扫描、扫描→消杀、消杀→待机等
|
|||
|
|
状态数据:状态码(1字节) + 状态描述(可选)
|
|||
|
|
0x02: 错误状态上报(系统错误、硬件故障等)
|
|||
|
|
数据格式:7字节 = 温度错误(1) + 电机错误(1) + 激光器错误(1) + 视觉错误(1) + 加速度错误(1) + 毫米波雷达错误(1) + 激光雷达错误(1)
|
|||
|
|
温度错误:0x00=无错误, 0x01=温度过高, 0x02=温度过低
|
|||
|
|
电机错误:0x00=无错误, 0x01=温度错误, 0x02=反馈错误
|
|||
|
|
激光器错误:0x00=无错误, 0x01=温度过高, 0x02=电压过低, 0x03=电压过高
|
|||
|
|
视觉错误:0x00=无错误, 0x01=通信错误
|
|||
|
|
加速度错误:0x00=无错误, 0x01=通信错误
|
|||
|
|
毫米波雷达错误:0x00=无错误, 0x01=通信错误
|
|||
|
|
激光雷达错误:0x00=无错误, 0x01=通信错误
|
|||
|
|
数据来源:meas_ctrl.error(测量控制模块的错误状态)
|
|||
|
|
0x03: 统计数据更新(灭虫数量、工作时间等)
|
|||
|
|
数据格式:44字节 = 灭虫数量(4) + 蚊虫数据数量(4) + 扫描次数(4) + 激光发射次数(4) + 总工作时间(4) + 今日工作时间(4) + 工作时间(4) + 角度(4) + 距离(2) + 大小(2) + 时间(6) + 保留(2)
|
|||
|
|
统计数据:灭虫数量、蚊虫数据数量、扫描次数、激光发射次数、总工作时间、今日工作时间、工作时间(本次工作会话时间)
|
|||
|
|
本次虫子数据:角度(*1000度,int32_t,支持负数,例如90000表示90.000度,-22500表示-22.500度)、距离(毫米)、大小(毫米)、时间(year+month+day+hour+minute+second)
|
|||
|
|
触发条件:每次成功写入蚊虫数据到Flash后发送
|
|||
|
|
0x04: 保留(原连接状态变化通知已删除)
|
|||
|
|
0x05: 安全告警(人体检测、安全保护触发等)
|
|||
|
|
0x06: 参数变化通知(参数被修改时主动通知)
|
|||
|
|
0x07: 保留(原设备振动告警功能已合并到0x02错误状态上报中的加速度错误字段)
|
|||
|
|
0x08: 蓄能状态通知(电容充电开始/完成)
|
|||
|
|
充电开始:设备开始充电
|
|||
|
|
充电完成:设备准备就绪,可发射激光
|
|||
|
|
0x09: 补光灯连接状态通知(补光灯连接/断开)
|
|||
|
|
连接:补光灯设备已连接
|
|||
|
|
断开:补光灯设备已断开
|
|||
|
|
0x0A: 保留(原温度告警通知功能已合并到0x02错误状态上报中的温度错误字段)
|
|||
|
|
0x0B: 蚊虫数据通知(查询蚊虫数据时发送)
|
|||
|
|
数据格式:索引(4字节小端序) + 蚊虫数据(18字节)
|
|||
|
|
蚊虫数据结构:角度(4字节,*1000度,int32_t,支持负数,例如90000表示90.000度,-22500表示-22.500度) + 距离(2字节,毫米) + 大小(2字节,毫米) + 时间(6字节:year+month+day+hour+minute+second) + 保留(4字节)
|
|||
|
|
发送间隔:每条数据间隔10ms
|
|||
|
|
触发条件:命令0xA4写操作成功后,设备自动发送指定索引范围的所有数据
|
|||
|
|
6.3.4 错误码定义
|
|||
|
|
错误码采用统一格式:
|
|||
|
|
6.4 安全机制
|
|||
|
|
采用多层安全机制:
|
|||
|
|
**用户认证**:
|
|||
|
|
密码验证在云端完成,设备端不验证密码
|
|||
|
|
设备与用户绑定关系存储在云端,APP通过云端验证绑定关系
|
|||
|
|
除注册和登录命令外,其他命令需要设备已解锁(设备端记录登录状态)
|
|||
|
|
**权限验证**: 设备端验证设备解锁状态,拒绝未解锁操作
|
|||
|
|
**数据完整性**: CRC16 校验确保数据包完整性
|
|||
|
|
**数据加密**: APP与云端之间的密码传输需要加密(使用 HTTPS 或 AES-128)
|
|||
|
|
**命令超时**: 设置命令超时时间(建议 5 秒),防止长时间等待
|
|||
|
|
**重传机制**: 校验失败时支持数据包重传(最多 3 次)
|
|||
|
|
6.5 协议实现建议
|
|||
|
|
协议设计遵循以下原则:
|
|||
|
|
**统一包结构**: 所有命令采用统一的数据包结构,简化解析逻辑
|
|||
|
|
**读/写分离**: 明确区分读操作和写操作,提高协议清晰度
|
|||
|
|
**分组管理**: 命令码按功能分组,便于管理和扩展
|
|||
|
|
**固定长度优先**: 优先使用固定长度数据包,提高处理效率
|
|||
|
|
**可变长度支持**: 对于大数据传输(如 OTA),支持可变长度数据包
|
|||
|
|
**校验机制**: 使用 CRC16 校验,确保数据传输可靠性
|
|||
|
|
|
|||
|
|
|
|||
|
|
7. 技术实现规范
|
|||
|
|
7.1 通信协议实现规范
|
|||
|
|
**详细通信协议**: 定义完整的命令格式、数据格式、错误码等
|
|||
|
|
**协议结构规范**:
|
|||
|
|
所有命令必须严格遵循 6.1 节定义的协议结构:
|
|||
|
|
**帧头**: 固定为 0xAA 0x55(2字节),标识 BLE 通信数据包
|
|||
|
|
**命令码**: 1字节,范围 0x01-0xFF,标识具体操作类型(参考 6.2 节命令分类)
|
|||
|
|
**读/写标识**: 1字节,0x00=读操作,0x01=写操作,0x02=通知
|
|||
|
|
**长度**: 1字节,数据字段长度(0-255 字节)
|
|||
|
|
**数据**: N字节,命令参数或响应数据(可变长度)
|
|||
|
|
**校验**: 2字节,CRC16 校验(LSB + MSB),校验范围:帧头到数据字段的所有字节
|
|||
|
|
**数据字段规范**:
|
|||
|
|
**字节序**: 采用小端序(Little-Endian),与 STM32H7 处理器一致
|
|||
|
|
多字节数据(如 16 位、32 位整数)的低字节在前,高字节在后
|
|||
|
|
示例:0x1234 存储为 0x34 0x12,0x12345678 存储为 0x78 0x56 0x34 0x12
|
|||
|
|
**编码**方式:
|
|||
|
|
**ASCII ****字符串**: 用于用户名、设备名称等文本数据,使用 ASCII 编码,不足长度用 0x00 填充
|
|||
|
|
**二进制数据**: 用于传感器数据、状态值等,直接使用二进制表示
|
|||
|
|
**枚举值**: 用于开关状态、模式选择等,使用单字节枚举值(如 0x00=关,0x01=开)
|
|||
|
|
**数据对齐**: 单字节数据无需对齐,多字节数据按自然边界对齐
|
|||
|
|
**错误码规范**:
|
|||
|
|
错误码定义参考 6.3.4 节,采用统一格式
|
|||
|
|
错误码在响应数据的第一字节返回(状态码字段)
|
|||
|
|
错误码分类:
|
|||
|
|
0x00: 成功
|
|||
|
|
0x01: 参数错误(参数无效或超出范围)
|
|||
|
|
0x02: 权限错误(用户未登录或权限不足)
|
|||
|
|
0x03: 设备忙(设备正在执行其他操作)
|
|||
|
|
0x04: 命令不支持(命令码不存在或未实现)
|
|||
|
|
0x05: 数据校验失败(CRC 校验失败)
|
|||
|
|
0x06: 超时(操作超时)
|
|||
|
|
0x07: 设备错误(设备内部错误)
|
|||
|
|
0x08-0xFF: 保留用于扩展错误码
|
|||
|
|
**协议版本管理**:
|
|||
|
|
协议版本号建议在设备信息查询命令(0xA2)中返回
|
|||
|
|
版本号格式:主版本号(1字节) + 次版本号(1字节) + 修订号(1字节)
|
|||
|
|
兼容性处理:新版本协议应向后兼容,新增命令使用新的命令码,不修改现有命令格式
|
|||
|
|
**命令格式示例**:
|
|||
|
|
读操作示例(查询设备注册状态,命令 0x01):
|
|||
|
|
写操作示例(设备注册绑定,命令 0x02):
|
|||
|
|
读操作响应示例(查询设备注册状态,命令 0x01,成功响应):
|
|||
|
|
写操作响应示例(设备注册绑定,命令 0x02,成功响应):
|
|||
|
|
错误响应示例(命令 0x02,参数错误):
|
|||
|
|
**数据加密**: APP 与 BLE 通信不需要应用层加密
|
|||
|
|
**数据完整性保护**:
|
|||
|
|
通过 CRC16 校验确保数据包完整性(参考 6.1 节协议结构)
|
|||
|
|
CRC16 校验范围:帧头到数据字段的所有字节
|
|||
|
|
校验失败时,设备返回错误码 0x05(数据校验失败),参考 6.3.4 节错误码定义
|
|||
|
|
校验失败时支持数据包重传(最多 3 次),参考 6.4 节安全机制
|
|||
|
|
**敏感数据处理**:
|
|||
|
|
**用户密码**: 在云端验证,不在 BLE 层传输,设备端不存储密码
|
|||
|
|
**设备序列号**: 通过查询命令(0xA2)获取,用于设备识别
|
|||
|
|
**指纹数据**: 仅存储在设备端,不通过 BLE 传输,设备本地验证
|
|||
|
|
**其他敏感数据**: 根据实际需求,可在设备端加密存储,但不在 BLE 通信层传输
|
|||
|
|
**安全机制总结**:
|
|||
|
|
BLE 链路层已提供加密保护
|
|||
|
|
应用层通过 CRC16 校验保证数据完整性
|
|||
|
|
敏感数据不在 BLE 层传输,降低安全风险
|
|||
|
|
与 6.4 节安全机制保持一致:数据完整性通过 CRC16 保证,无需应用层加密
|
|||
|
|
**连接状态检测**: BLE 连接状态检测机制
|
|||
|
|
**APP ****端实现细节**:
|
|||
|
|
**BLE SDK ****回调**: 通过 BLE SDK 提供的连接状态回调函数实时检测连接状态
|
|||
|
|
连接建立:onConnectionStateChange(connected)
|
|||
|
|
连接断开:onConnectionStateChange(disconnected)
|
|||
|
|
连接失败:onConnectionStateChange(failed)
|
|||
|
|
**状态机设计**:
|
|||
|
|
状态:未连接 → 连接中 → 已连接 → 断开中 → 未连接
|
|||
|
|
状态转换触发:BLE SDK 回调事件
|
|||
|
|
状态持久化:APP 端记录最后连接状态,用于 UI 显示
|
|||
|
|
**参考**: 1.3 节通信特点中说明 BLE 模块提供 LINK 和 WORK 状态引脚
|
|||
|
|
**设备端实现细节**:
|
|||
|
|
**LINK ****引脚检测**: 通过硬件 LINK 引脚检测连接状态
|
|||
|
|
高电平 = 已连接
|
|||
|
|
低电平 = 未连接
|
|||
|
|
**中断处理**: 使用 GPIO 中断检测 LINK 引脚状态变化
|
|||
|
|
上升沿中断:连接建立
|
|||
|
|
下降沿中断:连接断开
|
|||
|
|
**状态上报**: 连接状态由APP端BLE SDK直接检测,无需设备端主动通知
|
|||
|
|
注意:仅在连接存在时才能发送通知,连接断开后无法通信
|
|||
|
|
**内部逻辑处理**:
|
|||
|
|
连接断开时,设备自动停止工作(如停止激光发射、停止灭虫任务等)
|
|||
|
|
连接断开时,清理临时数据,保存必要状态
|
|||
|
|
连接建立时,恢复设备状态,准备接收命令
|
|||
|
|
**连接断开后的处理流程**:
|
|||
|
|
**APP ****端**:
|
|||
|
|
检测到连接断开后,更新 UI 显示(显示"设备已断开")
|
|||
|
|
清理命令队列,取消未完成的命令请求
|
|||
|
|
保存设备状态缓存,用于重连后状态同步
|
|||
|
|
**设备端**:
|
|||
|
|
立即停止所有工作(激光发射、灭虫任务等)
|
|||
|
|
保存当前工作状态和参数设置
|
|||
|
|
清理临时数据,准备下次连接
|
|||
|
|
**状态恢复**: 重连后,APP 可查询设备状态(命令 0xA0),同步设备状态
|
|||
|
|
**重连机制**:
|
|||
|
|
**自动重连策略**: APP 端实现自动重连功能
|
|||
|
|
检测到连接断开后,等待一定时间(建议 1-3 秒)
|
|||
|
|
自动发起重连请求
|
|||
|
|
重连失败后,增加等待时间(指数退避策略)
|
|||
|
|
最多重试 3-5 次,超过次数后提示用户手动重连
|
|||
|
|
**重连间隔**:
|
|||
|
|
首次重连:1 秒
|
|||
|
|
第二次重连:2 秒
|
|||
|
|
第三次重连:4 秒
|
|||
|
|
后续重连:8 秒(最大间隔)
|
|||
|
|
**用户手动重连**: 提供手动重连按钮,用户可主动触发重连
|
|||
|
|
**说明**:
|
|||
|
|
连接状态通过硬件 LINK 引脚检测,无需应用层命令查询
|
|||
|
|
如果 BLE 连接断开,APP 和设备之间无法通信,因此无需应用层查询命令
|
|||
|
|
与 4.9 节连接管理类保持一致:连接管理通过 BLE SDK 和硬件引脚实现
|
|||
|
|
**多设备管理**(可选功能): 支持一个 APP 管理多个设备
|
|||
|
|
**设备列表数据结构**:
|
|||
|
|
**设备信息**(参考 3.1.1 节设备信息):
|
|||
|
|
设备序列号:唯一标识设备(主要标识符,16字节,ASCII编码)
|
|||
|
|
设备名称:用户自定义的设备名称(可选,用于显示)
|
|||
|
|
固件版本:设备固件版本号(用于版本管理)
|
|||
|
|
硬件版本:设备硬件版本号
|
|||
|
|
设备 MAC 地址:通过查询设备信息命令(0x61)获取(Android/iOS 无法直接获取)
|
|||
|
|
**连接状态**:
|
|||
|
|
连接状态:已连接/未连接/连接中
|
|||
|
|
最后连接时间:记录最后成功连接的时间戳
|
|||
|
|
连接质量:信号强度(RSSI值)
|
|||
|
|
**设备配置缓存**:
|
|||
|
|
最后使用的参数设置(角度、距离等)
|
|||
|
|
设备工作模式(待机/扫描/消杀)
|
|||
|
|
设备硬件状态和错误状态(如有)
|
|||
|
|
**设备切换流程**:
|
|||
|
|
**断开当前设备**:
|
|||
|
|
APP 发送断开连接命令(命令 0x70,参考 6.2.7 节连接管理类)
|
|||
|
|
设备收到命令后断开 BLE 连接
|
|||
|
|
APP 端 BLE SDK 检测到连接断开,更新设备状态
|
|||
|
|
**连接新设备**:
|
|||
|
|
APP 扫描并发现目标设备(通过设备序列号或设备名称识别)
|
|||
|
|
APP 发起 BLE 连接请求
|
|||
|
|
连接建立后,APP 查询设备注册状态(命令 0x01)
|
|||
|
|
如设备已注册,APP 提示用户登录(密码或指纹)
|
|||
|
|
登录成功后,APP 同步设备状态(查询工作模式、参数设置等)
|
|||
|
|
**状态同步**:
|
|||
|
|
切换设备后,APP 查询设备当前状态(命令 0xA0、0xA1等)
|
|||
|
|
APP 更新设备配置缓存
|
|||
|
|
APP 显示设备当前状态和参数设置
|
|||
|
|
**批量操作设计**:
|
|||
|
|
**批量查询**: APP 端实现批量查询功能
|
|||
|
|
遍历设备列表,逐个设备执行查询命令
|
|||
|
|
使用操作队列管理批量操作,避免并发冲突
|
|||
|
|
显示批量操作进度(已完成/总数)
|
|||
|
|
操作超时处理:单个设备操作超时后,继续下一个设备
|
|||
|
|
**批量设置**: APP 端实现批量设置功能
|
|||
|
|
遍历设备列表,逐个设备执行设置命令
|
|||
|
|
使用操作队列管理批量操作
|
|||
|
|
显示批量操作进度和结果(成功/失败)
|
|||
|
|
部分失败处理:记录失败设备,操作完成后提示用户
|
|||
|
|
**操作队列**:
|
|||
|
|
使用队列管理批量操作,确保操作顺序
|
|||
|
|
支持取消批量操作(清空队列)
|
|||
|
|
操作失败时,记录错误信息,继续执行后续操作
|
|||
|
|
**设备标识方案**:
|
|||
|
|
**主要标识符**: 设备序列号(16字节,ASCII编码)
|
|||
|
|
通过查询设备信息命令(0xA2)获取,从返回数据中提取序列号
|
|||
|
|
设备序列号唯一标识设备,用于设备识别和绑定
|
|||
|
|
**辅助标识符**: 设备 MAC 地址(可选)
|
|||
|
|
通过查询设备信息命令(0xA2)获取
|
|||
|
|
注意:Android 6.0+ 和 iOS 7+ 无法直接获取 BLE MAC 地址(参考 3.1.1 节说明)
|
|||
|
|
设备识别主要使用设备序列号
|
|||
|
|
用户**标识**: 设备名称(用户自定义)
|
|||
|
|
用于 APP 界面显示,方便用户识别设备
|
|||
|
|
设备名称可重复,不作为唯一标识
|
|||
|
|
**设备分组和分类**:
|
|||
|
|
**按房间分组**: 用户可将设备按房间分组(客厅、卧室、厨房等)
|
|||
|
|
APP 端实现分组管理功能
|
|||
|
|
分组信息仅存储在 APP 端,不传输到设备
|
|||
|
|
**按**类型**分类**: 根据设备功能分类(灭虫设备、其他设备等)
|
|||
|
|
APP 端实现分类管理功能
|
|||
|
|
用于批量操作时的设备筛选
|
|||
|
|
自定义**标签**: 用户可为设备添加自定义标签
|
|||
|
|
APP 端实现标签管理功能
|
|||
|
|
标签信息仅存储在 APP 端
|
|||
|
|
**说明**:
|
|||
|
|
多设备管理为可选功能,APP 可根据实际需求实现
|
|||
|
|
所有操作使用 6.1 节的通信帧结构(帧头 0xAA 0x55、命令码、读/写、长度、数据、CRC16)
|
|||
|
|
仅涉及 APP 端设备管理,不涉及云端
|
|||
|
|
设备切换时,确保当前设备操作完成后再切换
|
|||
|
|
批量操作时,注意 BLE 连接限制(同一时间只能连接一个设备)
|
|||
|
|
**状态同步**: 设备状态变化时主动通知 APP
|
|||
|
|
**状态变化检测**:
|
|||
|
|
**状态机**设计(参考 3.6 节设备状态监控):
|
|||
|
|
工作模式:待机 → 扫描 → 消杀 → 待机
|
|||
|
|
硬件状态:正常 → 异常 → 正常(包含错误状态)
|
|||
|
|
**变化**触发**条件**:
|
|||
|
|
工作模式变化:用户操作、设备自动切换
|
|||
|
|
硬件状态变化:硬件故障检测、硬件恢复检测、错误发生、错误恢复
|
|||
|
|
参数变化:参数被修改(通过 APP 或设备本地操作)
|
|||
|
|
**状态变化检测机制**:
|
|||
|
|
设备端实时监测各状态值
|
|||
|
|
状态值变化时,立即触发状态变化事件
|
|||
|
|
状态变化事件触发主动通知(参考 6.3.3 节设备主动通知)
|
|||
|
|
**通知优先级**:
|
|||
|
|
紧急状态(最高优先级):
|
|||
|
|
错误状态上报(通知类型 0x02):硬件异常、系统错误等(包含温度错误、加速度错误/振动、电机错误、激光器错误、视觉错误、毫米波雷达错误、激光雷达错误)
|
|||
|
|
安全告警(通知类型 0x05):人体检测、安全保护触发
|
|||
|
|
处理:立即显示告警,中断当前操作(如需要)
|
|||
|
|
**普通**状态(中等优先级):
|
|||
|
|
设备状态变化(通知类型 0x01):工作模式变化等
|
|||
|
|
参数变化通知(通知类型 0x06):参数被修改
|
|||
|
|
处理:更新 UI 显示,记录状态变化
|
|||
|
|
**统计**信息(低优先级):
|
|||
|
|
统计数据更新(通知类型 0x03):灭虫数量、工作时间等,包含本次虫子的详细信息(角度、距离、大小、时间)
|
|||
|
|
蓄能状态通知(通知类型 0x08):电容充电开始/完成
|
|||
|
|
补光灯连接状态通知(通知类型 0x09):补光灯连接/断开
|
|||
|
|
蚊虫数据通知(通知类型 0x0B):查询蚊虫数据时发送,每条数据间隔10ms
|
|||
|
|
处理:后台更新统计数据,不中断用户操作
|
|||
|
|
**通知可靠性**:
|
|||
|
|
**确认**机制:
|
|||
|
|
APP 收到通知后,可发送确认响应(可选)
|
|||
|
|
设备端记录通知发送状态,用于重传判断
|
|||
|
|
**重传**策略:
|
|||
|
|
通知发送失败时(如连接断开),设备端记录未确认通知
|
|||
|
|
连接恢复后,设备端重新发送未确认的通知
|
|||
|
|
重传次数限制:最多重传 3 次
|
|||
|
|
**通知去重**:
|
|||
|
|
设备端记录最后发送的通知内容
|
|||
|
|
相同内容的通知不重复发送(避免重复通知)
|
|||
|
|
状态值变化时才发送通知(避免重复通知)
|
|||
|
|
**状态缓存和同步**:
|
|||
|
|
**APP ****端状态缓存**:
|
|||
|
|
APP 端缓存设备状态(工作模式、硬件状态、参数设置等)
|
|||
|
|
状态缓存用于 UI 显示,减少查询命令
|
|||
|
|
状态缓存更新:收到通知时更新,查询命令返回时更新
|
|||
|
|
状态缓存持久化:APP 退出时保存,启动时恢复
|
|||
|
|
**设备端**状态**持久化**:
|
|||
|
|
设备端持久化关键状态(参数设置、工作模式等)
|
|||
|
|
状态持久化到 Flash,设备重启后恢复
|
|||
|
|
状态变化时,立即更新持久化存储
|
|||
|
|
**状态同步机制**:
|
|||
|
|
连接建立后,APP 查询设备当前状态(命令 0xA0、0xA1等)
|
|||
|
|
APP 比较缓存状态和设备状态,如有差异则更新缓存
|
|||
|
|
设备端状态变化时,主动发送通知,APP 更新缓存
|
|||
|
|
**状态冲突处理**:
|
|||
|
|
**APP ****和设备**状态**不一致**:
|
|||
|
|
场景:APP 缓存状态与设备实际状态不一致
|
|||
|
|
处理:连接建立后,APP 查询设备当前状态,同步状态缓存
|
|||
|
|
**并发操作**冲突:
|
|||
|
|
场景:APP 发送设置命令,同时设备状态发生变化
|
|||
|
|
处理:设备端优先处理设置命令,状态变化通知在命令处理完成后发送
|
|||
|
|
**状态回滚**:
|
|||
|
|
场景:设备状态变化后,用户需要恢复到之前状态
|
|||
|
|
处理:APP 发送恢复命令,设备执行状态恢复,发送状态变化通知
|
|||
|
|
**通知格式**:
|
|||
|
|
所有通知使用 6.1 节的通信帧结构:
|
|||
|
|
帧头:0xAA 0x55
|
|||
|
|
通知码:与命令码区分(建议使用 0xF0-0xFF 范围)
|
|||
|
|
读/写标识:0x02(表示通知)
|
|||
|
|
长度:通知数据长度
|
|||
|
|
数据:通知类型(1字节) + 通知数据(参考 6.3.3 节设备主动通知)
|
|||
|
|
校验:CRC16 校验
|
|||
|
|
与 6.3.3 节设备主动通知保持一致,参考通知类型 0x01-0x0B(注意:0x07和0x0A已合并到0x02)
|
|||
|
|
**通知格式示例**:
|
|||
|
|
设备状态变化通知示例(通知类型 0x01,工作状态变化):
|
|||
|
|
错误状态上报通知示例(通知类型 0x02,振镜电机异常):
|
|||
|
|
**说明**:
|
|||
|
|
状态同步机制确保 APP 和设备状态一致
|
|||
|
|
通知优先级确保重要状态及时通知用户
|
|||
|
|
状态缓存减少查询命令,提高通信效率
|
|||
|
|
所有通知使用 6.1 节的通信帧结构(读/写标识为 0x02 表示通知)
|
|||
|
|
7.2 协议文档规划
|
|||
|
|
后续将添加以下详细协议文档,所有文档必须遵循 6.1 节的通信帧结构(帧头 0xAA 0x55、命令码、读/写标识、长度、数据、CRC16 校验)。
|
|||
|
|
7.2.1 BLE 通信协议详细规范.md
|
|||
|
|
**文档目的**: 定义完整的命令格式、数据格式、字节序和编码规范
|
|||
|
|
**目录结构**:
|
|||
|
|
**协议概述**
|
|||
|
|
协议版本信息
|
|||
|
|
协议结构说明(参考 6.1 节)
|
|||
|
|
通信流程概述
|
|||
|
|
**命令格式定义**(基于 6.2 节命令分类)
|
|||
|
|
设备注册与认证类 (0x01-0x0F)
|
|||
|
|
每个命令的详细格式
|
|||
|
|
请求格式(帧头、命令码、读/写、长度、数据、校验)
|
|||
|
|
响应格式(成功/失败)
|
|||
|
|
数据字段详细说明
|
|||
|
|
系统控制类 (0x10-0x1F)
|
|||
|
|
外设控制类 (0x20-0x3F)
|
|||
|
|
害虫消灭控制类 (0x40-0x4F)
|
|||
|
|
安全设置类 (0x50-0x5F)
|
|||
|
|
高级管理类 (0x60-0x6F)
|
|||
|
|
连接管理类 (0x70-0x7F)
|
|||
|
|
OTA 升级类 (0x80-0x9F)
|
|||
|
|
状态查询类 (0xA0-0xBF)
|
|||
|
|
**数据格式定义**
|
|||
|
|
字节序规范(小端序,与 STM32H7 一致)
|
|||
|
|
编码方式(ASCII 字符串、二进制数据、枚举值)
|
|||
|
|
数据结构定义
|
|||
|
|
用户信息结构
|
|||
|
|
设备状态结构
|
|||
|
|
参数配置结构
|
|||
|
|
传感器数据结构
|
|||
|
|
**响应格式定义**(基于 6.3 节响应格式)
|
|||
|
|
读操作响应(成功/失败)
|
|||
|
|
写操作响应(成功/失败)
|
|||
|
|
设备主动通知格式
|
|||
|
|
**错误码定义**(基于 6.3.4 节错误码定义)
|
|||
|
|
错误码列表
|
|||
|
|
错误原因说明
|
|||
|
|
错误处理建议
|
|||
|
|
**编写优先级**: 高(基础协议文档)
|
|||
|
|
7.2.2 OTA 升级协议详细规范.md
|
|||
|
|
**文档目的**: 定义 OTA 升级的详细协议和流程
|
|||
|
|
**目录结构**:
|
|||
|
|
**升级概述**
|
|||
|
|
OTA 功能说明(参考 5.1 节)
|
|||
|
|
升级架构(参考 5.2 节)
|
|||
|
|
**升级流程详细说明**(基于 5.3 节)
|
|||
|
|
升级前准备
|
|||
|
|
固件传输流程
|
|||
|
|
固件烧录流程
|
|||
|
|
升级后处理流程
|
|||
|
|
**数据包格式**(基于 6.2.8 节 OTA 升级类)
|
|||
|
|
查询OTA版本信息(命令 0x80,返回12字节:固件版本4 + 硬件版本4 + OTA版本4)
|
|||
|
|
开始升级(命令 0x81,接收版本号4 + 大小4,擦除Flash,写入文件头)
|
|||
|
|
传输固件数据(命令 0x82,接收序号2 + 数据N,写入Flash)
|
|||
|
|
结束传输(命令 0x83,接收总大小4,验证接收数据大小)
|
|||
|
|
结束传输(命令 0x83,接收总大小4,验证接收数据大小,保存CRC16到文件头,更新数据库OTA版本和force_boot标志)
|
|||
|
|
取消升级(命令 0x85,清除OTA状态)
|
|||
|
|
所有命令使用 6.1 节的通信帧结构
|
|||
|
|
**错误处理机制**
|
|||
|
|
升级过程中的错误处理
|
|||
|
|
错误恢复机制
|
|||
|
|
回滚机制
|
|||
|
|
**安全机制**(参考 5.4 节)
|
|||
|
|
固件签名验证
|
|||
|
|
版本验证
|
|||
|
|
权限验证
|
|||
|
|
**编写优先级**: 中(重要功能文档)
|
|||
|
|
7.2.3 错误码定义.md
|
|||
|
|
**文档目的**: 详细定义所有错误码及其处理方式
|
|||
|
|
**目录结构**:
|
|||
|
|
**错误码概述**
|
|||
|
|
错误码格式说明(参考 6.3.4 节)
|
|||
|
|
错误码分类
|
|||
|
|
**标准错误码列表**(基于 6.3.4 节)
|
|||
|
|
0x00: 成功
|
|||
|
|
0x01: 参数错误
|
|||
|
|
0x02: 权限错误
|
|||
|
|
0x03: 设备忙
|
|||
|
|
0x04: 命令不支持
|
|||
|
|
0x05: 数据校验失败
|
|||
|
|
0x06: 超时
|
|||
|
|
0x07: 设备错误
|
|||
|
|
每个错误码包含:
|
|||
|
|
错误码值
|
|||
|
|
错误含义
|
|||
|
|
错误原因说明
|
|||
|
|
错误处理建议
|
|||
|
|
典型场景示例
|
|||
|
|
**扩展错误码**(0x08-0xFF)
|
|||
|
|
保留用于未来扩展
|
|||
|
|
扩展错误码定义规范
|
|||
|
|
**错误处理流程**
|
|||
|
|
APP 端错误处理流程
|
|||
|
|
设备端错误处理流程
|
|||
|
|
错误恢复机制
|
|||
|
|
**编写优先级**: 高(基础协议文档)
|
|||
|
|
7.2.4 数据格式定义.md
|
|||
|
|
**文档目的**: 定义所有数据结构的详细格式
|
|||
|
|
**目录结构**:
|
|||
|
|
**数据格式概述**
|
|||
|
|
字节序规范(小端序)
|
|||
|
|
编码方式(ASCII、二进制、枚举)
|
|||
|
|
数据对齐规则
|
|||
|
|
**基础数据类型**
|
|||
|
|
单字节数据类型
|
|||
|
|
多字节数据类型(16位、32位)
|
|||
|
|
字符串类型
|
|||
|
|
枚举类型
|
|||
|
|
**数据结构定义**
|
|||
|
|
**用户信息结构**
|
|||
|
|
用户名(16字节,ASCII)
|
|||
|
|
指纹ID(1字节,uint8_t类型,0-255)
|
|||
|
|
指纹ID有效标志(1字节,0=无效,1=有效)
|
|||
|
|
设备状态结构
|
|||
|
|
工作模式(待机/扫描/消杀)
|
|||
|
|
硬件状态(正常/异常,包含错误状态)
|
|||
|
|
错误状态(错误码、错误描述,属于硬件状态)
|
|||
|
|
**参数配置结构**
|
|||
|
|
角度控制参数(2字节)
|
|||
|
|
距离控制参数(4字节)
|
|||
|
|
安全设置参数(开关、灵敏度、阈值等)
|
|||
|
|
**命令数据格式**(按命令分类)
|
|||
|
|
设备注册与认证类数据格式
|
|||
|
|
系统控制类数据格式
|
|||
|
|
外设控制类数据格式
|
|||
|
|
害虫消灭控制类数据格式
|
|||
|
|
安全设置类数据格式
|
|||
|
|
状态查询类数据格式
|
|||
|
|
**通知数据格式**(参考 6.3.3 节)
|
|||
|
|
各通知类型的数据格式
|
|||
|
|
通知数据示例
|
|||
|
|
**编写优先级**: 高(基础协议文档)
|
|||
|
|
7.2.5 文档关联关系
|
|||
|
|
**BLE ****通信协议详细**规范**.md** 是核心文档,其他文档作为补充
|
|||
|
|
错误码定义.md 和 数据格式定义.md 被 BLE 通信协议详细规范.md 引用
|
|||
|
|
**OTA ****升级协议详细规范.md** 是独立的功能文档,但遵循相同的协议结构
|
|||
|
|
7.2.6 文档维护和更新机制
|
|||
|
|
版本管理: 每个文档包含版本号,与主方案文档版本号关联
|
|||
|
|
兼容性: 新版本协议应向后兼容,文档中明确标注兼容性说明
|
|||
|
|
文档审核: 协议文档编写完成后,需与主方案文档(6.1-6.3 节)进行一致性检查
|
|||
|
|
**说明**:
|
|||
|
|
所有协议文档必须遵循 6.1 节的通信帧结构
|
|||
|
|
仅涉及 APP 与设备 BLE 通信协议,不涉及云端协议
|
|||
|
|
所有命令、响应、通知格式必须与 6.2 节和 6.3 节保持一致
|
|||
|
|
|
|||
|
|
| 版本 | 日期 | 更改内容 | 更改人 |
|
|||
|
|
|---|---|---|---|
|
|||
|
|
| V2.2 | 20260226 | 主要更新内容:
|
|||
|
|
补充补光灯控制指令;
|
|||
|
|
添加0X56环境变化检测以及试射测试指令;
|
|||
|
|
补充0XA1硬件状态说明
|
|||
|
|
部分0X80查询版本信息说明
|
|||
|
|
优化0XA3、0XA4指令协议 | |
|
|||
|
|
| v2.1 | 2025-12-25 | 主要更新内容:
|
|||
|
|
- 数据格式优化:角度字段精度提升,年份格式优化,定时任务格式改进
|
|||
|
|
- OTA升级流程完善:版本信息扩展,CRC校验优化,Flash存储优化
|
|||
|
|
- 通知机制优化:错误状态扩展为7字节,统计数据扩展为44字节,删除重复通知
|
|||
|
|
- 命令功能完善:合并重复命令,新增传感器数据查询命令,完善用户认证和指纹功能
|
|||
|
|
- 外设控制完善:LCD、RGB、WIFI等外设控制功能优化
|
|||
|
|
- 安全设置完善:毫米波雷达、视觉检测、加速度传感器等安全功能完善
|
|||
|
|
- 文档结构优化:修正工作状态定义,新增设备分享和多用户管理章节 | - |
|
|||
|
|
| V1.1 | 2025-11-11 | 修正工作状态定义:
|
|||
|
|
- 将"查询设备工作状态"改为"查询设备工作模式"
|
|||
|
|
- 工作模式仅保留三种:待机、扫描、消杀(移除运行、蓄能、停止、错误)
|
|||
|
|
- 将错误状态归类到硬件状态中
|
|||
|
|
- 更新所有相关章节和命令说明
|
|||
|
|
- 新增设备分享流程章节(4.1.5)
|
|||
|
|
- 新增多用户连接管理章节(4.9.2) | - |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x01 | 查询设备注册状态 | 读 | 返回设备是否已注册(1字节) | 设备首次连接时查询,判断是否需要注册 |
|
|||
|
|
| 0x02 | 设备注册绑定 | 写 | 用户名(16) | 设备首次注册时使用,APP将绑定关系存储到云端,仅发送用户名到设备 |
|
|||
|
|
| 0x03 | 用户登录(密码) | 写 | 用户名(16) + 解锁状态(1) | 已注册设备登录时使用(密码方式),APP云端验证通过后发送解锁状态 |
|
|||
|
|
| 0x04 | 指纹登录使能设置 | 写 | 用户名(16) + 使能状态(1) | 设置指定用户的指纹登录使能状态(0=禁用, 1=使能),需要设备已解锁 |
|
|||
|
|
| 0x05 | 指纹录制请求 | 写 | 用户名(16) | 启动指纹注册流程,需要设备已解锁
|
|||
|
|
功能:验证用户名,分配或使用已有的page_id,启动指纹注册状态机
|
|||
|
|
注册完成后自动更新数据库(finger_id和finger_id_valid字段) |
|
|||
|
|
| 0x06 | 保留 | - | - | 扩展用 |
|
|||
|
|
| 0x07 | 查询用户列表 | 读 | 返回用户列表 | 管理员查询设备绑定的所有用户信息 |
|
|||
|
|
| 0x08 | 注销用户 | 写 | 用户名(16) | 删除设备绑定的用户,需要设备已解锁
|
|||
|
|
功能:验证用户名,删除指纹模板(如果存在),删除用户信息
|
|||
|
|
如果删除后没有用户了,自动重置设备注册状态 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x10 | 语言设置 | 读/写 | 0x00=英文, 0x01=中文 | 用户个性化设置,更改设备显示语言 |
|
|||
|
|
| 0x11 | 时间设置 | 读/写 | 年(1) + 月(1) + 日(1) + 时(1) + 分(1) + 秒(1)
|
|||
|
|
年:1字节,相对于2000年的偏移(0-255对应2000-2255年) | 设备时间同步,用于定时功能 |
|
|||
|
|
| 0x12 | 定时任务设置 | 读/写 | 写:任务ID(1) + 开关(1) + 开始小时(1) + 开始分钟(1) + 结束小时(1) + 结束分钟(1) + 模式(1) + 重复(1)
|
|||
|
|
读:返回所有定时任务列表(最多5组,每组7字节)
|
|||
|
|
时间范围:0-23小时,0-59分钟
|
|||
|
|
重复:bit0周一,bit1周二,bit2周三,bit3周四,bit4周五,bit5周六,bit6周日 | 自动化控制,在指定时间范围内运行指定模式,支持按周重复,最多设置5组定时任务 |
|
|||
|
|
| 0x13-0x1F | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x20 | LCD 休眠设置 | 读/写 | 字节0:休眠开关(0x00=关, 0x01=开)
|
|||
|
|
字节1:休眠时间(0x01=1分钟, 0x05=5分钟, 0x0A=10分钟, 0x1E=30分钟) | 节能管理,设置LCD显示屏休眠开关和休眠时间 |
|
|||
|
|
| 0x21 | LCD 亮度设置 | 读/写 | 字节0:自适应开关(0x00=关闭自适应, 0x01=开启自适应)
|
|||
|
|
字节1:亮度值(10-100,仅在自适应关闭时有效) | 显示优化,设置LCD亮度自适应开关和亮度值 |
|
|||
|
|
| 0x22 | RGB 指示灯控制 | 读/写 | 开关(1) + R(1) + G(1) + B(1) + 效果(1) | 状态指示,个性化设置指示灯颜色和效果
|
|||
|
|
效果:0x00=闪烁, 0x01=常亮, 0x02=警示 |
|
|||
|
|
| 0x23 | WIFI 控制 | 读/写 | 读:65字节
|
|||
|
|
写:可变长度 | 网络配置,控制WIFI开关和连接信息
|
|||
|
|
读操作:返回65字节(开关1字节 + SSID 32字节 + 密码32字节)
|
|||
|
|
写操作:字节0为开关(0x00=关, 0x01=开),字节1-N为SSID字符串(以\0结尾,最多32字节,可选),字节N+1-M为密码字符串(以\0结尾,最多32字节,可选) |
|
|||
|
|
| 0x24 | BLE 控制 | 读/写 | 名称 | 蓝牙配置,设置BLE广播名称(BLE功能始终开启,不支持关闭) |
|
|||
|
|
| 0x25 | 多媒体控制 | 读/写 | 读:5字节
|
|||
|
|
写:可变长度 | 功能配置,控制视频录制和音效设置
|
|||
|
|
读操作:返回5字节(视频录制开关1字节 + 录制时长1字节 + 音效开关1字节 + 音效类型1字节 + 音量1字节)
|
|||
|
|
写操作:字节0为视频录制开关(0x00=关, 0x01=开),字节1为录制时长(1字节,0x03=3秒, 0x05=5秒, 0x0A=10秒),字节2为音效开关(0x00=关, 0x01=开),字节3为音效类型(0x00=Hello, 0x01=Goodbye, 0x02=Test, 0x03=BIU, 0x04=Main),字节4为音量(0-15,对应芯片E0-EF共16级) |
|
|||
|
|
| 0x26 | 补光灯控制 | 读/写 | 开关(1) + 类型(1) + 光照强度(1) | 夜间补光,控制补光灯开关、类型和光照强度 |
|
|||
|
|
| 0x27 | 查询补光灯连接状态 | 读 | 返回连接状态(0=未连接, 1=已连接) | 设备管理,查询补光灯外部设备连接状态 |
|
|||
|
|
| 0x28 | 可见光激光器控制 | 读/写 | 0x00=关, 0x01=开 | 激光控制,控制可见光激光器开关 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x40 | 角度控制 | 读/写 | 角度范围(2字节) | 扫描范围调整,设置激光扫描角度范围
|
|||
|
|
读操作:返回2字节(角度范围,小端序,单位:0.1度)
|
|||
|
|
写操作:接收2字节(角度范围,小端序,单位:0.1度)
|
|||
|
|
角度范围:1-900(对应0.1度-90度)(uint8_t)(angle_range & 0xFF); (uint8_t)((angle_range >> 8) & 0xFF); |
|
|||
|
|
| 0x41 | 距离控制 | 读/写 | 检测距离(2) + 瞄准距离(2) | 检测范围优化,设置害虫检测和瞄准距离 |
|
|||
|
|
| 0x42-0x4F | 保留 | - | - | 扩展用
|
|||
|
|
注:0x42(害虫类型)、0x43(启动/停止)、0x44(查询消灭状态)已删除 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x50 | 毫米波雷达设置 | 读/写 | 开关(1) + 灵敏度(1) + 距离(2) | 人体检测,配置毫米波雷达检测参数和安全距离
|
|||
|
|
读操作:返回4字节(开关1字节 + 灵敏度1字节 + 安全距离2字节)
|
|||
|
|
|
|||
|
|
写操作:接收4字节(开关1字节 + 灵敏度1字节 + 安全距离2字节)
|
|||
|
|
开关:0x00=关闭, 0x01=开启
|
|||
|
|
灵敏度:0x00=低, 0x01=中, 0x02=高
|
|||
|
|
安全距离:2字节,小端序,单位0.1米,范围1-100(0.1米-10米) |
|
|||
|
|
| 0x51 | 视觉检测设置 | 读/写 | 开关(1) + 灵敏度(1) | 安全检测,配置视觉检测开关和灵敏度
|
|||
|
|
读操作:返回2字节(开关1字节 + 灵敏度1字节)
|
|||
|
|
写操作:接收2字节(开关1字节 + 灵敏度1字节)
|
|||
|
|
开关:0x00=关闭, 0x01=开启
|
|||
|
|
灵敏度:0x00=低, 0x01=中, 0x02=高 |
|
|||
|
|
| 0x52 | 加速度传感器设置 | 读/写 | 开关(1) + 灵敏度(1) + 阈值(1) | 稳定性检测,配置振动检测参数,确保设备稳定放置
|
|||
|
|
读操作:返回3字节(开关1字节 + 灵敏度1字节 + 振动阈值1字节)
|
|||
|
|
写操作:接收3字节(开关1字节 + 灵敏度1字节 + 振动阈值1字节)
|
|||
|
|
开关:0x00=关闭, 0x01=开启
|
|||
|
|
灵敏度:0x00=低, 0x01=中, 0x02=高
|
|||
|
|
振动阈值:1-255 |
|
|||
|
|
| 0x53 | 查询加速度传感器数据 | 读 | 返回X(2) + Y(2) + Z(2)轴加速度值 | 数据监控,查询3轴加速度传感器实时数据
|
|||
|
|
读操作:返回6字节(X轴加速度2字节 + Y轴加速度2字节 + Z轴加速度2字节)
|
|||
|
|
数据格式:每个轴2字节,小端序,有符号整数(int16_t)
|
|||
|
|
单位:mg(毫重力加速度)
|
|||
|
|
数据范围:-32768到32767(对应-32768mg到32767mg) |
|
|||
|
|
| 0x54 | 保留 | - | - | 扩展用
|
|||
|
|
注:0x54(查询振动状态)、0x56(查询当前温度)、0x57(查询温度状态)的功能已合并到0xA5"查询设备传感器数据"中 |
|
|||
|
|
| 0x55 | 温度监控设置 | 读/写 | 告警阈值(1) + 停止阈值(1) + 开关(1) | 超温保护,设置温度告警和停止阈值 |
|
|||
|
|
| 0X56 | 环境变化检测和试射测试 | 读/写 | 1 | 读操作:返回1字节环境变化状态(0-没有变化,1-发生变化)
|
|||
|
|
写操作:触发激光进行3次试射测试,每次间隔1秒,每次持续10ms.写操作:0X01进行激光测试
|
|||
|
|
说明,仅用于触发测试 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x60 | 恢复出厂设置 | 写 | 需要管理员权限 | 设备管理,恢复设备到出厂默认状态(需管理员权限) |
|
|||
|
|
| 0x61-0x63 | 保留 | - | - | 已删除,功能已合并到0xA2命令中(参考2.9节) |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x70 | 断开连接 | 写 | 主动断开连接 | 连接管理,APP主动断开BLE连接 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x80 | 查询OTA版本信息 | 读 | 返回12字节版本信息(固件版本4 + 硬件版本4 + OTA版本4) | OTA升级,查询设备当前固件版本、硬件版本和OTA版本信息,用于升级前版本检查 |
|
|||
|
|
| 0x81 | 开始升级 | 写 | 版本号(4) + 大小(4) + CRC16(2) | OTA升级,启动固件升级流程
|
|||
|
|
功能:擦除1MB SPI Flash区域(地址0x100000),写入文件头(版本号、固件大小、CRC16占位为0),保存期望的CRC16
|
|||
|
|
数据格式:版本号(4字节小端序) + 固件大小(4字节小端序) + CRC16校验和(2字节小端序)
|
|||
|
|
Flash操作:擦除256个扇区(每个4KB),写入文件头10字节
|
|||
|
|
CRC16:从0x81命令接收,用于后续实时校验 |
|
|||
|
|
| 0x82 | 传输固件数据 | 写 | 数据包序号(2) + 数据(N) | OTA升级,分包传输固件数据包
|
|||
|
|
功能:将数据写入Flash,实时计算并累积CRC16,当所有数据接收完成时比较CRC16并设置force_boot标志
|
|||
|
|
数据格式:数据包序号(2字节小端序) + 数据(N字节)
|
|||
|
|
写入位置:从文件体起始地址(0x100000 + 10)开始顺序写入
|
|||
|
|
CRC16校验:实时累积计算CRC16,当所有数据接收完成时,如果CRC16匹配则设置force_boot=1(有效),否则设置force_boot=0(无效) |
|
|||
|
|
| 0x83 | 结束传输 | 写 | 总大小(4) | OTA升级,固件数据传输完成,确认总大小
|
|||
|
|
功能:验证接收数据大小是否匹配,保存CRC16到文件头并更新数据库
|
|||
|
|
数据格式:总大小(4字节小端序)
|
|||
|
|
验证:比较接收的总大小与已接收数据大小是否一致
|
|||
|
|
注意:CRC16校验已在0x82命令中完成,这里只验证大小并保存CRC16到文件头 |
|
|||
|
|
| 0x84 | 保留 | - | - | 已废弃,CRC校验功能已合并到0x82(传输固件数据)命令中,在数据接收时实时校验 |
|
|||
|
|
| 0x85 | 取消升级 | 写 | 取消标志(1) | OTA升级,取消正在进行的升级操作
|
|||
|
|
功能:清除OTA升级状态
|
|||
|
|
数据格式:取消标志(1字节,值任意) |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 指令名称 | 读/写 | 说明 | 备注 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0xA0 | 工作模式设置 | 读/写 | 读:返回1字节工作模式(0x00=待机, 0x01=扫描, 0x02=消杀)
|
|||
|
|
写:接收1字节工作模式(0x00=待机, 0x01=扫描, 0x02=消杀) | 状态监控和控制,查询或设置设备当前工作模式 |
|
|||
|
|
| 0xA1 | 查询硬件状态 | 读 | 返回7字节硬件错误状态
|
|||
|
|
数据格式:温度错误(1) + 电机错误(1) + 激光器错误(1) + 视觉错误(1) + 加速度错误(1) + 毫米波雷达错误(1) + 激光雷达错误(1)
|
|||
|
|
数据来源:meas_ctrl.error | 硬件监控,查询各硬件模块的错误状态 |
|
|||
|
|
| 0xA2 | 查询设备信息 | 读/写 | 读:返回76字节设备信息
|
|||
|
|
写:接收56字节设备信息
|
|||
|
|
读数据格式:设备序列号(16) + 设备型号(16) + 设备ID(16) + BLE MAC地址(6) + WiFi MAC地址(6) + 固件版本(4) + 硬件版本(4) + OTA版本(4)
|
|||
|
|
写数据格式:设备序列号(16) + 设备型号(16) + 设备ID(16) + 固件版本(4) + 硬件版本(4)
|
|||
|
|
数据来源/存储:db_cfg.device_info | 设备信息查询和设置,查询或设置设备基本信息(序列号、型号、ID、版本信息等) |
|
|||
|
|
| 0xA3 | 查询统计数据 | 读 | 返回32字节(统计数据24字节 + datalog日志信息154字节)
|
|||
|
|
统计数据:灭虫数量(4) + 总工作时间(4) + 今日工作时间(4) + 扫描次数(4) + 激光发射次数(4) + 蚊虫数据数量(4)+本地记录(4) | 数据统计,查询设备工作统计数据和历史日志索引 |
|
|||
|
|
| 0xA4 | 查询蚊虫数据 | 读/写 | 写:接收8字节(start_index 4字节 + end_index 4字节,小端序)
|
|||
|
|
如果start_index=0xFFFFFFFF,表示读取全部数据
|
|||
|
|
读:返回当前设置的索引范围(start_index 4字节 + end_index 4字节)
|
|||
|
|
数据发送:通过通知机制(通知类型0x0B)发送每条蚊虫数据(22字节:索引4字节 + 数据18字节),每条数据间隔10ms
|
|||
|
|
数据来源:SPI Flash | 数据查询,从SPI Flash读取指定索引范围的蚊虫数据 |
|
|||
|
|
| 0xA5 | 查询设备传感器数据 | 读 | 返回10字节传感器数据
|
|||
|
|
数据格式:温度(2字节,单位:0.1°C) + X轴加速度(2字节,单位:mg) + Y轴加速度(2字节,单位:mg) + Z轴加速度(2字节,单位:mg) + 电容电压(2字节,单位:0.01V)
|
|||
|
|
数据来源:meas_ctrl.temp、meas_ctrl.accel、capture_get_laser_gun_dev()->current_voltage | 传感器数据查询,一次性获取设备温度、3D传感器数据和电容电压 |
|
|||
|
|
| 0xA6-0xBF | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 帧头 | 命令 | 读/写 | 长度 | 数据 | 校验 |
|
|||
|
|
|---|---|---|---|---|---|
|
|||
|
|
| 2字节 | 1字节 | 1字节 | 1字节 | N字节 | 2字节 |
|
|||
|
|
| 固定标识 0xAA 0x55,标识 BLE 通信数据包 | 命令码(0x01-0xFF),标识具体操作类型 | 操作类型标识:0x00=读操作,0x01=写操作,0x02=通知 | 数据字段长度(0-255 字节) | 命令参数或响应数据(可变长度) | CRC16 校验(LSB + MSB),校验范围:帧头到数据字段的所有字节 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x01 | 查询设备注册状态 | 读 | 1 | 返回设备是否已注册 |
|
|||
|
|
| 0x02 | 设备注册绑定 | 写 | 16 | 用户名(16),绑定关系存储在云端 |
|
|||
|
|
| 0x03 | 用户登录(密码) | 写 | 17 | 用户名(16) + 解锁状态(1),APP云端验证后发送 |
|
|||
|
|
| 0x04 | 指纹登录使能设置 | 写 | 17 | 用户名(16) + 使能状态(1),使能状态:0x00=禁用, 0x01=使能 |
|
|||
|
|
| 0x05 | 指纹录制请求 | 写 | 16 | 用户名(16)
|
|||
|
|
功能:启动指纹注册流程
|
|||
|
|
- 验证用户名是否存在
|
|||
|
|
- 确定page_id:如果用户已有finger_id,使用它重新注册;否则分配新的page_id
|
|||
|
|
- 检查指纹库是否已满
|
|||
|
|
- 启动指纹注册状态机(异步处理)
|
|||
|
|
- 注册成功后自动更新数据库(finger_id和finger_id_valid字段)
|
|||
|
|
权限要求:需要设备已解锁,且不能有注册正在进行中
|
|||
|
|
错误码:用户不存在(0x03)、权限拒绝(0x02)、设备错误(0x07)
|
|||
|
|
说明:注册状态可通过查询用户列表(0x07)查看finger_id_valid字段 |
|
|||
|
|
| 0x06 | 保留 | - | - | 扩展用 |
|
|||
|
|
| 0x07 | 查询用户列表 | 读 | 可变 | 返回用户列表
|
|||
|
|
数据格式:用户数量(1字节) + 每个用户:用户名(16字节) + 指纹ID(1字节) + 指纹ID有效标志(1字节)
|
|||
|
|
说明:指纹ID为uint8_t类型(0-255),指纹ID有效标志:0=无效,1=有效 |
|
|||
|
|
| 0x08 | 注销用户 | 写 | 16 | 用户名(16)
|
|||
|
|
功能:删除设备绑定的用户
|
|||
|
|
- 验证用户名是否存在
|
|||
|
|
- 如果用户有有效的指纹ID(finger_id_valid == 1),删除指纹库中对应的模板
|
|||
|
|
- 删除用户信息(用户名、指纹ID、登录时间等)
|
|||
|
|
- 检查是否还有用户存在,如果没有用户了,重置设备注册状态(registered = 0)
|
|||
|
|
- 保存数据库
|
|||
|
|
权限要求:需要设备已解锁
|
|||
|
|
错误码:用户不存在(0x03)、权限拒绝(0x02)、设备错误(0x07) |
|
|||
|
|
| 0x09-0x0F | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x10 | 语言设置 | 读/写 | 1 | 0x00=英文, 0x01=中文 |
|
|||
|
|
| 0x11 | 时间设置 | 读/写 | 6 | 年(1) + 月(1) + 日(1) + 时(1) + 分(1) + 秒(1)
|
|||
|
|
年:1字节,相对于2000年的偏移(0-255对应2000-2255年) |
|
|||
|
|
| 0x12 | 定时任务设置 | 读/写 | 写:8
|
|||
|
|
读:可变(最多35) | 写:任务ID(1) + 开关(1) + 开始小时(1) + 开始分钟(1) + 结束小时(1) + 结束分钟(1) + 模式(1) + 重复(1)
|
|||
|
|
任务ID:0-4(对应数组索引)
|
|||
|
|
开关:0x00=禁用, 0x01=启用
|
|||
|
|
开始小时:0-23
|
|||
|
|
开始分钟:0-59
|
|||
|
|
结束小时:0-23
|
|||
|
|
结束分钟:0-59
|
|||
|
|
模式:待机(0x00,用于定时关机)、扫描(0x01)、消杀(0x02)
|
|||
|
|
重复:1字节,按位表示星期几重复执行
|
|||
|
|
- bit0: 周一 (0x01)
|
|||
|
|
- bit1: 周二 (0x02)
|
|||
|
|
- bit2: 周三 (0x04)
|
|||
|
|
- bit3: 周四 (0x08)
|
|||
|
|
- bit4: 周五 (0x10)
|
|||
|
|
- bit5: 周六 (0x20)
|
|||
|
|
- bit6: 周日 (0x40)
|
|||
|
|
读:返回所有定时任务列表(最多5组,每组7字节=开关+开始小时+开始分钟+结束小时+结束分钟+模式+重复) |
|
|||
|
|
| 0x13-0x1F | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x20 | LCD 休眠设置 | 读/写 | 2 | 字节0:休眠开关(0x00=关, 0x01=开)
|
|||
|
|
字节1:休眠时间(0x01=1分钟, 0x05=5分钟, 0x0A=10分钟, 0x1E=30分钟) |
|
|||
|
|
| 0x21 | LCD 亮度设置 | 读/写 | 2 | 字节0:自适应开关(0x00=关闭自适应, 0x01=开启自适应)
|
|||
|
|
字节1:亮度值(10-100,仅在自适应关闭时有效) |
|
|||
|
|
| 0x22 | RGB 指示灯控制 | 读/写 | 5 | 开关(1) + R(1) + G(1) + B(1) + 效果(1)
|
|||
|
|
效果:0x00=闪烁, 0x01=常亮, 0x02=警示 |
|
|||
|
|
| 0x23 | WIFI 控制 | 读/写 | 读:65
|
|||
|
|
写:可变 | 读操作:返回65字节(开关1字节 + SSID 32字节 + 密码32字节)
|
|||
|
|
写操作:字节0为开关(0x00=关, 0x01=开),字节1-N为SSID字符串(以\0结尾,最多32字节,可选),字节N+1-M为密码字符串(以\0结尾,最多32字节,可选)
|
|||
|
|
说明:写操作至少需要1字节(开关),SSID和密码为可选字段 |
|
|||
|
|
| 0x24 | BLE 控制 | 读/写 | 可变 | 名称,BLE功能始终开启,不支持关闭 |
|
|||
|
|
| 0x25 | 多媒体控制 | 读/写 | 读:5
|
|||
|
|
写:可变 | 读操作:返回5字节(视频录制开关1字节 + 录制时长1字节 + 音效开关1字节 + 音效类型1字节 + 音量1字节)
|
|||
|
|
写操作:字节0为视频录制开关(0x00=关, 0x01=开),字节1为录制时长(1字节,0x03=3秒, 0x05=5秒, 0x0A=10秒),字节2为音效开关(0x00=关, 0x01=开),字节3为音效类型(0x00=Hello, 0x01=Goodbye, 0x02=Test, 0x03=BIU, 0x04=Main),字节4为音量(0-15)
|
|||
|
|
说明:写操作至少需要1字节(视频录制开关),其他字段为可选 |
|
|||
|
|
| 0x26 | 补光灯控制 | 读/写 | 3 | 开关(1) + 类型(1) + 光照强度(1)
|
|||
|
|
类型:0-红外光;1-白光;
|
|||
|
|
光照强度:0-低、1-中、2-高 |
|
|||
|
|
| 0x27 | 查询补光灯连接状态 | 读 | 1 | 返回连接状态(0=未连接, 1=已连接) |
|
|||
|
|
| 0x28 | 可见光激光器控制 | 读/写 | 1 | 0x00=关, 0x01=开 |
|
|||
|
|
| 0x29-0x3F | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x40 | 角度控制 | 读/写 | 2 | 读操作:返回2字节(角度范围,小端序,单位:0.1度)
|
|||
|
|
写操作:接收2字节(角度范围,小端序,单位:0.1度)
|
|||
|
|
角度范围:1-900(对应0.1度-90度)
|
|||
|
|
说明:数据格式为小端序(低字节在前,高字节在后) |
|
|||
|
|
| 0x41 | 距离控制 | 读/写 | 4 | 检测距离(2) + 瞄准距离(2) |
|
|||
|
|
| 0x42-0x4F | 保留 | - | - | 扩展用
|
|||
|
|
注:0x42(害虫类型)、0x43(启动/停止)、0x44(查询消灭状态)已删除 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x50 | 毫米波雷达设置 | 读/写 | 4 | 读操作:返回4字节(开关1字节 + 灵敏度1字节 + 安全距离2字节)
|
|||
|
|
写操作:接收4字节(开关1字节 + 灵敏度1字节 + 安全距离2字节)
|
|||
|
|
开关:0x00=关闭, 0x01=开启
|
|||
|
|
灵敏度:0x00=低, 0x01=中, 0x02=高
|
|||
|
|
安全距离:2字节,小端序,单位0.1米,范围1-100(0.1米-10米)
|
|||
|
|
说明:数据格式为小端序(低字节在前,高字节在后) |
|
|||
|
|
| 0x51 | 视觉检测设置 | 读/写 | 2 | 读操作:返回2字节(开关1字节 + 灵敏度1字节)
|
|||
|
|
写操作:接收2字节(开关1字节 + 灵敏度1字节)
|
|||
|
|
开关:0x00=关闭, 0x01=开启
|
|||
|
|
灵敏度:0x00=低, 0x01=中, 0x02=高 |
|
|||
|
|
| 0x52 | 加速度传感器设置 | 读/写 | 3 | 读操作:返回3字节(开关1字节 + 灵敏度1字节 + 振动阈值1字节)
|
|||
|
|
写操作:接收3字节(开关1字节 + 灵敏度1字节 + 振动阈值1字节)
|
|||
|
|
开关:0x00=关闭, 0x01=开启
|
|||
|
|
灵敏度:0x00=低, 0x01=中, 0x02=高
|
|||
|
|
振动阈值:1-255 |
|
|||
|
|
| 0x53 | 查询加速度传感器数据 | 读 | 6 | 读操作:返回6字节(X轴加速度2字节 + Y轴加速度2字节 + Z轴加速度2字节)
|
|||
|
|
数据格式:每个轴2字节,小端序,有符号整数(int16_t)
|
|||
|
|
单位:mg(毫重力加速度)
|
|||
|
|
数据范围:-32768到32767(对应-32768mg到32767mg)
|
|||
|
|
说明:数据格式为小端序(低字节在前,高字节在后),有符号整数 |
|
|||
|
|
| 0x54 | 保留 | - | - | 扩展用
|
|||
|
|
注:0x54(查询振动状态)、0x56(查询当前温度)、0x57(查询温度状态)的功能已合并到0xA5"查询设备传感器数据"中 |
|
|||
|
|
| 0x55 | 温度监控设置 | 读/写 | 3 | 告警阈值(1) + 停止阈值(1) + 开关(1) |
|
|||
|
|
| 0X56 | 环境变化检测和试射测试 | 读/写 | 1 | 读操作:返回1字节环境变化状态(0-没有变化,1-发生变化)
|
|||
|
|
写操作:触发激光进行3次试射测试,每次间隔1秒,每次持续10ms.写操作:0X01进行激光测试
|
|||
|
|
说明,仅用于触发测试 |
|
|||
|
|
| 0x57-0x5F | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x60 | 恢复出厂设置 | 写 | 1 | 需要管理员权限 |
|
|||
|
|
| 0x61-0x63 | 保留 | - | - | 已删除,功能已合并到0xA2命令中 |
|
|||
|
|
| 0x64-0x6F | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x70 | 断开连接 | 写 | 1 | 主动断开连接 |
|
|||
|
|
| 0x71-0x7F | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0x80 | 查询OTA版本信息 | 读 | 12 | 读操作:返回12字节版本信息
|
|||
|
|
数据格式(12字节,小端序):
|
|||
|
|
字节0-3:固件版本(uint32_t,4字节小端序)
|
|||
|
|
字节4-7:硬件版本(uint32_t,4字节小端序)
|
|||
|
|
字节8-11:OTA版本(uint32_t,4字节小端序)
|
|||
|
|
数据来源:db_cfg.device_info
|
|||
|
|
uint32_t:99999999表示版本号:99.99.99;1表示版本号00.00.00.01;
|
|||
|
|
写操作:不支持
|
|||
|
|
错误码:命令不支持(0x04) |
|
|||
|
|
| 0x81 | 开始升级 | 写 | 10 | 写操作:接收10字节(版本号4 + 大小4 + CRC16 2)
|
|||
|
|
数据格式(10字节,小端序):
|
|||
|
|
字节0-3:版本号(uint32_t,4字节小端序)
|
|||
|
|
字节4-7:固件大小(uint32_t,4字节小端序,单位:字节)
|
|||
|
|
字节8-9:CRC16校验和(uint16_t,2字节小端序)
|
|||
|
|
|
|||
|
|
功能说明:
|
|||
|
|
1. 验证参数:检查固件大小是否有效(0 < 大小 <= 1MB-10字节)
|
|||
|
|
2. 检查状态:如果已有升级在进行,返回设备错误
|
|||
|
|
3. 擦除Flash:擦除1MB SPI Flash区域(地址0x100000,256个扇区,每个4KB)
|
|||
|
|
4. 写入文件头:版本号(4) + 固件大小(4) + CRC16(2,占位为0) = 10字节
|
|||
|
|
5. 初始化状态:设置OTA升级状态跟踪,保存期望的CRC16到状态结构
|
|||
|
|
6. 初始化force_boot:设置db_cfg.device_info.force_boot=0(初始为无效)
|
|||
|
|
|
|||
|
|
错误码:参数无效(0x01)、设备错误(0x07) |
|
|||
|
|
| 0x82 | 传输固件数据 | 写 | 可变 | 写操作:接收可变长度(数据包序号2 + 数据N)
|
|||
|
|
数据格式(可变长度,小端序):
|
|||
|
|
字节0-1:数据包序号(uint16_t,2字节小端序)
|
|||
|
|
字节2-N:固件数据(N字节)
|
|||
|
|
|
|||
|
|
功能说明:
|
|||
|
|
1. 检查状态:如果升级未开始,返回设备错误
|
|||
|
|
2. 验证数据:检查数据大小是否超出固件大小,检查写入地址是否超出范围
|
|||
|
|
3. 写入Flash:将数据写入Flash(从文件体起始地址0x10000A开始顺序写入)
|
|||
|
|
4. 实时计算CRC16:对接收的数据实时计算并累积CRC16(CRC16-CCITT算法,多项式0x1021,初始值0xFFFF)
|
|||
|
|
5. 更新状态:更新已接收数据大小和当前写入地址
|
|||
|
|
6. CRC16校验:当所有数据接收完成时(received_size >= firmware_size),比较计算的CRC16与期望的CRC16
|
|||
|
|
- 如果CRC16匹配:设置db_cfg.device_info.force_boot=1(固件有效)
|
|||
|
|
- 如果CRC16不匹配:设置db_cfg.device_info.force_boot=0(固件无效)
|
|||
|
|
7. 返回状态:返回成功响应,上位机继续发送下一帧数据
|
|||
|
|
|
|||
|
|
错误码:参数无效(0x01)、设备错误(0x07) |
|
|||
|
|
| 0x83 | 结束传输 | 写 | 4 | 写操作:接收4字节(总大小4)
|
|||
|
|
数据格式(4字节,小端序):
|
|||
|
|
字节0-3:总大小(uint32_t,4字节小端序,单位:字节)
|
|||
|
|
|
|||
|
|
功能说明:
|
|||
|
|
1. 检查状态:如果升级未开始,返回设备错误
|
|||
|
|
2. 验证大小:比较接收的总大小与已接收数据大小是否一致
|
|||
|
|
3. 保存CRC16:保存计算的CRC16到文件头(偏移8字节处)
|
|||
|
|
4. 更新数据库:更新数据库OTA版本(db_cfg.device_info.ota_version)和force_boot标志(db_cfg.device_info.force_boot)
|
|||
|
|
5. 保存数据库:保存数据库到非易失性存储
|
|||
|
|
6. 清除状态:清除OTA升级状态跟踪
|
|||
|
|
7. 返回响应:返回成功响应
|
|||
|
|
|
|||
|
|
注意:CRC16校验已在0x82命令中完成,这里只验证大小并保存CRC16到文件头
|
|||
|
|
|
|||
|
|
错误码:参数无效(0x01)、设备错误(0x07) |
|
|||
|
|
| 0x84 | 保留 | - | - | 已废弃:此命令已废弃,CRC校验功能已合并到0x82(传输固件数据)命令中,在数据接收时实时校验 |
|
|||
|
|
| 0x85 | 取消升级 | 写 | 1 | 写操作:接收1字节(取消标志)
|
|||
|
|
数据格式(1字节):
|
|||
|
|
字节0:取消标志(uint8_t,值任意)
|
|||
|
|
|
|||
|
|
功能说明:
|
|||
|
|
1. 清除状态:清除OTA升级状态跟踪
|
|||
|
|
2. 返回成功:即使没有升级在进行,也返回成功
|
|||
|
|
|
|||
|
|
错误码:参数无效(0x01) |
|
|||
|
|
| 0x86-0x9F | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 命令码 | 命令名称 | 读/写 | 数据长度 | 说明 |
|
|||
|
|
|---|---|---|---|---|
|
|||
|
|
| 0xA0 | 工作模式设置 | 读/写 | 1 | 读:返回1字节工作模式(0x00=待机, 0x01=扫描, 0x02=消杀)
|
|||
|
|
写:接收1字节工作模式(0x00=待机, 0x01=扫描, 0x02=消杀)
|
|||
|
|
数据来源/存储:db_cfg.system.work_mode |
|
|||
|
|
| 0xA1 | 查询硬件状态 | 读 | 7 | 返回7字节硬件错误状态
|
|||
|
|
字节0:温度错误(0x00=无错误, 0x01=温度过高, 0x02=温度过低)
|
|||
|
|
字节1:电机错误(0x00=无错误, 0x01=温度错误, 0x02=反馈错误)
|
|||
|
|
字节2:激光器错误(0x00=无错误, 0x01=温度过高, 0x02=电压过低, 0x03=电压过高)
|
|||
|
|
字节3:视觉错误(0x00=无错误, 0x01=通信错误)
|
|||
|
|
字节4:加速度错误(0x00=无错误, 0x01=通信错误,0X02=设备不稳定)
|
|||
|
|
字节5:毫米波雷达错误(0x00=无错误, 0x01=通信错误)
|
|||
|
|
字节6:激光雷达错误(0x00=无错误, 0x01=通信错误)
|
|||
|
|
数据来源:meas_ctrl.error(测量控制模块的错误状态) |
|
|||
|
|
| 0xA2 | 查询设备信息 | 读/写 | 读:76
|
|||
|
|
写:56 | 读操作:返回76字节设备信息
|
|||
|
|
数据格式(76字节,小端序):
|
|||
|
|
字节0-15:设备序列号(16字节,ASCII编码)
|
|||
|
|
字节16-31:设备型号(16字节,ASCII编码)
|
|||
|
|
字节32-47:设备ID(16字节,ASCII编码)
|
|||
|
|
字节48-53:BLE MAC地址(6字节)
|
|||
|
|
字节54-59:WiFi MAC地址(6字节)
|
|||
|
|
字节60-63:固件版本(uint32_t,4字节小端序)
|
|||
|
|
字节64-67:硬件版本(uint32_t,4字节小端序)
|
|||
|
|
字节68-71:OTA版本(uint32_t,4字节小端序)
|
|||
|
|
数据来源:db_cfg.device_info
|
|||
|
|
|
|||
|
|
写操作:接收56字节设备信息
|
|||
|
|
数据格式(56字节,小端序):
|
|||
|
|
字节0-15:设备序列号(16字节,ASCII编码)
|
|||
|
|
字节16-31:设备型号(16字节,ASCII编码)
|
|||
|
|
字节32-47:设备ID(16字节,ASCII编码)
|
|||
|
|
字节48-51:固件版本(uint32_t,4字节小端序)
|
|||
|
|
字节52-55:硬件版本(uint32_t,4字节小端序)
|
|||
|
|
数据存储:db_cfg.device_info |
|
|||
|
|
| 0xA3 | 查询统计数据 | 读 | 32 | 返回32字节(统计数据24字节 + datalog日志信息4字节)
|
|||
|
|
统计数据部分(24字节,小端序):
|
|||
|
|
字节0-3:灭虫数量(uint32_t)
|
|||
|
|
字节4-7:总工作时间(uint32_t,单位:秒)
|
|||
|
|
字节8-11:今日工作时间(uint32_t,单位:秒)
|
|||
|
|
字节12-15:扫描次数(uint32_t)
|
|||
|
|
字节16-19:激光发射次数(uint32_t)
|
|||
|
|
字节20-23:蚊虫数据数量(uint32_t,扫描到、杀了的蚊子总数)
|
|||
|
|
|
|||
|
|
datalog日志信息部分(4字节):
|
|||
|
|
字节24-27:设备本地数据条数。 |
|
|||
|
|
| 0xA4 | 查询蚊虫数据 | 读/写 | 写:4
|
|||
|
|
读:4
|
|||
|
|
通知:22 | 写操作:接收4字节(读取的数量,小端序)
|
|||
|
|
- 写操作成功后,设备通过通知机制发送数据,先发送成功响应,然后发送每条数据
|
|||
|
|
读操作:返回4字节(设备本地数据条数,小端序)
|
|||
|
|
数据发送(通知机制):
|
|||
|
|
- 通知类型:0x0B(蚊虫数据通知)
|
|||
|
|
- 每条通知数据:22字节 = 索引(4字节小端序) + 蚊虫数据(18字节)
|
|||
|
|
- 蚊虫数据结构:角度(4字节,*1000度,int32_t,支持负数,例如90000表示90.000度,-22500表示-22.500度) + 距离(2字节,毫米) + 大小(2字节,毫米) + 时间(6字节:year+month+day+hour+minute+second) + 保留(4字节)
|
|||
|
|
- 每条数据间隔:10ms
|
|||
|
|
数据来源:SPI Flash(从SPI_FLASH_MOSQUITO_DATA_ADDR开始存储,每条数据16字节,其中角度字段为int32_t) |
|
|||
|
|
| 0xA5 | 查询设备传感器数据 | 读 | 10 | 读操作:返回10字节传感器数据
|
|||
|
|
数据格式(10字节,小端序):
|
|||
|
|
字节0-1:温度(uint16_t,单位:0.1°C,例如250表示25.0°C)
|
|||
|
|
字节2-3:X轴加速度(int16_t,单位:mg,有符号整数,范围:-32768到32767)
|
|||
|
|
字节4-5:Y轴加速度(int16_t,单位:mg,有符号整数,范围:-32768到32767)
|
|||
|
|
字节6-7:Z轴加速度(int16_t,单位:mg,有符号整数,范围:-32768到32767)
|
|||
|
|
字节8-9:电容电压(uint16_t,单位:0.01V,例如1530表示15.30V)
|
|||
|
|
数据来源:
|
|||
|
|
- 温度:meas_ctrl.temp(测量控制模块的温度值,单位:°C)
|
|||
|
|
- 3D传感器数据:meas_ctrl.accel.x_mg、y_mg、z_mg(测量控制模块的加速度数据,单位:mg)
|
|||
|
|
- 电容电压:capture_get_laser_gun_dev()->current_voltage(激光器设备的当前电容电压,单位:V)
|
|||
|
|
说明:
|
|||
|
|
- 如果无法获取电容电压(设备未初始化或读取失败),电容电压字段返回0
|
|||
|
|
- 数据格式为小端序(低字节在前,高字节在后)
|
|||
|
|
- 写操作不支持,返回命令不支持错误 |
|
|||
|
|
| 0xA6-0xBF | 保留 | - | - | 扩展用 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 帧头 | 命令 | 读/写 | 长度 | 数据 | 校验 |
|
|||
|
|
|---|---|---|---|---|---|
|
|||
|
|
| 2字节 | 1字节 | 1字节(0x00) | 1字节 | N字节 | 2字节 |
|
|||
|
|
| 固定标识 0xAA 0x55 | 原命令码 | 读操作标识 | 数据长度 | 状态码(1字节, 0x00=成功) + 响应数据 | CRC16校验 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 帧头 | 命令 | 读/写 | 长度 | 数据 | 校验 |
|
|||
|
|
|---|---|---|---|---|---|
|
|||
|
|
| 2字节 | 1字节 | 1字节(0x00) | 1字节 | N字节 | 2字节 |
|
|||
|
|
| 固定标识 0xAA 0x55 | 原命令码 | 读操作标识 | 数据长度 | 状态码(1字节, 非0=错误码) + 错误描述(可选) | CRC16校验 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 帧头 | 命令 | 读/写 | 长度 | 数据 | 校验 |
|
|||
|
|
|---|---|---|---|---|---|
|
|||
|
|
| 2字节 | 1字节 | 1字节(0x01) | 1字节 | N字节 | 2字节 |
|
|||
|
|
| 固定标识 0xAA 0x55 | 原命令码 | 写操作标识 | 数据长度 | 状态码(1字节, 0x00=成功) + 确认信息(可选) | CRC16校验 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 帧头 | 命令 | 读/写 | 长度 | 数据 | 校验 |
|
|||
|
|
|---|---|---|---|---|---|
|
|||
|
|
| 2字节 | 1字节 | 1字节(0x01) | 1字节 | N字节 | 2字节 |
|
|||
|
|
| 固定标识 0xAA 0x55 | 原命令码 | 写操作标识 | 数据长度 | 状态码(1字节, 非0=错误码) + 错误描述(可选) | CRC16校验 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 帧头 | 通知码 | 读/写 | 长度 | 数据 | 校验 |
|
|||
|
|
|---|---|---|---|---|---|
|
|||
|
|
| 2字节 | 1字节 | 1字节(0x02) | 1字节 | N字节 | 2字节 |
|
|||
|
|
| 固定标识 0xAA 0x55 | 通知码(与命令码区分) | 通知标识 | 数据长度 | 通知类型(1字节) + 通知数据 | CRC16校验 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 错误码 | 含义 | 说明 |
|
|||
|
|
|---|---|---|
|
|||
|
|
| 0x00 | 成功 | 操作成功 |
|
|||
|
|
| 0x01 | 参数错误 | 参数无效或超出范围 |
|
|||
|
|
| 0x02 | 权限错误 | 用户未登录或权限不足 |
|
|||
|
|
| 0x03 | 设备忙 | 设备正在执行其他操作 |
|
|||
|
|
| 0x04 | 命令不支持 | 命令码不存在或未实现 |
|
|||
|
|
| 0x05 | 数据校验失败 | CRC 校验失败 |
|
|||
|
|
| 0x06 | 超时 | 操作超时 |
|
|||
|
|
| 0x07 | 设备错误 | 设备内部错误 |
|
|||
|
|
| 0x08-0xFF | 保留 | 扩展错误码 |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 字节序号 | 字段名 | 字节数 | 值/说明 |
|
|||
|
|
|---|---|---|---|
|
|||
|
|
| 0-1 | 帧头 | 2 | 0xAA 0x55 |
|
|||
|
|
| 2 | 命令 | 1 | 0x01 |
|
|||
|
|
| 3 | 读/写 | 1 | 0x00(读操作) |
|
|||
|
|
| 4 | 长度 | 1 | 0x00(无数据) |
|
|||
|
|
| 5-6 | 校验 | 2 | CRC16(字节0-4) |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 字节序号 | 字段名 | 字节数 | 值/说明 |
|
|||
|
|
|---|---|---|---|
|
|||
|
|
| 0-1 | 帧头 | 2 | 0xAA 0x55 |
|
|||
|
|
| 2 | 命令 | 1 | 0x02 |
|
|||
|
|
| 3 | 读/写 | 1 | 0x01(写操作) |
|
|||
|
|
| 4 | 长度 | 1 | 0x10(16字节) |
|
|||
|
|
| 5-20 | 数据 | 16 | 用户名(ASCII编码,不足用0x00填充) |
|
|||
|
|
| 21-22 | 校验 | 2 | CRC16(字节0-20) |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 字节序号 | 字段名 | 字节数 | 值/说明 |
|
|||
|
|
|---|---|---|---|
|
|||
|
|
| 0-1 | 帧头 | 2 | 0xAA 0x55 |
|
|||
|
|
| 2 | 命令 | 1 | 0x01(原命令码) |
|
|||
|
|
| 3 | 读/写 | 1 | 0x00(读操作) |
|
|||
|
|
| 4 | 长度 | 1 | 0x02(2字节数据) |
|
|||
|
|
| 5 | 状态码 | 1 | 0x00(成功) |
|
|||
|
|
| 6 | 响应数据 | 1 | 0x01(已注册) |
|
|||
|
|
| 7-8 | 校验 | 2 | CRC16(字节0-6) |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 字节序号 | 字段名 | 字节数 | 值/说明 |
|
|||
|
|
|---|---|---|---|
|
|||
|
|
| 0-1 | 帧头 | 2 | 0xAA 0x55 |
|
|||
|
|
| 2 | 命令 | 1 | 0x02(原命令码) |
|
|||
|
|
| 3 | 读/写 | 1 | 0x01(写操作) |
|
|||
|
|
| 4 | 长度 | 1 | 0x01(1字节数据) |
|
|||
|
|
| 5 | 状态码 | 1 | 0x00(成功) |
|
|||
|
|
| 6-7 | 校验 | 2 | CRC16(字节0-5) |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 字节序号 | 字段名 | 字节数 | 值/说明 |
|
|||
|
|
|---|---|---|---|
|
|||
|
|
| 0-1 | 帧头 | 2 | 0xAA 0x55 |
|
|||
|
|
| 2 | 命令 | 1 | 0x02(原命令码) |
|
|||
|
|
| 3 | 读/写 | 1 | 0x01(写操作) |
|
|||
|
|
| 4 | 长度 | 1 | 0x01(1字节数据) |
|
|||
|
|
| 5 | 状态码 | 1 | 0x01(参数错误) |
|
|||
|
|
| 6-7 | 校验 | 2 | CRC16(字节0-5) |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 字节序号 | 字段名 | 字节数 | 值/说明 |
|
|||
|
|
|---|---|---|---|
|
|||
|
|
| 0-1 | 帧头 | 2 | 0xAA 0x55 |
|
|||
|
|
| 2 | 通知码 | 1 | 0xF0(示例通知码) |
|
|||
|
|
| 3 | 读/写 | 1 | 0x02(通知) |
|
|||
|
|
| 4 | 长度 | 1 | 0x02(2字节数据) |
|
|||
|
|
| 5 | 通知类型 | 1 | 0x01(设备状态变化) |
|
|||
|
|
| 6 | 状态码 | 1 | 0x01(扫描模式) |
|
|||
|
|
| 7-8 | 校验 | 2 | CRC16(字节0-6) |
|
|||
|
|
|
|||
|
|
|
|||
|
|
| 字节序号 | 字段名 | 字节数 | 值/说明 |
|
|||
|
|
|---|---|---|---|
|
|||
|
|
| 0-1 | 帧头 | 2 | 0xAA 0x55 |
|
|||
|
|
| 2 | 通知码 | 1 | 0xF0(示例通知码) |
|
|||
|
|
| 3 | 读/写 | 1 | 0x02(通知) |
|
|||
|
|
| 4 | 长度 | 1 | 0x02(2字节数据) |
|
|||
|
|
| 5 | 通知类型 | 1 | 0x02(错误状态上报) |
|
|||
|
|
| 6 | 错误码 | 1 | 0x07(设备错误) |
|
|||
|
|
| 7-8 | 校验 | 2 | CRC16(字节0-6) |
|