1
簡介
本demo是基于Openharmony 3.1 Beta本版開發(fā),不僅可以接收數(shù)字管家應(yīng)用下發(fā)的指令來控制門鎖開啟,而且還可以通過數(shù)字管家設(shè)置不同的開鎖密碼以及一次性密碼,實現(xiàn)給臨時用戶一個臨時密碼,保證門戶安全。當(dāng)然除了開鎖的功能,智能門鎖還可以通過檢測門與門鎖距離自動上鎖以及如果長時間未上鎖,上報告警消息到數(shù)字管家,及時提醒用戶關(guān)門關(guān)鎖等功能。
1. 交互流程:

如上圖所示,智能門鎖整體方案原理圖可以大致分成:智能門鎖設(shè)備、數(shù)字管家應(yīng)用、云平臺三部分。智能門鎖通過MQTT協(xié)議連接華為IOT物聯(lián)網(wǎng)平臺,從而實現(xiàn)命令的接收和屬性上報。關(guān)于智能設(shè)備接入華為云IoT平臺的詳細細節(jié)可以參考 連接IOT云平臺指南;智能設(shè)備與數(shù)字管家應(yīng)用之間的設(shè)備模型定義可以參考profile
2. 實物簡介:

如上圖所示,上面是XR806開發(fā)板,中間的是hcsr04超聲波距離傳感器,下面是E53_IA1擴展板。
我們是通過距離傳感器感應(yīng)門的距離,進行自動上鎖,也可以在一定時間內(nèi)無法上鎖而產(chǎn)生告警信息上傳到數(shù)字管家。
E53_IA1擴展板主要是通過控制電機模擬開關(guān)鎖的一個動作。
接線說明:

距離傳感器有4根線,其中echo接XR806的PA19,trig接XR806的PA20。
E53_IA1擴展板主需要接3根線,其中IO控制腳接XR806的PA12。
3. 實物操作體驗
2
快速上手
1. 硬件準(zhǔn)備
2. 環(huán)境準(zhǔn)備
參照文檔: XR806快速上手指導(dǎo)文檔
3. 編譯前準(zhǔn)備設(shè)備側(cè)代碼下載
具體倉庫地址:https://gitee.com/openharmony-sig/knowledge_demo_smart_home/
下載方式:使用git 命令下載,指令如下(用戶也可以根據(jù)需要將該倉庫fork到自己的目錄下后進行下載)
cd ~/
git clone git@gitee.com:openharmony-sig/knowledge_demo_smart_home.git
左右滑動查看全部代碼
代碼拷貝
cp -rfa ~/knowledge_demo_smart_home/dev/team_x ~/openharmony/vendor/
cp -rfa ~/knowledge_demo_smart_home/dev/third_party/iot_link ~/openharmony/third_party/
左右滑動查看全部代碼
整合并修改完成后的目錄結(jié)構(gòu)如下圖:

