跳至主要內容

米家/飞利浦/宜家 Zigbee 智能家居设备接入 ThingsCloud

约 2871 字大约 10 分钟

米家/飞利浦/宜家 Zigbee 智能家居设备接入 ThingsCloud

搭建 Zigbee2MQTT 网关

通过架设自己的 Zigbee 网关,我们可以将米家的 Zigbee 设备轻松接入 ThingsCloud。借助 ThingsCloud 平台的内置应用和开放性,我们可以在很多行业项目和应用场景中灵活自如的发挥 Zigbee 无线设备的优势。例如:楼宇办公、温室大棚、小型仓库、环境监测、工业控制等一些非家居场景。

这里要用到开源项目 Zigbee2MQTTopen in new window ,它采用 NodeJS 编写,可以运行在 Linux/Windows 下,详细的搭建过程这里略过,官网有详细的介绍。

Zigbee2MQTT 支持的 Zigbee 设备多大2000多种。

通常来说,搭建 Zigbee2MQTT 网关需要以下硬件:

  • Linux 小型主机,可通过 WiFi/以太网/4G 连接互联网,支持 USB 接口。我们这里以树莓派为例。
  • Zigbee 适配器,支持 USB 或以太网接口。采用 CC25xx 或 CC26xx 的 Zigbee 芯片。CC26xx 具有更远的传输距离和更好的稳定性。

树莓派 4B + USB Zigbee 适配器

树莓派 Zero + USB Zigbee 适配器

版本适配说明

如果使用的 Zigbee2MQTT 是 1.8.0 以上的版本,需要对代码进行一点小小的修改。在本地源代码目录中找到该文件 lib/mqtt.tsopen in new window,如下图:

将以下代码:

this.subscribe(`${settings.get().mqtt.base_topic}/#`);

修改为:

this.subscribe(`${settings.get().mqtt.base_topic}/+/set`);

修改后保存,由于修改了 lib 下的文件,需要重新编译,方法如下:

npm run build

Zigbee 优势

Zigbee 无线设备的主要优势包括:

  • 低功耗:例如小米温湿度传感器使用 3V 纽扣锂电池,可以续航长达一年多时间。
  • 低延迟:设备响应速度快,从睡眠状态切换到工作状态通常仅需要 15ms,节点访问网络仅需要 30ms,从而进一步节省了电量。
  • 容量大:Zigbee 可以采用星状,片状和网状的网络结构,最多可以形成 65000 个节点的大型网络。
  • 低成本:Zigbee 协议免专利费,且市面上支持 Zigbee 标准协议的传感器、灯、开关、电源等产品非常多,价格低廉。仅 Zigbee2MQTT 支持的设备就有超过 2000 多种,包括小米、绿米、宜家、飞利浦等。

Zigbee2MQTT 接入 ThingsCloud

Zigbee2MQTT 网关准备好后,我们来重点介绍 ThingsCloud 平台的接入和应用,对于其它 Zigbee 网关的接入同样具有参考意义。

创建项目

打开 ThingsCloud 控制台open in new window,如果还没有创建项目,先创建一个项目。

创建设备类型

为了定义网关设备的功能,我们需要先创建一个设备类型,这里可以直接使用我们已经发布的模板,创建类型时选择产品类型,输入产品 ID:7892219658。如下图:

这样会自动生成一些规则,用来解析网关和子设备的消息,直接使用即可。

同时还有自动生成的自定义数据流,支持 Zigbee2MQTT 的 MQTT 主题。

创建网关设备

接下来创建一个设备,绑定到刚创建的设备类型下。

进入设备>连接,可以看到设备证书和 MQTT 连接地址,稍后会用到。

编辑 Zigbee2MQTT 配置

接下来配置 Zigbee2MQTT,以默认安装路径为例,打开配置文件:

nano /opt/zigbee2mqtt/data/configuration.yaml

需要注意的几点:

  • base_topic:必须修改为 data/zigbee2mqtt
  • server:修改为从网关设备页面复制的 MQTT 接入点完整地址,例如 mqtt://xxx.iot-api.com:1883
  • user:修改为从网关设备页面复制的 AccessToken
  • password:修改为从网关设备页面复制的 ProjectKey
  • homeassistant:设置为 false
  • permit_join:当需要添加子设备时,设置为 true

如下图:

保存配置文件,重启 Zigbee2MQTT,网关设备连接成功,会上报网关的基本信息。

添加子设备

创建子设备类型

所有 Zigbee 设备都是网关的子设备,我们以温湿度传感器为例,创建一个子设备类型。

创建子设备

然后在该类型下创建多个温湿度传感器设备。

添加子设备到网关

最后,进入网关设备的子设备管理列表,将创建好的多个子设备添加到网关下,并且设置子设备地址。

