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

ESP32环境搭建 HomeKit 平台搭建 苹果智能家居HomeKit_第1张图片

 

第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):

ESP32环境搭建 HomeKit 平台搭建 苹果智能家居HomeKit_第2张图片

 

修改Lightbulb目录中的CMakeLists.txt文件,如下:

ESP32环境搭建 HomeKit 平台搭建 苹果智能家居HomeKit_第3张图片

 

$ 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配置)时,您将看到一些类似以下的日志:

ESP32环境搭建 HomeKit 平台搭建 苹果智能家居HomeKit_第4张图片

 

第五步: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

你可能感兴趣的:(物联网)