LV03-03-蓝牙Mesh进阶-03-蓝牙Mesh模型
本文主要是蓝牙Mesh进阶——蓝牙Mesh模型的相关笔记,若笔记中有错误或者不合适的地方,欢迎批评指正😃。
点击查看使用工具及版本
Windows版本 | windows11 |
Ubuntu版本 | Ubuntu22.04的64位版本 |
VMware® Workstation 16 Pro | 16.2.3 build-19376536 |
终端软件 | MobaXterm(Professional Edition v23.0 Build 5042 (license)) |
点击查看本文参考资料
分类 | 网址 | 说明 |
官方网站 | 阿里云 | 阿里云官网主页 |
阿里生活物联平台 | 生活物联网平台(飞燕平台)主页 | |
AliGenie | 天猫精灵开放平台AliGenie主页 | |
阿里物联网平台 | 阿里物联网平台主页 | |
Bluetooth 技术网站 | 蓝牙协议规范什么的可以来这里找 | |
Telink | Telink | Chips for a Smarter IoT (telink-semi.com) Telink中文官网 | |
开发手册 | AliOS Things开发指南 | AliOS Things开发指南,这里是最新版本,可以直接从官网找到 |
AliOS Things开发指南 | AliOS Things应用开发指南,这里应该是3.3版本的完整开发文档 | |
AliOS Things开发指南(3.0) | AliOS Things应用开发指南,这里应该是3.0版本的完整开发文档 | |
生活物联网平台开发文档 | 生活物联网平台(飞燕平台)开发文档 《设备端开发指南》 | |
Wi-Fi IoT品类定义与功能开发 | 天猫精灵IoT开放平台——Wi-Fi IoT品类定义与功能开发 | |
硬件平台 | mk3080 WiFi开发板 | WiFi开发板使用指南-阿里云开发者社区 |
esp8266开发板 | 一个教程:ESP8266-NodeMCU开发板详解-太极创客 (taichi-maker.com) | |
TLSR8258 Datasheet | Datasheet for Telink BLE + IEEE802.15.4 MultiStandard Wireless SoC TLSR8258 | |
参考资料 | AliOS Things 3.0 应用开发指南 | 这个只是一篇参考文章,里面是一些环境搭建相关的,可以参考 |
IP知识百科 - 华为 (huawei.com) | IP的一些相关知识点 |
点击查看相关文件下载
分类 | 网址 | 说明 |
蓝牙规范相关文档 | Core Specification 5.2 | 核心规格 5.2,该规范定义了创建可互操作的Bluetooth 设备所需的技术。 《Core_v5.2.pdf》 |
Mesh Model(v1.1) | 本Bluetooth 规范定义了模型(以及它们所需的状态和消息),这些模型用于在mesh 网络中的节点上执行基本功能,超出了Bluetooth Mesh 配置文件 规范中定义的基础模型。 本规范包括定义跨设备类型标准功能的通用模型,以及支持关键mesh 场景的模型,如照明控制、传感器、时间和场景。 《MshMDL_v1.1.pdf》 | |
Mesh Profile(v1.0.1) | 该Bluetooth 规范定义了基本要求,以实现可互操作的mesh 网络解决方案,用于Bluetooth 低能量无线技术。 《MshPRFv1.0.1.pdf》 | |
Mesh Device Properties | 本规范包含Bluetooth Mesh 配置文件 和Bluetooth Mesh 模型规范所要求的设备属性的定义。 但是跟之前的有些区别,我主要看的之前的版本:《MMeshDeviceProperties_v1.2.pdf》 | |
GATT Specification Supplement | GATT Specification Supplement | Bluetooth® Technology Website。 好像可以在线看:《GATT Specification Supplement》 | |
Assigned Numbers | GATT的一些类型定义可以在这里找。 | |
AliOS Things | alios-things/AliOS-Things | Gitee上的AliOSThings SDK源码仓库 |
alibaba/AliOS-Things | GitHub上的AliOSThings SDK源码仓库 | |
天猫精灵蓝牙Mesh协议栈 | alibaba-archive/genie-bt-mesh-stack | GitHub上的天猫精灵蓝牙Mesh协议栈源码仓库。 之前是在alibaba/genie-bt-mesh-stack这个仓库。 写笔记的时候最新提交为faf523618a6a2560090fc423222b9db80984bb7a |
蓝牙Mesh设备开发指南 | 阿里云生活服务平台开发手册——蓝牙设备开发一节中的内容 |
一、蓝牙Mesh模型简介
1. 模型的基本概念
蓝牙Mesh模型(Model)是Mesh模型架构中的基础业务单元,每个模型其实就是对应一个功能,(也有可能多个模型组合对应一个特定功能),每个元素(Element)可以添加多个不同的模型相同的模型也可以存在一个设备的不同元素中,例如:一盏RGB的氛围灯,其中红(R)黄(G)蓝(B)每个颜色的Led为一个元素,一共三个元素,每个元素中分别可以包含通用开关模型、通用上下电等级模型等。
模型又分为服务模型(Server Model)和终端模型(Client Model)。我们在IoT设备上配置的模型均为服务模型,表示该设备具备有特定的业务能力。
蓝牙Mesh模型又分为三种不同的类型,分别是基础模型(Foundation Model)、通用模型(Generic Model),以及厂商模型(Vendor Model)。
2. 官方文档
关于模型,我们具体可以查看这篇文档:《MshMDL_v1.1.pdf》
二、基础模型
基础模型定义了用于配置和管理蓝牙Mesh网络的消息,分为配置模型(Configuration Model)和健康模型(Health Mesh)两个部分。其中配置模型仅存在于设备的主元素(Primary Element)上,其他元素不需要添加该模型;健康模型必须存在于设备的主元素上,其他元素可以根据需求决定是否添加该模型。
三、通用模型
通用模型定义了一些列用于非特定功能的标准设备模型。例如:许多设备都具有开关功能,如风扇、电灯、插座等。这些设备都可以通过支持通用模型的开关模型来实现开关功能,而不用为每种类型的设备分别提供一个开关模型,这样也方便了不同厂商设备之间进行相互通信、控制。
1. 通用模型种类
通用模型分为通用服务模型和通用终端模型,要在设备上配置的通常为通用服务模型,通用服务模型一共有14种,如下表:
中文 | 英文 |
---|---|
通用开关服务模型 | Generic OnOff Server Model |
通用等级服务模型 | Generic Level Server Model |
通用默认渐变时间服务模型 | Generic Default Transition Time Server Model |
通用上下电开关服务模型 | Generic Power OnOff Server Model |
通用上下电开关设置服务模型 | Generic Power OnOff Setup Server Model |
通用上下电等级服务模型 | Generic Power Level Server Model |
通用上下电等级设置服务模型 | Generic Power Level Setup Server Model |
通用电池服务模型 | Generic Battery Server Model |
通用位置信息服务模型 | Generic Location Server Model |
通用位置信息设置服务模型 | Generic Location Setup Server Model |
通用用户自定义属性服务模型 | Generic User Property Server Model |
通用管理员属性服务模型 | Generic Admin Proerty Server Model |
通用制造商属性服务模型 | Generic Manufacturer Proerty Server Model |
通用终端属性服务模型 | Generic Client Proerty Server Model |
2. 通用服务模型字段说明
TID:用于应用层判断消息ID是否重复,该字段数值由应用层定义。
渐变时间:表示设备从一个状态变换到另一个状态所需要的时间,该字段在通用服务模型中长度为1字节,该字节的低6位表示渐变时间的具体数值(该6位的取值范围是0x00~0x3E);该字节的高2位表示渐变时间的单位。
该字节数据格式如下图:
该字节对应的渐变时间单位为:
渐变字段高2位 | 渐变时间单位 | 渐变字段高2位 | 渐变时间单位 |
---|---|---|---|
0b00 | 100ms | 0b10 | 10s |
0b01 | 1s | 0b11 | 10min |
例如:该字段为0x41,对应低6位为0x01,高2位为0x01,解析得到的时间为1×1s = 1s。
延迟时间:表示设备从收到消息到消息开始执行变化的这段时间,该字段对应的实际延迟时间为该字段数值×单位步长5ms。例如:该字段为0x0A,解析得到的时间为10×5ms = 50ms。
3. 通用开关服务模型
通用开关模型是一个根模型(Root Model),该模型支持广播和订阅。
通用开关模型定义了一种通用的开关控制方式,不同的设备可以使用同一个消息格式控制开关,实现了多个设备/模型订阅同一地址时,可以通过向该地址发送开关控制执行来控制开关。
3.1 获取开关状态
获取开关状态(Generic OnOff Get)消息用于获取当前元素的开始状态。当设备收到获取开关状态消息时,需要返回的开关状态消息。获取开关状态消息格式如下:
字段 | 字段长度(字节) | 备注 |
---|---|---|
Opcode(操作码) | 2 | 0x82 0x01(Get) |
3.2 设置开关状态
设置开关状态(Generic OnOff Set)消息用于设置当前元素的开关状态。当设备收到设置开关状态消息时,需要回复开关状态消息。设置开关消息格式如下:
字段 | 字段长度(字节) | 备注 |
---|---|---|
Opcode(操作码) | 2 | 0x82 0x02 |
目标开关状态 | 1 | 需要设置的目标开关状态 |
TID | 1 | TID |
渐变时间 | 1 | 渐变时间(可选字段) |
延迟时间 | 1 | 延迟时间(可选字段) |
渐变时间和延迟时间必须一起设置,如果渐变时间存在,则延迟时间必须存在;反之亦然。
3.3 设置开关状态(无确认)
设置开关状态(无确认)(Generic OnOff Set Unacknowledged)消息用于设置当前元素的开关状态。当设备接收设置开关状态(无确认)消息时,不需要回复任何消息,设置开关状态(无确认)消息格式:
字段 | 字段长度(字节) | 备注 |
---|---|---|
Opcode | 2 | 0x82 0x03 |
目标开关状态 | 1 | 需要设置的开关状态 |
TID | 1 | TID |
渐变时间 | 1 | 渐变时间(可选字段) |
延迟时间 | 1 | 延迟时间(可选字段) |
3.4 开关状态
开关状态(Generic OnOff Status)消息用于上报设备的开关状态。消息格式如下:
字段 | 字段长度(字节) | 备注 |
---|---|---|
Opcode | 2 | 0x82 0x04 |
当前开关状态 | 1 | 设备当前开关状态 |
目标开关状态 | 1 | 设备目标开关状态 |
剩余时间 | 1 | 设备切换到目标状态剩余时间 |
目标开关状态和剩余时间必须一起返回,如果目标开关状态存在,则剩余时间必须存在,反之以然。
4. Lighting Server 模型
接下来一起分析一个官方提供好的智能灯得一个服务模型,在此之前我们可以先回顾一下元素、模型、状态、消息之间得关系。首先应该设想好4种消息的特点:
类型 | 特点 |
---|---|
GET | 用于获取该属性的状态、接收方需要发送该属性Status消息作为回应、此消息不包含其他参数 |
SET | 用于设置该属性的状态、接收方需要发送该属性的Status作为消息回应 |
Set Unacknowledged | 用于设置该属性的状态、接收方不需要回应 |
Status | 用于报告该属性的状态(包含但不限于当前状态、目标状态、剩余转换时间等)、接收方不用回应 |
元素、模型和状态三者之间个关系:
Lighting Server模型定义了一组照明控制功能。此模型出包含了可调亮度及变色灯外,还包括一个允许由传感器触发特定行为的灯光控制模型,例如,根据人的位置开启灯光、根据环境光线调整灯光亮度,或在一段时间没任何东京的情况下调暗灯光并最终关闭。
接下来将针对Light Lightness 及Light CTL这两个符合状态模型及其状态进行详细描述。
在蓝牙Mesh网络中,Provision一般时提供属性给Provisioner进行操作的一方,属于Server角色,其中包含的模型即为Server模型。Lighting Server模型是由LightLightness Server、Light Lightness Setup Server、Light CTL Server、Light CTL Setup Server、Light CTL Temperature Server、Light HSL Server、Light HSL Hue Server、Light HSL Saturation Server、Light HSL Setup Server、Light xyL Server和Light xyL Setup Server这11种模型组成。其中前四种应用最为广泛,本次也主要与前4种模型相关的状态、消息及各种操作消息对应的行为。
不同的模型之间存在继承和共生关系。以Light Lightness Server模型为例,它扩展了Generic OnOff Server 和Generic Level Server两种模型,这种扩展关系即集成关系;如果一个元素中包含Light Lightness Server模型,则必须包含Light Lightness Set Server模型,这种关系叫做共生关系。
上图所示:Light Lighteness Server Model、Light Lighteness Setup Server Model、Light CTL Server Model、Light CTL Setup Server Model模型与其他模型之间的关系。
其中Light Lighteness Server Model模型和Light CTL Server Model模型同事支持注册和发布操作;而Light Lighteness Setup Server Model和Light CTL Setup Server Model模型仅支持注册操作,这些模型所包含的状态如下:
4.1 Lightness 状态
Lightness状态时Lighting模型种应用最为广泛的一组符合状态。因为光源的类型及属性不同,所以在描述Lightness状态时会有所不同的表达方式。最简单的灯只有开和关两种状态,通过Generic OnOff描述和控制其他开关状态。高级一点的灯可以改变亮度,通过Light Lightness Actual描述和控制其亮度状态。
除此之外,还有变色灯,可以通过Light CTL 和DUV(Delta UV)来描述和调节其色温。对于变色灯,可以通过调整亮度、色调、饱和度三个维度的值对其颜色进行调整,三个维度都可以被独立控制。
4.2 Light Lightness 状态
Light Lightness状态是一个由Light Lightness Actual、Light Lightness Linear、LightLightness Last和Light Lightness Default组合成的符合状态。这4种状态都分别与其他一种或者多种状态存在绑定关系。可以理解为联动关系。
4.3 Light Lightness Actual 状态
取值 | 描述 |
---|---|
0x0000 | 元素处于未发光状态 |
0x0001 ~ 0xFFFF | 元素发出的被实际感知的光强度 |
0xFFFF | 元素所能发射的能被感知的最强光的强度 |
与Light Lightness Actual状态操作对应的是Light Lightness消息。Light Lightness状态属于可设置状态,所以Light Lightness消息由Light Lightness Set、Light Lightness Get、Light Lightness Set Unacknowledged、和Light Lightness Status这4种消息组成。
Light Lightness Set、Light Lightness Set Unacknowledged具有相同结构:
字段 | 大小(字节) | 说明 |
---|---|---|
光亮度值 | 2 | Light Lighness Actual状态的目标值 |
TID | 1 | 传输标识,可以用此字段判定当前收到的消息是一条新消息还是重传消息 |
状态切换时间 | 1 | 可选 |
状态切换延迟 | 1 | 开始状态切换时间必须添加此项 |
Light Lightness Server在收到这两种消息后,应该将Light Lighness Actual状态设置为Lightness目标值。如果6s内收到SRC、DST、TID栏位都相同,的多条消息,可以忽略掉第1条消息之后的其他消息。
如果消息种包含“状态转换时间”字段,则元素状态切换应该符合该字段定义的行为,如果不包含“状态转换时间”字段,但元素支持“Generic Default Transition”状态的情况下,元素状态切换应该符合“Generic Default Transition”状态的行为定义,否则状态将立即执行。
如果当前状态和目标状态是一致的话,应该认为状态切换过程已经完成。
在收到Light Lightness Set消息之后,Light Lightness Server应该回复Light Lightness Status消息给发送方。
4.4 Light Lightness Status 状态
字段 | 大小(字节) | 说明 |
---|---|---|
当前亮度 | 2 | Light lightness Actual 当前状态值 |
目标亮度 | 2 | Light lightness Actual 目标值(可选)如果元素处于状态切换过程中,则需要包含此项,代表元素的目标亮度值 |
剩余状态 切换时间 | 1 | 需要与“目标状态”字段同时出现 代表元素完成状态切换过程所剩余的时间 |
四、厂商自定义模型
关于这一部分,官方有相关的说明:蓝牙Mesh设备扩展协议_生活物联网平台(飞燕平台)-阿里云帮助中心 (aliyun.com)
1. 背景信息
蓝牙技术联盟(Bluetooth SIG)定义的SIG Mesh的模型目前尚未覆盖所有的智能家居设备,我们采用厂商自定义模型(Vendor Model)来实现智能家居设备的控制和状态上报。在天猫精灵生态项目中,Mesh网关包括天猫精灵音箱与天猫精灵App。在自有品牌项目中,Mesh网关包括自有品牌项目Mesh网关产品与云智能App。注意以下部分消息仅在天猫精灵生态项目中支持。
2. Vendor Model
SIG定义Vendor Model格式为4字节(其中2字节的Company ID和2字节的Vendor-assigned Model ID),其中Alibaba的Company ID为0x01A8,如下表所示。
字段 | 字节数 | 说明 |
---|---|---|
16-bit Company Identifier | 2 | 0x01A8 |
16-bit vendor-assigned model Identifier | 2 | - |
下表为两个VendorModel ID,用于消息扩展用。
Model Name | SIG Model ID |
---|---|
Vendor Model Server | 0x01A80000 |
Vendor Model Client | 0x01A80001 |
说明 Mesh设备作为Vendor Model Server,Mesh网关作为Vendor Model Client。
3. 扩展消息操作码
在蓝牙Mesh协议中规定,操作码分为3种:1字节Opcode、2字节Opcode、3字节Opcode。
- 1字节Opcode的最高位为0,所以1字节Opcode的取值范围从0x00-0x7e(其中0x7f用于将来扩展用)。
- 2字节Opcode第一字节的最高位为1,第2位为0,所以2字节OpCode的取值范围从0x8000到0xbfff,都为SIG分配。
- 3字节Opcode第一字节的最高两位均为1,后两字节z是由SIG分配的Company ID,Company ID使用小端优先的方式传输,阿里巴巴使用的Company ID为0x01a8。6 bit的x可由厂商定义64个Opcodes。
Opcode Format | 说明 |
---|---|
0b0xxxxxxx(排除0b01111111) | 1字节Opcode。 |
0b01111111 | 保留,用于将来扩展。 |
0b10xxxxxx xxxxxxxx | 2字节Opcode。 |
0b11xxxxxx zzzzzzzz zzzzzzzz | 3字节Opcode。 |
4. 操作码定义
智能生活平台蓝牙Mesh扩展消息Opcode定义如下表所示。
Vendor Message Name | Opcode |
---|---|
Vendor Message Attribute Get | 0xD001A8 |
Vendor Message Attribute Set | 0xD101A8 |
Vendor Message Attribute Set Unacknowledged | 0xD201A8 |
Vendor Message Attribute Status | 0xD301A8 |
Vendor Message Attribute Indication | 0xD401A8 |
Vendor Message Attribute Confirmation | 0xD501A8 |
Vendor Message Attribute Indication To Tmall Genie | 0xDE01A8 |
Vendor Message Attribute Confirmation From Tmall Genie | 0xDF01A8 |
Vendor Message Transparent msg | 0xCF01A8 |
Vendor Message Transparent Indication | 0xCE01A8 |
Vendor Message Transparent ACK | 0xCD01A8 |
5. Vendor Model属性消息结构
Vendor message里的数据都使用小端优先方式传输。
5.1 Vendor Message Attribute Get
该消息用于Vendor Model Client获取Vendor Model Server的一个或多个属性值,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xD001A8 |
TID | 1 | Transaction Identifier,每条新消息递增 |
Attribute Type | 2 | 读取的Attribute类型 |
Attribute Type最多可有15个。当Vendor Model Server收到Attribute Get消息后,必须向Vendor Model Client回复Attribute Status。如Vendor Model Client在下发该命令之后未收到Vendor Model Server返回的Attribute Status,可以再次下发该指令。
5.2 Vendor Message Attribute Set
该消息用于Vendor Model Client设置Vendor Model Server的一个或多个属性值,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xD101A8 |
TID | 1 | Transaction Identifier,每条新消息递增 |
Attribute Type | 2 | 设置的Attribute类型 |
Attribute Parameter | N | 设置的Attribute参数 |
Attribute Type和Attribute Parameter最多可有15个。当Vendor Model Server收到Attribute Set消息后,必须向Vendor Model Client回复Attribute Status。如Vendor Model Client在下发该命令之后未收到Vendor Model Server返回的Attribute Status,可以再次下发该指令。
5.3 Vendor Message Attribute Set Unacknowledged
该消息用于Vendor model Client设置Vendor Model Server的一个或多个属性值,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xD201A8 |
TID | 1 | Transaction Identifier,每条新消息递增 |
Attribute Type | 2 | 设置的Attribute类型 |
Attribute Parameter | N | 设置的Attribute参数 |
Attribute Type和Attribute Parameter最多可有15个。当Vendor Model Server收到Attribute Set Unacknowledged消息后,不需要向Vendor Model Client发送Attribute Status消息。
5.4 Vendor Message Attribute Status
该消息用于Vendor Model Server回复Attribute Get和Attribute Set命令或上报设备状态信息给Vendor Model Client,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xD301A8 |
TID | 1 | Transaction Identifier,每条新消息递增 |
Attribute Type | 2 | 上报的Attribute类型 |
Attribute Parameter | N | 上报的Attribute参数 |
Vendor Model Client收到Attribute Status后,不需要回复消息给Vendor Model Server。
5.5 Vendor Message Attribute Indication
该消息用于Vendor Model Server发送属性给Vendor Model Client,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xD401A8 |
TID | 1 | Transaction Identifier,每条新消息递增,回复控制命令的TID为下发消息的TID;设备状态主动改变上报的TID从128到191循环。 |
Attribute Type | 2 | 上报的Attribute类型 |
Attribute Parameter | N | 上报的Attribute参数 |
Attribute Type和Attribute Parameter最多可有15个。当Vendor Model Client收到Attribute Indication消息后,必须向Vendor Model Server回复Attribute Confirmation。如Vendor Model Server在发出该命令之后未收到Vendor Model Client回复的confirmation,可以再次发送该指令。
5.6 Vendor Message Attribute Confirmation
该消息用于Vendor Model Client回复给Vendor Model Server,用于表示已收到Vendor Model Server发出的Indication,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xD501A8 |
TID | 1 | Transaction Identifier,收到的Indication消息的TID |
Vendor Model Server收到Attribute Confirmation后,不需要回复消息给Vendor Model Client。
5.7 Vendor Message Attribute Indication To TmallGenie
该消息用于天猫精灵生态项目Vendor Model Server发送属性给Vendor Model Client,该消息由天猫精灵音箱直接处理,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xDE01A8 |
TID | 1 | Transaction Identifier,每条新消息递增 |
Attribute Type | 2 | 上报的Attribute类型 |
Attribute Parameter | N | 上报的Attribute参数 |
Attribute Type和Attribute Parameter最多可有15个。当Vendor Model Client收到Attribute Indication消息后,必须向Vendor Model Server回复Attribute Confirmation。如Vendor Model Server在发出该命令之后未收到Vendor Model Client回复的Confirmation,可以再次发送该指令。
5.8 Vendor Message Attribute Confirmation From TmallGenie
该消息用于天猫精灵生态项目Vendor Model Client回复给Vendor Model Server,用于表示天猫精灵音箱已收到Vendor Model Server发出的Indication,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xDF01A8 |
TID | 1 | Transaction Identifier,每条新消息递增 |
Attribute Type | 2 | 设置的Attribute类型 |
Attribute Parameter | N | 设置的Attribute参数 |
Attribute Type和Attribute Parameter的个数从0到15。Vendor Model Server收到Attribute Confirmation后,不需要回复消息给Vendor Model Client。
说明 TID:对于TID相同的消息,需按照协议回复对应的消息,但应用层是否处理则由产品自身特性决定。
6. Vendor Model透传消息结构
Vendor message里的数据都使用小端优先方式传输。
6.1 Vendor Message Transparent Message
该消息用于Mesh设备与天猫精灵音箱与天猫精灵App之间透传数据,Payload数据格式由各厂家自己实现。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xCF01A8 |
TID | 1 | Transaction Identifier,每条新消息递增,回复控制命令的TID为下发消息的TID;设备状态主动改变上报的TID从0到255循环。 |
Payload | N | 由厂商自定义 |
6.2 Vendor Message Transparent Indication
该消息用于天猫精灵生态项目中Vendor Model Server发送属性给Vendor Model Client,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xCE01A8 |
TID | 1 | Transaction Identifier,每条新消息递增,回复控制命令的TID为下发消息的TID;设备状态主动改变上报的TID从128到191循环。 |
Payload | N | 由厂商自定义 |
6.3 Vendor Message Transparent ACK
该消息用于天猫精灵生态项目中Vendor Model Client回复给Vendor Model Server,用于表示已收到Vendor Model Server发出的Transparent Indication,消息格式如下。
字段 | 字节数 | 说明 |
---|---|---|
Opcode | 3 | 0xCD01A8 |
TID | 1 | Transaction Identifier,收到的Indication消息的TID。 |
说明 TID:对于TID相同的消息,需按照协议回复对应的消息,但应用层是否处理则由产品自身特性决定。
7. Vendor Message 示例数据
7.1 Vendor Model Client设置目标温度
本示例为Vendor Model Client设置目标温度为22摄氏度。
- Vendor Model Client下发设置目标温度的Attribute Set命令。
- Vendor Model Server设置目标温度成功时返回的Attribute Status如下
- Vendor Model Server设置目标温度失败时返回的Attribute Status如下。
7.2 Vendor Model Client读取数据
本示例为Vendor Model Client读取前后位置,当前温度,当前湿度。
- Vendor Model Client发送Attribute Get读取前后位置、当前温度、当前湿度属性的值如下。
- Vendor Model Server读取三个属性成功时返回的Attribute Status如下。
- Vendor Model Server读取温度失败时返回的Attribute Status如下。
7.3 Vendor Model Server上报温度
本示例为Vendor Model Server发送温度给Vendor Model Client。
- Vendor Model Server发送Attribute Indication上报温度如下。
- Vendor Model Client收到Attribute Indication后发送Confirmation如下。
7.4 Vendor Model Server上报漏水故障
本示例为Vendor Model Server上报漏水故障给Vendor Model Client。
- Vendor Model Server发送Attribute Indication上报漏水故障如下。
- Vendor Model Client收到Attribute Indication后发送Confirmation如下。