子设备地址可以有两种方式找到:

  • 在 Zigbee2MQTT 的本地日志中,可以找到类似 data/zigbee2mqtt/0xXXXXXXXXXXXXXXXX 的主题,这里的 0xXXXXXXXXXXXXXXXX 就是子设备地址。
  • 或者在 ThingsCloud 网关设备的调试消息历史中,查看自定义上报消息的详情,也可以找到如上设备地址。

配置子设备地址后,就可以立即看到传感器上报的数据被网关设备转发到了子设备,子设备显示在线状态。

查看设备当前状态

进入不同的子设备,可以看到 Zigbee 设备的当前属性数据。

绿米温湿度传感器

绿米门窗状态传感器

小米人体存在传感器

小米智能电源

小米无线开关

查看设备历史数据

进入设备页面,对于数值型属性,直接点击属性面板上的历史数据图标,即可打开历史数据曲线图。

可以选择时间范围、聚合时间段,以及聚合方式。来看看最近三天每小时湿度的中位数,如下图:

实时控制

一些 Zigbee 设备具备控制功能,例如小米智能电源,可以从云平台下发指令控制电源开关,从而控制使用市电的设备,相当于继电器。

在智能电源设备类型中定义开关量属性,并且使用设备云端共享的属性类型,这样该属性既可以由智能电源上报,也可以通过控制台、App 或调用 API 下发给设备。

例如:在控制台操作开关,如下图:

在设备调试消息中,可以看到下发的 JSON 指令,同时设备更新状态后会立即上报一条最新 JSON 属性数据。从消息时间可见,Zigbee 的传输延迟非常低。

可视化看板

当我们希望通过统一的看板来方便的掌握多个设备的数据,并且快速的控制设备,ThingsCloud 可视化看板派上用场。

创建看板

添加看板组件

通过不同的看板组件,可以将不同设备的不同属性,以可视化的形式呈现出来。

看板全屏

可视化看板支持全屏,可以利用这个特性,将看板呈现在大屏幕上。

看板中的设备实时互动

看板中实时更新门窗传感器状态,我们也可以随时打开或关闭电源,请观看以下视频:

设计 App 界面

到目前为止,我们已经通过 ThingsCloud 获取所有 Zigbee 子设备的状态数据,并可以对一些设备下发实时控制指令。

接下来,我们来为生成用户 App 做一些准备,对于不同的设备类型,我们编辑相应的 App 设备面板。

小米智能电源

添加基本的属性定义,如下图:

进入 App 界面编辑,如下:


小米智能开关

小米智能开关支持上报多种开关动作,对应的属性标识符是 click,它的取值包括:

  • 点击
  • 双击
  • 三击
  • 四击
  • 多击(超过四击)
  • 长按
  • 长按释放

添加基本的属性定义,如下图:

这里,我们希望根据单击来生成开关状态 status,例如用来控制灯的开关。为此,我们编写了一个简单的属性上报预处理规则,如下:

进入 App 界面编辑,如下:

门窗传感器

进入 App 界面编辑,如下:

温湿度传感器

添加基本的属性定义,如下图:

进入 App 界面编辑,如下:

创建用户 App

对设备类型完成 App 界面设计后,我们来创建用户应用,即可获得支持多个移动平台的用户 App,如下图:

接下来创建用户账号,用来登录用户 App。然后为用户关联多个设备。当用户登录后,便可以查看或控制这些设备。

告警通知

利用 ThingsCloud 的内置告警规则和通知组,可以轻松实现强大的告警通知,通知方式支持丰富的选择,包括邮件、短信、钉钉群通知、企业微信通知、飞书群通知等。

告警通知的详细介绍,请参考 告警规则open in new window

应用端设备 API

除了内置的可视化看板及通用应用。我们还可以利用 API,将设备的数据和控制集成到任何第三方应用系统中。

以小米智能电源为例,我们通过 HTTP 客户端工具来实现数据读取和控制。

读取智能电源的当前所有属性值,如下图:

读取指定的属性值,如下图:

立即闭合电源,如下图:

立即断开电源:如下图:

详细介绍,请参考 应用端设备访问 APIopen in new window

设备联动

通过在 ThingsCloud 云平台的消息规则,可以跨越网关,实现项目内任何设备之间的智能联动。

这里不详细介绍,请参考 消息规则open in new window

项目 API

通过项目 API 的使用,您可以完全按照自己的需求,实现设备的展现和控制。

项目 API 基于标准的 HTTP 协议和 MQTT 协议,对于不支持 MQTT 的浏览器应用,我们提供了 MQTT@Websocket。这使得项目 API 兼容几乎所有应用程序运行平台,因此,基于项目 API 可以开发的应用软件,包括但不限于以下:

  • 基于 Web 浏览器的 SaaS 软件
  • 运行在桌面的客户端软件
  • 运行在手机端的 App
  • 运行在工业平板上的可视化应用
  • 运行在电视屏上的大屏应用

详细介绍,请参考 项目 API