homebridge-xiaomi-aqara-heatercooler

A homebridge plugin for Mi/Aqara AC Partner

Usage no npm install needed!

<script type="module">
  import homebridgeXiaomiAqaraHeatercooler from 'https://cdn.skypack.dev/homebridge-xiaomi-aqara-heatercooler';
</script>

README

Homebridge Xiaomi Aqara AC Cooler

npm version

适用于 米家 / Aqara 空调伴侣的 Homebridge 插件

支援 homebridge-config-ui-x 进行配置

功能

控制

  • 仅保留制冷模式
  • 温度
    • 17 - 30 度
  • 风速
    • 1 : 低
    • 2 : 中
    • 3 : 高
    • 4 : 自动
  • 摆动
  • 灯光
    • 仅当 enableLED 为 true 时
    • 作为单独的灯光配件

显示

  • 空调伴侣状态同步
  • 空闲 / 工作 颜色区分
    • 空闲 : 绿
    • 制冷 : 蓝
  • 当前功率(百分比)
    • 仅当设定了 ratedPower(额定功率)时
    • 作为「电池电量」显示
  • 当前温、湿度
    • 仅当指定了温湿度传感器的 sensorId
    • 湿度集成在空调内,不以单独传感器显示

安装

npm i -g miio@0.14.1 homebridge homebridge-xiaomi-aqara-heatercooler

配置

首先需要获取空调伴侣的token 以及 IP 地址

然后使用 Config UI 进行配置

或者在 Homebridge 的 config.json 中加入如下配置:

"accessories": [
  {
    "accessory": "MiHeaterCooler",
    "name": "AC Partner",
    "address": "192.168.1.154",
    "Manufacturer": "Aqara",
    "Model": "KTBL11LM",
    "token": "71b4e85d8527aab32c8f9175124c0d59",
    "sensorId": "158d0001a4c582",
    "enableLED": false,
    "ratedPower": 735
  }
]

| 参数 | 描述 | 必须配置 | |-|-|:-:| | accessory | "MiHeaterCooler"                             | ✓ | | name     | 名称唯一                                       | ✓ | | address   | 空调伴侣的 ip 地址                              | ✓ | | token     | 执行 miio --discover 命令获取, 或者使用Get_MiHome_devices_token                | ✓ | | Manufacturer | 用于显示设备生产商信息,默认为Aqara       | ✓ | | Model | 用于显示设备型号信息,默认为二代空调伴侣       | ✓ | | sensorId   | 温湿度传感器 (必须绑定到此空调伴侣) id。执行 miio --control 空调伴侣ip --method get_device_prop --params '["lumi.0", "device_list"]' 命令获取(去除 'lumi.' 前缀)|| | enableLED  | true 或 'true'                                || | ratedPower | 瓦,空调额定功率,用于以「电池电量」显示当前功率百分比 || | idlePower | 瓦,用于判定当前是否处于空闲状态,默认值为 100       ||

其它

自动支持大部分品牌的第一套预设方案

否则, 你可以用 Android 模拟器(如 BlueStacks)和抓包工具 Wireshark 抓取并分析空调伴侣的命令码(执行 miio --token 空调伴侣token --json-dump 报文 命令获取),然后修改位于插件目录下的 template.json 文件

{
  "010500378033333102": {
    "tpl": "0180333331${p}${m}${w}${s}${th}${l}2",
    "brand": "haier",
    "set": "1"
  }
}

主键是空调伴侣的 model,执行 miio --control 空调伴侣ip --method get_model_and_state 命令获取

tpl 是该 model 的命令模板,用 ES6 模板字符串编写,可用以下变量:

/**
 * 生成命令码
 *
 * 如果你的方案下空调伴侣发出的命令形如 01xxxxxxxxpmwstlx(正如大部分品牌第一套预设方案一样)
 * 则无须此配置
 *
 * 用 ES6 模板字符串编写
 * 支持 +, -, *, /, %, ?:, [], toString(16) 等运算
 *
 * @param p  number 开关 0 : 关, 1 : 开
 * @param m  number 模式 0 : 制热, 1 : 制冷, 2 : 自动
 * @param w  number 风速 0 : 低, 1 : 中, 2 : 高, 3 : 自动
 * @param s  number 摆动 0 : 关, 1 : 开
 * @param td number 温度 十进制
 * @param th string 温度 十六进制
 * @param l  string 灯光 '0' : 开, 'a' : 关
 */