ESP32环境搭建 HomeKit 平台搭建 苹果智能家居HomeKit
本文所有操作环境在linux下,参考README文档,官方sdk获取连接https://github.com/espressif/esp-apple-homekit-adk
HomeKit是Apple开发的框架,用于使用iOS设备与用户家里的连接附件进行通讯和控制。该项目是Apple的ESP32和ESP32S2开源HomeKit ADK的移植版本。任何开发人员都可以使用它来制作非商业智能家居配件的原型。
第1步:IDF环境
IDF分支 release/v4.2 ,然后拉去最新代码
$git pull origin release/v4.2
$git log
commit 636b964c8cceee900e5ff1dd4d5d38852de0fc42 (HEAD -> release/v4.2, origin/release/v4.2)
第2步:设置 MbedTLS
ESP-IDF当前使用MbedTLS 2.16.x,而HomeKit ADK需要2.18。这里here维护着一个分支mbedtls-2.16.6-adk,该分支具有2.16.6之上的2.18版本所需的补丁。若要切换到此,请按照下列步骤操作:
$ cd $IDF_PATH/components/mbedtls/mbedtls
$ git checkout -b mbedtls-2.16.6-adk origin/mbedtls-2.16.6-adk
$ git pull
第3步: 获取仓库代码esp-apple-homekit-adk
$ git clone --recursive https://github.com/espressif/esp-apple-homekit-adk.git
注意--recursive选项。这是将HomeKit ADK存储库放入esp-apple-homekit-adk所必需的。如果您已经克隆了没有此选项的存储库,则对子模块中的pull执行此操作:git submodule update --init --recursive
第4步: 编译烧录
您可以将esp-apple-homekit-adk与任何ESP32或ESP32-S2开发板一起使用。我们提供了一个灯泡示例供参考。编译并下载如下:
进入example的代码中编译,在官方的demo中,我测试无法编译通过,会有如下错误:
CMake Error at /home/share/esp/esp-adf/esp-idf/tools/cmake/component.cmake:221 (message):
CMake Error at /usr/share/cmake-3.16/Modules/ExternalProject.cmake:1029
(define_property):
define_property command is not scriptable
Call Stack (most recent call first):
修改Lightbulb目录中的CMakeLists.txt文件,如下:
$ idf.py menuconfig #可以修改wifi ssid和密码, 串口号(也可以通过 export ESPPORT=/dev/ttyUSBx 修改)
$ idf.py build
$ idf.py flash
$ esptool.py write_flash 0x340000 accessory_setup.bin
$ idf.py monitor
当设备启动并连接到家庭Wi-Fi网络(使用menuconfig配置)时,您将看到一些类似以下的日志:
第五步:Home app使用
- 在iPhone / iPad上打开“家庭”应用程序,然后执行以下步骤
- 选择"Add or Scan Accessory"
- 选择"I Don't Have a Code or Cannot Scan"
- 在附近配件列表中点击“Acme Light Bulb”
- 为“Uncertified Accessory”提示选择“Add Anyway”选项。
- 输入11122333并确认
- 继续选择next,然后选在DONE,可以选择添加场景
重新设置配对代码(11122333):url
复位配对:
附件配对信息存储在NVS(非易失性存储)分区中。一旦配对,附件将无法再次配对,除非先清除此配对信息。可以通过以下方式完成:
$ esptool.py -p $ESPPORT erase_region 0x10000 0x6000
具体调试日志在app.c添加打印
欢迎留言交流.2018.08.03
更多推荐
所有评论(0)