SOC代碼下載替換
當(dāng)前官方soc代碼由于DHCP暫未適配,所以暫時不支持AP模式,這時需要下載并替換之前SOC代碼。如果官方soc代碼已修復(fù)該問題,可忽略此步驟。
git clone https://gitee.com/moldy-potato-chips/xr806_-ap_mode.git
mv ~/openharmony/device/soc/allwinner ~/allwinner.org // 不建議直接刪除,
cp -raf xr806_-ap_mode ~/openharmony/device/soc/allwinner
左右滑動查看全部代碼
修改文件
-
修改編譯依賴
打開 device/soc/allwinner/xradio/xr806/BUILD.gn,添加應(yīng)用依賴(deps字段):
module_group(module_name) {
modules = [
"src",
"project",
"include",
]
configs = [
":SdkLdCconfig",
]
deps = [ "http://vendor/team_x/smart_lock/demo_smart_lock:app_smart_lock" ]
}
左右滑動查看全部代碼
-
修改編譯方式
將demo依賴的庫編譯方式(static_library)修改為(source_set):
具體依賴查看demo_smart_lock目錄下的BUILD.gn:
deps = [
"../../common/iot_wifi_xradio:iot_wifi",
"../../common/iot_cloud:iot_cloud",
"../../common/iot_boardbutton_xradio:iot_boardbutton",
"../../common/iot_list:iot_list",
"../../common/iot_sntp:iot_sntp",
"../../common/iot_boardled_xradio",
"http://third_party/cJSON:cJSON"
]
左右滑動查看全部代碼
其中//third_party/cJSON目錄下的BUILD.gn建議參照下面的修改:
source_set("cJSON") {
sources = [
"cJSON.c",
"cJSON_Utils.c",
]
ldflags = [ "-lm" ]
}
左右滑動查看全部代碼
-
修改iot_link中的部分文件
third_party/iot_link目錄下文件改動較多,此處以patch方式做修改,patch在路徑在(team_x/smart_lock/iot_link_patch_xr806.patch),主要修改內(nèi)容:
1.BUILD.gn修改source_set.
2.fd為0時通訊會異常,做了規(guī)避操作(socket創(chuàng)建時多創(chuàng)建一個)。
3.部分mbedtl接口未適配,做一些簡單適配以及無法適配的接口需要注釋
4.弱引用導(dǎo)致無法鏈接相關(guān)符號,因此需要注釋相關(guān)文件中的弱引用。
5.osDelay接口在XR806中未實現(xiàn),需要替換為OS_Msleep();
以上內(nèi)容修改的修改均在iot_link_patch_xr806.patch中,只需將該patch文件拷貝到third_party/iot_link目錄下,并執(zhí)行打補丁即可:
cp -af vendor/team_x/smart_lock/iot_link_patch_xr806.patch third_party/iot_link // 拷貝patch文件到對應(yīng)目錄
cd third_party/iot_link/ // cd 到對應(yīng)目錄
patch -p1<./iot_link_patch_xr806.patch ? ? ? ? ? ? ? ? ? ? ? ?// 執(zhí)行打patch動作
左右滑動查看全部代碼
-
修改GPIO查找方式
因為GPIO框架修改了設(shè)備驅(qū)動注冊的管腳號,導(dǎo)致應(yīng)用無法根據(jù)HCS的引腳操作對應(yīng)的GPIO,此問題已經(jīng)提issue,如果該問題已解決,可以忽略此步驟。
打開drivers/framework/support/platform/src/gpio/gpio_manager.c,將cntlr->start = start;注釋即可。
static int32_t GpioManagerAdd(struct PlatformManager *manager, struct PlatformDevice *device)
{
uint16_t start;
struct GpioCntlr *cntlr = CONTAINER_OF(device, struct GpioCntlr, device);
if ((start = GpioCntlrQueryStart(cntlr, &manager->devices)) >= GPIO_NUM_MAX) {
PLAT_LOGE("GpioCntlrAdd: query range for start:%d fail:%d", cntlr->start, start);
return HDF_ERR_INVALID_PARAM;
}
// cntlr->start = start;
DListInsertTail(&device->node, &manager->devices);
PLAT_LOGI("%s: start:%u count:%u", __func__, cntlr->start, cntlr->count);
return HDF_SUCCESS;
}
左右滑動查看全部代碼
-
將對應(yīng)的驅(qū)動文件復(fù)制到drvier對應(yīng)目錄:
因為主倉代碼中未將對應(yīng)的驅(qū)動文件合并到driver/adpater/platform對應(yīng)的目錄下,固需要手動將文件拷貝到對應(yīng)目錄。若主倉已合入,可忽略此步驟。
注意:(如果已用xr806_-ap_mode替換原來的soc文件,則需要將拷貝原來被替換的對應(yīng)文件,因為xr806_-ap_mode中的驅(qū)動文件非最新版)
// 拷貝gpio驅(qū)動
cp -af device/soc/allwinner/xradio/drivers/gpio/gpio_xradio.* driver/adpater/platform/gpio
// 修改driver/adpater/platform/gpio/BUILD.gn文件,加上gpio_xradio的編譯
hdf_driver(module_name) {
sources = []
if (defined(LOSCFG_SOC_COMPANY_BESTECHNIC)) {
sources += [ "gpio_bes.c" ]
}
if (defined(LOSCFG_SOC_COMPANY_ALLWINNER)) {
sources += [ "gpio_xradio.c" ]
}
include_dirs = [ "." ]
}
左右滑動查看全部代碼
-
為了節(jié)省ram資源,可以把無用的資源先關(guān)閉,如關(guān)閉內(nèi)部codec,將 device/soc/allwinner/xradio/xr806/project/prj_config.h中的PRJCONF_INTERNAL_SOUNDCARD_EN設(shè)置為0,如下:
/* Xradio internal codec sound card enable/disable */
左右滑動查看全部代碼
4. 編譯&燒錄
更新hb
首先可以查看一下hb的版本,如果hb版本為0.4.4就不需要更新。
## 查看hb版本
hb --version
## 更新hb, 以下指令需要在openharmony SDK根目錄執(zhí)行
pip3 uninstall ohos_build
pip3 install build/lite
左右滑動查看全部代碼
編譯
1.hb set 選擇demo指令,具體命令如下:
hb set -root
左右滑動查看全部代碼
如下圖所示,使用鍵盤上下鍵選中smart_lock

2.hb build 全量編譯命令
hb build -f
左右滑動查看全部代碼

