news 2026/5/11 2:22:42

如何使用EBHelper 简化EdgeBus的代码编写?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何使用EBHelper 简化EdgeBus的代码编写?

EBHelper是一款专为简化 EB 代码开发设计的插件工具。用户仅需完成JSON 格式配置文件,即可快速实现设备通信与数据上报,无需编写代码。

核心功能与支持规约

  • 设计目标:简化开发流程,通过配置实现通信。
  • 支持协议
  • Modbus
  • DL/T 645
  • Any(自定义任意格式)

数据结构定义

EB 上行标准帧结构

上行事件采用固定格式封装原始数据:

字段名偏移长度 (Bytes)含义说明
version01协议版本号
dataType11数据类型编码
covStatus21保留字节(供内部 COV 处理)
status31查询事件状态
battery41电池电量
addr[]5n子设备地址(Modbus 为 1 字节,DL/T 645 为 6 字节)
appData[]5+nm应用层原始数据(解析由物模型完成)

配置项详解

上行事件配置(主配置)

用于定义数据上报通道及周期。

  • 基础项name(标识名),port(端口, 默认 22),addrSize(地址长度)。
  • 版本控制version(默认 0x83),dataType(自动递增)。
  • 周期策略
  • 优先级upPeriod>upPeriodIndex> 默认不触发。
  • 动态调整:推荐使用upPeriodIndex(起始地址 70,4 字节对齐)。

3.2. 查询事件配置 (quInfo)

定义如何向子设备发起请求。

  • 协议参数:支持protocol,code(功能码),addr(设备地址)。
  • 数据注入:通过indexAPP,indexCMD,copySize可将 App 参数动态写入命令帧,避免硬编码。
  • 校验与触发
  • isLast: 设为true时,该查询完成后立即触发数据上行。
  • listTag: 用于回复报文的基础校验。

3.3. 数据处理与 COV (listVal)

定义从回复报文中提取数据的规则及变化上报 (COV)策略。

  • 提取范围startend闭区间。在 Modbus 中代表寄存器地址,非偏移量。
  • COV 机制
  • 支持Uint8/16/32,Int8/16/32,Float(大/小端)。
  • 触发条件:采集值与上次发送值的差值绝对值 >covAppIndex存储的阈值。

最佳实践建议

效率优化

  • 减少查询次数:尽量用单次查询获取连续数据,即使包含少量无效字节(回复报文支持达 250 字节)。
  • 分包原则:若无效数据超过 50 字节,建议拆分为多个查询事件。

参数规划

  • 动态化:优先使用Index类配置(如upPeriodIndex),便于后期无需重新编译即可调整参数。
  • 内存分配参考
  • 70+:周期相关参数。
  • 110+:COV 阈值缓存区。
  • 150+:动态参数源地址。

周期单位参考

支持:s(秒),m(分),h(时),d(天),y(年)。

示例:"900s"表示 900秒。

参考示例

import { Buffer } from "buffer"; import { buildOtaFile } from "@EBSDK/run"; import { ActionAfertExpr, CalcData, CrcMode, CvtRule, EBBuffer, EBModel, ExprCondition, LoraUpEvent, QueryEvent, SetUpCovDataType, UserConfUPItem,EventInfoItem } from "@EBSDK/EBCompiler/all_variable"; import { CheckbitEnum, getOtaConfig, HwTypeEnum, UpgrdTypeEnum } from "@EBSDK/otaConfig"; //////////////////////////////////////////////////////////////////////////////////////// const eventInfo:UserConfUPItem[]=[ { name:"transh",dataType:"0x23",upPeriodIndex:70, // port:22, version:"0x83",upPeriod:"900s", quInfo:[ { protocol:"modbus",addr:"0x02",code:"0x03", periodIndex:74, //indexAPP:150, indexCMD:0, copySize:4,period:"900s",isLast:false,payIndex:3,ackAddrIndex:0, listVal:[ { start: "0", end: "1" ,covType:"Uint32BE",covAppIndex:110}, { start: "2", end: "3" ,covType:"Uint32BE",covAppIndex:110}, { start: "4", end: "7" }, ] },{ protocol:"modbus",addr:"0x01",code:"0x03",periodIndex:74, //indexAPP:-1, indexCMD:0, copySize:4,period:"300s",//isLast:false,payIndex:3,ackAddrIndex:0, hook:false listVal:[ { start: "0x0102", end: "0x0102",covType:"Uint16BE",covAppIndex:114} //,covAppIndex ] } ] } ] let otaConfig = getOtaConfig({ SwVersion:31, BaudRate: 9600, StopBits: 1, DataBits: 8, Checkbit: CheckbitEnum.NONE, Battery: false, // 非电池供电,Class C模式 ConfirmDuty: 60, BzType: 10105, BzVersion: 11 }) const MODBUS_TT = (ebModel: EBModel) => { for (let i=0; i<eventInfo.length; i++){ let event=new EventInfoItem(eventInfo[i]); event.upEventSetup() event.eventInstall() } return JSON.stringify(ebModel, null, 2) }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:26:18

vue框架如何处理内网大文件的目录结构上传?

前端老炮的20G文件夹上传大冒险&#xff08;附部分代码&#xff09; 各位前端同仁们&#xff0c;我是老张&#xff0c;一个在辽宁苦哈哈写代码的"前端民工"。最近接了个活&#xff0c;客户要求用原生JS实现20G文件夹上传下载&#xff0c;还要支持IE9&#xff01;这简…

作者头像 李华
网站建设 2026/5/6 22:11:47

基于KRR核岭回归的多变量回归预测,核岭回归(Kernel Ridge Regression, KRR)是一种结合了岭回归和核技巧的非线性回归方法,Matlab代码实现

KRR核岭回归多变量回归预测代码 一、研究背景 核岭回归&#xff08;Kernel Ridge Regression, KRR&#xff09;是一种结合了岭回归和核技巧的非线性回归方法&#xff0c;广泛应用于机器学习中的回归预测问题。本研究基于实际工程或科学实验数据&#xff0c;旨在&#xff1a; …

作者头像 李华
网站建设 2026/5/10 4:12:14

用 ESP32-C3 直接连 Starlink 路由器/热点并完成配网

我们这边没有做过“用 ESP32-C3 直接连 Starlink 路由器/热点并完成配网”的专项实物测试&#xff0c;所以不能给你一个“我们已验证没问题/一定可以”的结论。但从协议和已知限制来看&#xff1a;ESP32-C3 作为 2.4GHz Wi-Fi STA 连接 Starlink 的热点本身通常是可行的&#x…

作者头像 李华
网站建设 2026/5/3 7:57:47

Shell脚本命令大全:快速入门与实用案例详解

Shell脚本是自动化系统管理任务的核心工具&#xff0c;掌握常用命令能极大提升工作效率。本文不罗列所有命令&#xff0c;而是聚焦于实际工作中最有用、最易出错的命令组合与应用场景&#xff0c;帮助读者建立实用的脚本编写思维。 shell脚本命令如何快速入门 入门shell脚本不…

作者头像 李华