燒錄:參照文檔:XR806快速上手指導(dǎo)文檔
5. 設(shè)備配網(wǎng)
-
在設(shè)備上電前需準(zhǔn)備好安裝了數(shù)字管家應(yīng)用的HarmonyOS手機,詳情見數(shù)字管家應(yīng)用開發(fā), 并在設(shè)置中開啟手機的NFC功能;
-
寫設(shè)備NFC標(biāo)簽,詳細操作見設(shè)備NFC標(biāo)簽指導(dǎo)文檔;
-
燒錄完成后,上電。開發(fā)者在觀察開發(fā)板上狀態(tài)LED燈以8Hz的頻率閃爍時,將手機上半部靠近開發(fā)板NFC標(biāo)簽處(無NFC標(biāo)簽的可用NFC貼紙?zhí)娲?;
-
碰一碰后手機將自動拉起數(shù)字管家應(yīng)用并進入配網(wǎng)狀態(tài)。
-
配網(wǎng)過程中需要 連接設(shè)備的AP熱點,然后填寫需要配置的wifi的密碼。
-
最后點擊配置,手機會將ssid以及對應(yīng)的密碼通過AP熱點發(fā)送到設(shè)備。
-
當(dāng)設(shè)備端藍燈每5s閃爍一次則代碼設(shè)備聯(lián)網(wǎng)成功。
6. 設(shè)置主密碼并通過主密碼開鎖
-
數(shù)字管家下發(fā)修改密碼指令以及修改后的密碼
-
設(shè)備端接收指令以及修改后的密碼進行更新
-
數(shù)字管家下方開鎖指令以及開鎖密碼
-
設(shè)備端接收指令并判斷密碼是否正確,正確的話電機轉(zhuǎn)動模擬開鎖,否則向數(shù)字管家發(fā)送密碼錯誤信息
7. 設(shè)置臨時密碼
-
數(shù)字管家下發(fā)創(chuàng)建臨時密碼指令以及創(chuàng)建臨時密碼時的信息,主要包括臨時密碼標(biāo)志,臨時密碼信息,臨時密碼生效時間段。
-
設(shè)備端接收指令并保存信息。
-
臨時用戶通過數(shù)字管家下發(fā)開鎖指令以及開發(fā)密碼。
-
設(shè)備端接收指令并判斷密碼是否正確以及該密碼是否在當(dāng)前時間段生效,正確的話電機轉(zhuǎn)動模擬開鎖,否則向數(shù)字管家發(fā)送密碼錯誤信息。
8. 門未關(guān)告警
-
設(shè)備端執(zhí)行完開門指令后會一直通過超聲波距離傳感器來判斷門是否可以關(guān)閉,如果超過5分鐘發(fā)現(xiàn)門不能關(guān)閉,則主動向數(shù)字管家發(fā)送門未關(guān)的告警信息。
-
數(shù)字管家通過系統(tǒng)消息查看到告警消息。
-
數(shù)字管家可以從設(shè)備控制頁面進入到告警消息頁面,也可以通過點擊告警消息進入到告警界面。
9. 模擬自動關(guān)門
-
設(shè)備端執(zhí)行開門動作后,用手或者其他物體靠近超聲波距離傳感器
-
設(shè)備每隔10S檢測一次超聲波距離傳感器,發(fā)現(xiàn)在設(shè)定范圍內(nèi)(模擬門已關(guān)),則控制電機轉(zhuǎn)動(模擬關(guān)門動作),同時上報關(guān)門信息到數(shù)字管家
原文標(biāo)題:OpenHarmony開發(fā)樣例:智能門鎖
文章出處:【微信公眾號:HarmonyOS官方合作社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
-
開發(fā)
+關(guān)注
關(guān)注
0文章
373瀏覽量
41426 -
智能門鎖
+關(guān)注
關(guān)注
17文章
1889瀏覽量
44149 -
OpenHarmony
+關(guān)注
關(guān)注
29文章
3847瀏覽量
18346
原文標(biāo)題:OpenHarmony開發(fā)樣例:智能門鎖
文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
OpenHarmony 項目實戰(zhàn):基于全志 XR806 實現(xiàn)的上下位機雙 OpenHarmony 智能門鎖樣例

低功耗藍牙智能門鎖應(yīng)用

智能門鎖(NFC架構(gòu))方案
藍牙智能門鎖解決方案 BLE藍牙指紋智能門鎖開發(fā)方案
藍牙智能門鎖解決方案
基于32位單片機的智能門鎖解決方案
如何去實現(xiàn)一種基于STM32和freeRTOS智能門鎖設(shè)計
智能門鎖電機驅(qū)動集成電路(IC)設(shè)計方案

基于STM32和freeRTOS智能門鎖設(shè)計方案

評論