国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】

這篇具有很好參考價值的文章主要介紹了OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

樣例簡介

智能門鈴?fù)ㄟ^監(jiān)控來訪者信息,告訴主人門外是否有人按鈴、有陌生人靠近或者無人狀態(tài)。主人可以在數(shù)字管家中遠程接收消息,并根據(jù)需要進行遠程取消報警和一鍵開鎖。同時,也可以通過室內(nèi)屏幕獲取門外狀態(tài)。室內(nèi)屏幕顯示界面使用DevEco Studio 編寫的js應(yīng)用,具有很好的兼容和移植特性。硬件上采用了帶有HDF框架的驅(qū)動模型,通過GPIO來獲取傳感器采集信息并驅(qū)動報警器進行動作。

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

運行效果

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

樣例原理

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

如上圖所示,智能門鈴整體方案原理圖可以大致分成:智能門鈴設(shè)備、數(shù)字管家應(yīng)用、云平臺三部分。智能門鈴?fù)ㄟ^MQTT協(xié)議連接華為IOT物聯(lián)網(wǎng)平臺,從而實現(xiàn)命令的接收和屬性上報。 。

工程版本
  • 系統(tǒng)版本/API版本:OpenHarmony 3.1 Beta
  • hb版本:0.4.4
  • 工具鏈版本:gcc-arm-none-eabi-10.3-2021.10
  • 鴻蒙開發(fā)指導(dǎo)文檔:gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md點擊或者復(fù)制轉(zhuǎn)到。

快速上手

準備硬件環(huán)境
  • 歐智通V200Z-R開發(fā)板
  • 潤和智能家居套件-紅綠燈板
  • 潤和智能家居套件-炫彩燈板
  • 預(yù)裝HarmonyOS手機一臺

    注:HarmonyOS是華為基于開源項目OpenHarmony開發(fā)的面向多種全場景智能設(shè)備的商用版本

準備開發(fā)環(huán)境

HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

安裝必備軟件

開發(fā)基礎(chǔ)環(huán)境由 windows 工作臺和 Linux 編譯服務(wù)器組成。windows 工作臺可以通過 samba 服務(wù)或 ssh 方式訪問 Linux編譯服務(wù)器。其中 windows 工作臺用來燒錄和代碼編輯,Linux 編譯服務(wù)器用來編譯 OpenHarmony 代碼,為了簡化步驟,Linux 編譯服務(wù)器推薦安裝 Ubuntu20.04。

安裝編譯依賴基礎(chǔ)軟件
sudo apt-get install -y build-essential gcc g++ make zlib* libffi-dev git git-lfs
安裝和配置Python
  • 打開Linux終端。
  • 輸入如下命令,查看python版本號,需要使用python3.7以上版本。
python3 --version
  • 安裝并升級Python包管理工具(pip3)。
sudo apt-get install python3-setuptools python3-pip -y
sudo pip3 install --upgrade pip
  • 設(shè)置pip的國內(nèi)鏡像
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple requests
安裝hb
  • 輸入如下命令確認hb是否為version 0.4.4
hb -v

a. 若提示如下內(nèi)容,則表示未安裝可以從第2步開始操作。

bash: /home/***/.local/bin/hb: No such file or directory

b.若提示如下內(nèi)容,需要先卸載該版本,然后再執(zhí)行第2步操作步驟。

[OHOS INFO] hb version 0.4.3

卸載命令:

pip3 uninstall ohos-build
  • 運行如下命令安裝hb
pip3 install build/lite   // 該命令需在OpenHarmony源碼根目錄下執(zhí)行
  • 設(shè)置環(huán)境變量
vim ~/.bashrc

將以下命令拷貝到.bashrc文件的最后一行,保存并退出。

export PATH=~/.local/bin:$PATH

執(zhí)行如下命令更新環(huán)境變量。

source ~/.bashrc
  • 再次執(zhí)行”hb -v“,有以下版本顯示則表示安裝的hb版本正確。
[OHOS INFO] hb version 0.4.4
安裝交叉編譯環(huán)境

在Linux編譯服務(wù)器上搭建好基礎(chǔ)開發(fā)環(huán)境后,需要安裝OpenHarmony 編譯V200Z-R平臺特有的開發(fā)環(huán)境。

安裝arm-none-eabi-gcc
  • 打開Linux終端。
  • 下載[arm-none-eabi-gcc]編譯工具。
  • 安裝[arm-none-eabi-gcc]

解壓?[gcc-arm-none-eabi-10.3-2021.10-x86_64-linux.tar.bz2]安裝包至~/toolchain/路徑下。

mkdir -p ~/toolchain/
tar -jxvf gcc-arm-none-eabi-10.3-2021.10-x86_64-linux.tar.bz2 -C ~/toolchain/

設(shè)置環(huán)境變量。

vim ~/.bashrc

將以下命令拷貝到.bashrc文件的最后一行,保存并退出。

export PATH=~/toolchain/gcc-arm-none-eabi-10.3-2021.10/bin:$PATH

生效環(huán)境變量。

source ~/.bashrc
  • 在命令行中輸入如下命令,如果能正確顯示編譯器版本號,表明編譯器安裝成功。
arm-none-eabi-gcc -v
準備工程

本用例采用repo的方式從碼云官倉下載系統(tǒng)系統(tǒng)源碼以及開發(fā)板適配代碼,使用git從gitee的sig倉庫拉取設(shè)備應(yīng)用代碼。

配置git
  • 提前注冊準備碼云gitee賬號。
  • git工具下載安裝

    sudo apt install git
    sudo apt install git-lfs
  • 生成/添加SSH密鑰:生成密鑰

    使用gitee賬號綁定的郵箱生成密鑰對

    ssh-keygen -t ed25519 -C "xxxxx@xxxxx.com"
  • 查看生成的密鑰

    cat ~/.ssh/id_ed25519.pub
  • 復(fù)制生成后的 ssh key,返回gitee個人主頁,通過主頁 「個人設(shè)置」->「安全設(shè)置」->「SSH 公鑰」 ,將生成的“SSH密鑰”添加到倉庫中。
  • 配置git用戶信息

    git config --global user.name "yourname"
    git config --global user.email "your-email-address"
    git config --global credential.helper store
準備repo
sudo curl https://gitee.com/oschina/repo/raw/fork_flow/repo-py3 > /usr/local/bin/repo
chmod a+x /usr/local/bin/repo
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple requests
準備系統(tǒng)源碼
#特別注意:請下載OpenHarmony 3.1 Beta版本
mkdir ~/OpenHarmony_3.1_Beta
cd ~/OpenHarmony_3.1_Beta
repo init -u git@gitee.com:openharmony/manifest.git -b refs/tags/OpenHarmony-v3.1-Beta --no-repo-verify
repo sync -c
repo forall -c 'git lfs pull'

注意:

  • 權(quán)限問題請參考[生成/添加SSH公鑰]。
  • 若在已安裝python3.8后,執(zhí)行repo init 時,仍顯示如下錯誤:
/usr/bin/env: ‘python’: No such file or directory

執(zhí)行如下命令后,進行重試:

sudo ln -s /usr/bin/python3.8 /usr/bin/python
準備設(shè)備側(cè)應(yīng)用代碼

使用git 命令下載

git clone git@gitee.com:openharmony-sig/knowledge_demo_smart_home.git --depth=1
編譯前準備
  • 代碼拷貝

team_x源碼拷貝

mkdir ~/OpenHarmony_3.1_Beta/vendor/team_x
cp -rfa ~/knowledge_demo_smart_home/dev/team_x/smart_door_bell ~/OpenHarmony_3.1_Beta/vendor/team_x

common庫拷貝

cp -rfa ~/knowledge_demo_smart_home/dev/team_x/common ~/OpenHarmony_3.1_Beta/vendor/team_x

iot_link庫拷貝

cp -rfa ~/knowledge_demo_smart_home/dev/third_party/iot_link ~/OpenHarmony_3.1_Beta/third_party/
  • kernel/liteos_m 修改

步驟1、下載patch

? 點擊上述鏈接進入瀏覽器,將該網(wǎng)頁中內(nèi)容全部復(fù)制。

? 本地創(chuàng)建一個名為bes_kernle.patch文件,并將已經(jīng)復(fù)制的內(nèi)容粘貼到該文件中。

步驟2、 打上步驟1中的patch

cd ~/OpenHarmony_3.1_Beta/kernel/liteos_m
patch -p1 < bes_kernle.patch
  • device/soc/bestechnic 修改

步驟1、下載patch

? 點擊上述鏈接進入瀏覽器,將該網(wǎng)頁中內(nèi)容全部復(fù)制。

? 本地創(chuàng)建一個名為bes_device.patch文件,并將已經(jīng)復(fù)制的內(nèi)容粘貼到該文件中。

步驟2、 打上步驟1中的patch

cd ~/OpenHarmony_3.1_Beta/device/soc/bestechnic
patch -p1 < bes_device.patch
  • third_party/mbedtls 修改

參考如下代碼段修改 mbedtls/library/platform.c

diff --git a/library/platform.c b/library/platform.c
index c4c3fd3..214173b 100755
--- a/library/platform.c
+++ b/library/platform.c
@@ -86,9 +86,24 @@ static void platform_free_uninit( void *ptr )
 static void * (*mbedtls_calloc_func)( size_t, size_t ) = MBEDTLS_PLATFORM_STD_CALLOC;
 static void (*mbedtls_free_func)( void * ) = MBEDTLS_PLATFORM_STD_FREE;
 
+#include "los_memory.h"
+
 void * mbedtls_calloc( size_t nmemb, size_t size )
 {
-    return (*mbedtls_calloc_func)( nmemb, size );
+    //return (*mbedtls_calloc_func)( nmemb, size );
+    size_t real_size;
+    void *ptr = NULL;
+
+    if (nmemb == 0 || size == 0) {
+        return NULL;
+    }
+
+    real_size = (size_t)(nmemb * size);
+    ptr = LOS_MemAlloc(OS_SYS_MEM_ADDR, real_size);
+    if (ptr != NULL) {
+        (void)memset_s(ptr, real_size, 0, real_size);
+    }
+    return ptr;
 }

參考如下代碼段修改 mbedtls/BUILD.gn

diff --git a/BUILD.gn b/BUILD.gn
index 9ecb37a..30dbb2e 100755
--- a/BUILD.gn
+++ b/BUILD.gn
@@ -124,6 +124,7 @@ if (ohos_kernel_type == "liteos_m") {
      include_dirs = [
        "http://kernel/liteos_m/kal/posix/include",
         "http://kernel/liteos_m/kernel/include",
         "http://kernel/liteos_m/utils",
        "http://third_party/musl/porting/liteos_m/kernel/include/",
+        "http://kernel/liteos_m/kernel/include/",
       ]
     }
     output_name = "mbedtls"
  • third_party/lwip 修改

修改src/api/netdb.c 文件

diff --git a/src/api/netdb.c b/src/api/netdb.c
index 52a6fdf..2043636 100644
--- a/src/api/netdb.c
+++ b/src/api/netdb.c
@@ -100,7 +100,7 @@ lwip_gethostbyname(const char *name)
   err = netconn_gethostbyname(name, &addr);
   if (err != ERR_OK) {
     LWIP_DEBUGF(DNS_DEBUG, ("lwip_gethostbyname(%s) failed,   err=%d\n", name, err));
-    h_errno = HOST_NOT_FOUND;
+    //h_errno = HOST_NOT_FOUND;
     return NULL;
   }
  • third_party/iot_link 修改

參考如下代碼段修改 third_party/iot_link/network/dtls/BUILD.gn

diff --git a/third_party/iot_link/network/dtls/BUILD.gn b/third_party/iot_link/network/dtls/BUILD.gn
index 035805d709075ef2bc9d9388e73edb84dc1ee943..ac7256cf2bc93a0a998388f31910f152bf306fa9 100755
--- a/third_party/iot_link/network/dtls/BUILD.gn
+++ b/third_party/iot_link/network/dtls/BUILD.gn
@@ -41,7 +41,8 @@ dtls_cflags = [
     "-Wno-unused-parameter",
 ]
 
-static_library("dtls") {
+#static_library("dtls") {
+source_set("dtls") {
         cflags = dtls_cflags
         defines = dtls_def
         sources = dtls_src

參考如下代碼段修改 third_party/iot_link/network/dtls/mbedtls/mbedtls_port/dtls_interface.c

diff --git a/third_party/iot_link/network/dtls/mbedtls/mbedtls_port/dtls_interface.c b/third_party/iot_link/network/dtls/mbedtls/mbedtls_port/dtls_interface.c
index 9f87c6fae041b17af4522d5d89114b69005a00be..73e406893a33385a9888a82cf6d1b3706a81387d 100755
--- a/third_party/iot_link/network/dtls/mbedtls/mbedtls_port/dtls_interface.c
+++ b/third_party/iot_link/network/dtls/mbedtls/mbedtls_port/dtls_interface.c
@@ -56,6 +56,7 @@
 #include "dtls_interface.h"
 #include "mbedtls/net_sockets.h"
 #include "mbedtls/ssl_internal.h"
+#include "mbedtls/platform.h"
 #include "cmsis_os2.h"
 #include "string.h"
 
@@ -157,6 +158,7 @@ mbedtls_ssl_context *dtls_ssl_new(dtls_establish_info_s *info, char plat_type)
 #if defined(MBEDTLS_KEY_EXCHANGE__SOME__PSK_ENABLED)
     if (info->psk_or_cert == VERIFY_WITH_PSK)
     {
+      #if 0
         if ((ret = mbedtls_ssl_conf_psk(conf,
                                         info->v.p.psk,
                                         info->v.p.psk_len,
@@ -166,6 +168,7 @@ mbedtls_ssl_context *dtls_ssl_new(dtls_establish_info_s *info, char plat_type)
             MBEDTLS_LOG("mbedtls_ssl_conf_psk failed: -0x%x", -ret);
             goto exit_fail;
         }
+        #endif
     }
 #endif
 
@@ -548,5 +551,5 @@ void dtls_init(void)
 {
     (void)mbedtls_platform_set_calloc_free(calloc, free);
     (void)mbedtls_platform_set_snprintf(snprintf);
-    (void)mbedtls_platform_set_printf(printf);
+    //(void)mbedtls_platform_set_printf(printf);
 }

參考如下代碼段修改 third_party/iot_link/network/mqtt/BUILD.gn

diff --git a/third_party/iot_link/network/mqtt/BUILD.gn b/third_party/iot_link/network/mqtt/BUILD.gn
index 5a4a8e0ded129b91ce550a5d16f04e0784fddd45..d6bc39b8ede5735d79c74a6ab562c6141bd0b377 100755
--- a/third_party/iot_link/network/mqtt/BUILD.gn
+++ b/third_party/iot_link/network/mqtt/BUILD.gn
@@ -16,6 +16,7 @@ mqtt_paho_inc = [
     "paho_mqtt/paho/MQTTPacket/src",
     "paho_mqtt/port",
     "../../inc",
+    "http://third_party/musl/porting/liteos_m/kernel/include/",
     "http://kernel/liteos_m/components/cmsis/2.0",
     "http://vendor/hisi/hi3861/hi3861/third_party/lwip_sack/include/",
 ]
@@ -50,7 +51,8 @@ mqtt_cflags = [
     "-Wno-unused-function",
 ]
 
-static_library("mqtt") {
+#static_library("mqtt") {
+source_set("mqtt") {
         cflags = mqtt_cflags
         defines = mqtt_paho_defs
         sources = mqtt_paho_src

參考如下代碼段修改 third_party/iot_link/network/mqtt/paho_mqtt/port/paho_mqtt_port.c

diff --git a/third_party/iot_link/network/mqtt/paho_mqtt/port/paho_mqtt_port.c b/third_party/iot_link/network/mqtt/paho_mqtt/port/paho_mqtt_port.c
index a213b74c7286c68061e3285c0c3ac6c440949f26..d0900c8d88149f08c93fe885f34f4d2affa30885 100755
--- a/third_party/iot_link/network/mqtt/paho_mqtt/port/paho_mqtt_port.c
+++ b/third_party/iot_link/network/mqtt/paho_mqtt/port/paho_mqtt_port.c
@@ -180,6 +180,50 @@ static int __socket_read(void *ctx, unsigned char *buf, int len, int timeout)
     int fd;
     int ret = 0;
 
+#if 1
+        int bytes = 0;
+    fd_set fdset;
+
+    struct timeval timedelay = {timeout / 1000, (timeout % 1000) * 1000};
+    if(NULL== buf)
+    {
+        return ret;
+    }
+
+    fd = (int)(intptr_t)ctx;  ///< socket could be zero
+
+    if (timedelay.tv_sec < 0 || (timedelay.tv_sec == 0 && timedelay.tv_usec <= 0))
+    {
+        timedelay.tv_sec = 0;
+        timedelay.tv_usec = 100;
+    }
+    timedelay.tv_sec = 5;
+    FD_ZERO(&fdset);
+    FD_SET(fd, &fdset);
+
+    ret = select(fd + 1, &fdset, NULL, NULL, &timedelay);
+    printf("[%s|%s|%d]fd = %d, ret = %d\n", __FILE__,__func__,__LINE__, fd, ret);
+    if (ret > 0) {
+        while (bytes < len) {
+            int rc = recv(fd, &buf[bytes], (size_t)(len - bytes), 0);
+            printf("[%s|%s|%d]fd = %d, rc = %d\n", __FILE__,__func__,__LINE__, fd, rc);
+            if (rc == -1) {
+                if (errno != EAGAIN && errno != EWOULDBLOCK) {
+                    bytes = -1;
+                }
+                break;
+            } else if (rc == 0) {
+                bytes = 0;
+                break;
+            } else {
+                bytes += rc;
+            }
+        }
+   }
+
+   return bytes;
+#else
+
     struct timeval timedelay = {timeout / 1000, (timeout % 1000) * 1000};
     if(NULL== buf)
     {
@@ -216,7 +260,7 @@ static int __socket_read(void *ctx, unsigned char *buf, int len, int timeout)
         }
     }
     return bytes;
-
+  #endif
 }
 
 
@@ -586,7 +630,7 @@ static void * __connect(mqtt_al_conpara_t *conparam)
     attr.cb_mem = NULL;
     attr.cb_size = 0U;
     attr.stack_mem = NULL;
-    attr.stack_size = 1024 * 2;
+    attr.stack_size = 1024 * 4;
     attr.priority = 28;
     cb->task = osThreadNew((osThreadFunc_t)__loop_entry, cb, &attr);
     if(NULL == cb->task)

參考如下代碼段修改 third_party/iot_link/network/mqtt/paho_mqtt/port/paho_osdepends.h

diff --git a/third_party/iot_link/network/mqtt/paho_mqtt/port/paho_osdepends.h b/third_party/iot_link/network/mqtt/paho_mqtt/port/paho_osdepends.h
index 2c6cab1b90bef7be82891637c200cdb664e9735b..38e3dce3867d2b2d538858c72b36bee7330c7b4f 100755
--- a/third_party/iot_link/network/mqtt/paho_mqtt/port/paho_osdepends.h
+++ b/third_party/iot_link/network/mqtt/paho_mqtt/port/paho_osdepends.h
@@ -84,6 +84,7 @@
 
 #include "ohos_init.h"
 #include "cmsis_os2.h"
+#include "sys/time.h"
 #include  <mqtt_al.h>
 
 #define MQTT_TASK 1
@@ -117,6 +118,13 @@ typedef struct Thread
 int ThreadStart(Thread*, void (*fn)(void*), void* arg);
 
 
+#define timeradd(s,t,a) (void) ( (a)->tv_sec = (s)->tv_sec + (t)->tv_sec, \
+        ((a)->tv_usec = (s)->tv_usec + (t)->tv_usec) >= 1000000 && \
+        ((a)->tv_usec -= 1000000, (a)->tv_sec++) )
+#define timersub(s,t,a) (void) ( (a)->tv_sec = (s)->tv_sec - (t)->tv_sec, \
+        ((a)->tv_usec = (s)->tv_usec - (t)->tv_usec) < 0 && \
+        ((a)->tv_usec += 1000000, (a)->tv_sec--) )
+
 typedef struct Network
 {
     void *ctx;                      ///< if it is tls, then it is tls context, else it is socket fd

參考如下代碼段修改 third_party/iot_link/oc_mqtt/BUILD.gn

diff --git a/third_party/iot_link/oc_mqtt/BUILD.gn b/third_party/iot_link/oc_mqtt/BUILD.gn
index c777c5e4f2e79646a5c76471f22c5437e9d4b3ee..1e3e07ddb6c0bc52465a60c415c8550608a21e55 100755
--- a/third_party/iot_link/oc_mqtt/BUILD.gn
+++ b/third_party/iot_link/oc_mqtt/BUILD.gn
@@ -11,7 +11,8 @@
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
-static_library("oc_mqtt") {
+#static_library("oc_mqtt") {
+source_set("oc_mqtt") {
     sources = [
         "oc_mqtt_al/oc_mqtt_al.c",
         "oc_mqtt_profile_v5/oc_mqtt_profile.c",
  • communicationkit相關(guān)修改

參考下方代碼修改foundation/ace/ace_engine_lite/frameworks/module_manager/ohos_module_config.h

diff --git a/frameworks/module_manager/ohos_module_config.h b/frameworks/module_manager/ohos_module_config.h
index f8eb744..3bb25d1 100644
--- a/frameworks/module_manager/ohos_module_config.h
+++ b/frameworks/module_manager/ohos_module_config.h
@@ -47,6 +47,10 @@ extern void InitNativeApiFs(JSIValue exports);
 extern void InitNativeApiKv(JSIValue exports);
 #endif

+#if (FEATURE_MODULE_COMMUNICATIONKIT == 1)
+extern void InitNativeApiCommunicationKit(JSIValue exports);
+#endif
+
 #if (FEATURE_MODULE_DEVICE == 1)
 extern void InitDeviceModule(JSIValue exports);
 #endif
@@ -98,11 +102,13 @@ const Module OHOS_MODULES[] = {
 #if (FEATURE_MODULE_DIALOG == 1)
     {"prompt", InitDialogModule},
 #endif // FEATURE_MODULE_DIALOG
-
 #if (FEATURE_MODULE_STORAGE == 1)
     {"file", InitNativeApiFs},
     {"storage", InitNativeApiKv},
 #endif
+#if (FEATURE_MODULE_COMMUNICATIONKIT == 1)
+    {"CommunicationKit", InitNativeApiCommunicationKit},
+#endif
 #if (FEATURE_MODULE_DEVICE == 1)
     {"device", InitDeviceModule},
 #endif
  • flash_size配置修改

根據(jù)開發(fā)板的硬件版本不同,還需更改配置文件中flash_size的值。具體路徑為/device/board/fnlink/v200zr/liteos_m/config.gni。其中v1.0版本對應(yīng)16,2.0版本對應(yīng)32,硬件版本打印在了開發(fā)板正面。

diff --git a/v200zr/liteos_m/config.gni b/v200zr/liteos_m/config.gni
index b288101..6489dd2 100644
--- a/v200zr/liteos_m/config.gni
+++ b/v200zr/liteos_m/config.gni
@@ -47,7 +47,7 @@ if (product_path != "") {
   bsp_bin_list = product_conf.bsp_bin_list
   pack_burn = product_conf.pack_burn
 }
-flash_size = 16
+flash_size = 32
  • hdf配置文件修改

參考下方代碼修改device/board/fnlink/shields/v200zr-evb-t1/v200zr-evb-t1.hcs

diff --git a/shields/v200zr-evb-t1/v200zr-evb-t1.hcs b/shields/v200zr-evb-t1/v200zr-evb-t1.hcs
index 44212eb..4fc99da 100644
--- a/shields/v200zr-evb-t1/v200zr-evb-t1.hcs
+++ b/shields/v200zr-evb-t1/v200zr-evb-t1.hcs
@@ -17,12 +17,17 @@ root {
     platform {
         gpio_config {
             match_attr = "gpio_config";
-            pin = [0, 1];
+            pin = [0, 1, 2, 3, 4, 5, 6, 7];
             // touch_ztw523: TSP_RST - GPIO12, TSP_INT-GPIO27
             // touch_fts: TSP_RST - GPIO05, TSP_INT-GPIO27
-            realPin = [5, 27];
-            config = [5, 2];
-            pinNum = 2;
+            realPin = [5, 27, 1, 11, 15, 10, 14, 13];
+            config = [5, 2, 2, 4, 5, 5, 5, 2];
+            pinNum = 8;
+        }
+        pwm0_config{
+            match_attr = "pwm0_config";
+            pwmId = 0;
+            pwmPin = 20;
         }
         i2c_config {
             i2c0 {
  • gpio hdf框架相關(guān)修改。

根據(jù)下方代碼修改drivers/adapter/platform/gpio/gpio_bes.c

diff --git a/platform/gpio/gpio_bes.c b/platform/gpio/gpio_bes.c
index ed4d18b..890d528 100755
--- a/platform/gpio/gpio_bes.c
+++ b/platform/gpio/gpio_bes.c
@@ -257,7 +257,7 @@ static int32_t GpioDriverBind(struct HdfDeviceObject *device)
     }

     gpioCntlr.device.hdfDev = device;
-    device->service = gpioCntlr.device.service;
+    device->service = &(gpioCntlr.device);

     return HDF_SUCCESS;
 }
  • 將pwm_if.c納入編譯。

參考下方代碼修改drivers\adapter\khdf\liteos_m\platform\BUILD.gn

diff --git a/khdf/liteos_m/platform/BUILD.gn b/khdf/liteos_m/platform/BUILD.gn
index 84c9152..8a4016a 100755
--- a/khdf/liteos_m/platform/BUILD.gn
+++ b/khdf/liteos_m/platform/BUILD.gn
@@ -63,7 +63,10 @@ hdf_driver("hdf_platform_lite") {
   }

   if (defined(LOSCFG_DRIVERS_HDF_PLATFORM_PWM)) {
-    sources += [ "$HDF_FRAMEWORKS_PATH/support/platform/src/pwm/pwm_core.c" ]
+    sources += [
+      "$HDF_FRAMEWORKS_PATH/support/platform/src/pwm/pwm_core.c",
+      "$HDF_FRAMEWORKS_PATH/support/platform/src/pwm/pwm_if.c",
+    ]
   }

   if (defined(LOSCFG_DRIVERS_HDF_PLATFORM_RTC)) {
  • 將JS應(yīng)用合入工程。

關(guān)于JS應(yīng)用開發(fā)請參考從零開始學(xué)習(xí)L0: JS開發(fā)系列。本節(jié)為可選章節(jié),忽略本節(jié)內(nèi)容不影響智能門鈴項目的展示和運行。但若想要在本項目的基礎(chǔ)上進行涉及到顯示的內(nèi)容修改與新規(guī)開發(fā),例如增加天氣預(yù)報的圖標,則需完整的閱讀本節(jié)及鏈接內(nèi)容。

  • 下載并安裝[DevEco Studio]。

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 打開js工程。

工程目錄為:knowledge_demo_smart_home/dev/team_x/smart_door_bell/FA

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 在DevEco Studio的SDK中添加@system.communicationkit.d.ts文件。

將@system.communicationkit.d.ts文件(源文件目錄:~/knowledge_demo_smart_home/dev/interface/sdk-js/api/common/@system.communicationkit.d.ts)拷貝到在DevEco Studio的SDK中(目標目錄:HarmonyOS Legacy SDK/js/3.0.0.0/api/common)。HarmonyOS Legacy SDK目錄在DevEco Studio安裝時,由用戶配置,該目錄位置可在設(shè)置(ctrl+alt+s)中查找。

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 編譯hap包。

依次選擇構(gòu)建 -> Build Hap(s)/APP(s) -> Build Hap(s)進行hap包編譯,編譯后的hap包目錄為:FA\entry\build\outputs\hap\debug\entry-debug-lite-unsigned.hap。

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 將js代碼合入OpenHarmonySDK。

將entry-debug-lite-unsigned.hap修改后綴為zip并解壓。在解壓后的目錄:entry-debug-lite-unsigned/assets/js/default目錄中除app.js.map外的的數(shù)據(jù)全部拷貝到OpenHarmonySDK中的vendor/team_x/smart_door_bell/fs/data/data/js目錄下。

工程效果

整合并修改完成后的代碼目錄結(jié)構(gòu)如下圖:

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

編譯

編譯命令:

hb set  // 如果是第一次編譯,Input code path 命令行中鍵入"./" 指定OpenHarmony工程編譯根目錄后回車。

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

如下圖所示,使用鍵盤上下鍵選中智能門鈴 “smart_door_bell”(注:工程名字根據(jù)實際要編譯的工程來):

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

hb build // 如果需要全量編譯,可以添加-f 選項

編譯通過,生成固件成功,如圖:

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

燒錄/安裝
  • 安裝[CP2102驅(qū)動]
  • 固件編譯完成以后拷貝/out/v200zr/smart_door_bell/write_flash_gui文件夾到windows下,并點擊Wifi_download_main.exe

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 點擊工具上的文件夾圖標

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 選擇List按鈕

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 在顯示出來的串口列表中選擇需要燒錄的串口,并點擊開始按鈕。

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 在開發(fā)板上點擊reset按鍵,或者重新上電。

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 進入燒錄狀態(tài)

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 燒錄成功

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

? 注意:固件燒錄完成后需將燒錄窗口關(guān)閉,再按下設(shè)備Reset鍵設(shè)備才能啟動。如果未將燒錄窗口關(guān)閉,設(shè)備會再次進行燒寫狀態(tài)。

操作體驗
設(shè)備配網(wǎng)
  • 在設(shè)備上電前需準備好安裝了數(shù)字管家應(yīng)用的HarmonyOS手機, 并在設(shè)置中開啟手機的NFC功能;
  • 寫設(shè)備NFC標簽;
  • 燒錄完成后,上電。開發(fā)者在觀察開發(fā)板上狀態(tài)LED燈以1Hz的頻率閃爍時,將手機上半部靠近開發(fā)板NFC標簽處;
  • 手機將自動拉起數(shù)字管家應(yīng)用并進入配網(wǎng)狀態(tài),根據(jù)手機提示連接到設(shè)備熱點teamX-DoorBell01后返回數(shù)字管家APP,輸入路由賬號密碼,點擊確定后,手機將信息傳輸?shù)皆O(shè)備側(cè),設(shè)備開始聯(lián)網(wǎng)。

    OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

設(shè)備控制
  • 有陌生人靠近:

    OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 有人按門鈴:

    OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

  • 遠程一鍵開門:

    OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

鴻蒙開發(fā)崗位需要掌握那些核心要領(lǐng)?

目前還有很多小伙伴不知道要學(xué)習(xí)哪些鴻蒙技術(shù)?不知道重點掌握哪些?為了避免學(xué)習(xí)時頻繁踩坑,最終浪費大量時間的。

自己學(xué)習(xí)時必須要有一份實用的鴻蒙(Harmony NEXT)資料非常有必要。 這里我推薦,根據(jù)鴻蒙開發(fā)官網(wǎng)梳理與華為內(nèi)部人員的分享總結(jié)出的開發(fā)文檔。內(nèi)容包含了:【ArkTS、ArkUI、Stage模型、多端部署、分布式應(yīng)用開發(fā)、音頻、視頻、WebGL、OpenHarmony多媒體技術(shù)、Napi組件、OpenHarmony內(nèi)核、Harmony南向開發(fā)、鴻蒙項目實戰(zhàn)】等技術(shù)知識點。

廢話就不多說了,接下來好好看下這份資料。

如果你是一名Android、Java、前端等等開發(fā)人員,想要轉(zhuǎn)入鴻蒙方向發(fā)展。可以直接領(lǐng)取這份資料輔助你的學(xué)習(xí)。鴻蒙OpenHarmony知識←前往。下面是鴻蒙開發(fā)的學(xué)習(xí)路線圖。

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】,鴻蒙,harmonyos,移動開發(fā),鴻蒙開發(fā),鴻蒙,OpenHarmony,程序員,鴻蒙南向開發(fā)

針對鴻蒙成長路線打造的鴻蒙學(xué)習(xí)文檔。鴻蒙(OpenHarmony )學(xué)習(xí)手冊(共計1236頁)與鴻蒙(OpenHarmony )開發(fā)入門教學(xué)視頻,幫助大家在技術(shù)的道路上更進一步。

其中內(nèi)容包含:

《鴻蒙開發(fā)基礎(chǔ)》鴻蒙OpenHarmony知識←前往

  1. ArkTS語言
  2. 安裝DevEco Studio
  3. 運用你的第一個ArkTS應(yīng)用
  4. ArkUI聲明式UI開發(fā)
  5. .……

《鴻蒙開發(fā)進階》鴻蒙OpenHarmony知識←前往

  1. Stage模型入門
  2. 網(wǎng)絡(luò)管理
  3. 數(shù)據(jù)管理
  4. 電話服務(wù)
  5. 分布式應(yīng)用開發(fā)
  6. 通知與窗口管理
  7. 多媒體技術(shù)
  8. 安全技能
  9. 任務(wù)管理
  10. WebGL
  11. 國際化開發(fā)
  12. 應(yīng)用測試
  13. DFX面向未來設(shè)計
  14. 鴻蒙系統(tǒng)移植和裁剪定制
  15. ……

《鴻蒙開發(fā)實戰(zhàn)》鴻蒙OpenHarmony知識←前往

  1. ArkTS實踐
  2. UIAbility應(yīng)用
  3. 網(wǎng)絡(luò)案例
  4. ……

最后

鴻蒙是完全具備無與倫比的機遇和潛力的;預(yù)計到年底將有 5,000 款的應(yīng)用完成原生鴻蒙開發(fā),這么多的應(yīng)用需要開發(fā),也就意味著需要有更多的鴻蒙人才。鴻蒙開發(fā)工程師也將會迎來爆發(fā)式的增長,學(xué)習(xí)鴻蒙勢在必行!文章來源地址http://www.zghlxwxcb.cn/news/detail-858377.html

到了這里,關(guān)于OpenHarmony鴻蒙南向開發(fā)案例:【智能門鈴】的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • HarmonyOS 鴻蒙開發(fā)DevEco Studio OpenHarmony:配置開發(fā)環(huán)境

    目錄 下載OpenHarmony SDK及工具鏈 參考信息 配置DevEco Studio代理 配置NPM代理 在進行OpenHarmony應(yīng)用/服務(wù)開發(fā)前,需要提前在DevEco Studio中下載對應(yīng)版本的SDK。下載OpenHarmony SDK需要連接網(wǎng)絡(luò),一般情況下,可以直接下載;但部分用戶的網(wǎng)絡(luò)可能受限,此時需要先根據(jù)參考信息 配置相

    2024年02月19日
    瀏覽(93)
  • HarmonyOS 鴻蒙開發(fā)DevEco Studio OpenHarmony:使用低代碼進行開發(fā)

    HarmonyOS 鴻蒙開發(fā)DevEco Studio OpenHarmony:使用低代碼進行開發(fā)

    OpenHarmony低代碼開發(fā)方式,具有豐富的UI界面編輯功能,遵循JS、TS開發(fā)規(guī)范 ,通過可視化界面開發(fā)方式快速構(gòu)建布局,可有效降低用戶的時間成本和提升用戶構(gòu)建UI界面的效率。 說明 支持使用低代碼進行JS/eTS頁面開發(fā),本章節(jié)以開發(fā)eTS頁面為例,介紹低代碼功能及使用方法。

    2024年02月19日
    瀏覽(89)
  • HarmonyOS 鴻蒙開發(fā)DevEco Studio OpenHarmony:編譯構(gòu)建概述

    目錄 OpenHarmony構(gòu)建體系 構(gòu)建工具Hvigor 構(gòu)建插件hvigor-ohos-plugin 工程目錄及配置文件說明 如何構(gòu)建應(yīng)用/服務(wù) 啟動應(yīng)用/服務(wù)構(gòu)建 查看編譯過程

    2024年02月22日
    瀏覽(93)
  • 鴻蒙開發(fā)OpenHarmony組件復(fù)用案例

    鴻蒙開發(fā)OpenHarmony組件復(fù)用案例

    在開發(fā)應(yīng)用時,有些場景下的自定義組件具有相同的組件布局結(jié)構(gòu),僅有狀態(tài)變量等承載數(shù)據(jù)的差異。這樣的組件緩存起來,需要使用到該組件時直接復(fù)用, 減少重復(fù)創(chuàng)建和渲染的時間,從而提高應(yīng)用頁面的加載速度和響應(yīng)速度。 在OpenHarmony應(yīng)用開發(fā)時,自定義組件被@Reus

    2024年01月19日
    瀏覽(19)
  • 【OpenHarmony-鴻蒙】 華為智能家居IoT設(shè)備開發(fā)-環(huán)境搭建篇 一鍵部署開發(fā)環(huán)境

    【OpenHarmony-鴻蒙】 華為智能家居IoT設(shè)備開發(fā)-環(huán)境搭建篇 一鍵部署開發(fā)環(huán)境

    輕量與小型系統(tǒng)入門概述 簡介 OpenHarmony輕量和小型系統(tǒng)適用于內(nèi)存較小的IOT設(shè)備(參考內(nèi)存≥128KiB)。通過本文,開發(fā)者可以快速熟悉OpenHarmony輕量和小型系統(tǒng)的環(huán)境搭建、編譯、燒錄、調(diào)測以及運行“Hello World”等。 開發(fā)環(huán)境 開發(fā)者通常習(xí)慣采用Windows+Ubuntu環(huán)境進行OpenHa

    2024年02月12日
    瀏覽(16)
  • Harmony鴻蒙南向驅(qū)動開發(fā)流程

    Harmony鴻蒙南向驅(qū)動開發(fā)流程

    HDF(Hardware Driver Foundation)驅(qū)動框架,為驅(qū)動開發(fā)者提供驅(qū)動框架能力,包括驅(qū)動加載、驅(qū)動服務(wù)管理、驅(qū)動消息機制和配置管理。并以組件化驅(qū)動模型作為核心設(shè)計思路,讓驅(qū)動開發(fā)和部署更加規(guī)范,旨在構(gòu)建統(tǒng)一的驅(qū)動架構(gòu)平臺,為驅(qū)動開發(fā)者提供更精準、更高效的驅(qū)動

    2024年04月27日
    瀏覽(25)
  • Harmony鴻蒙南向驅(qū)動開發(fā)-RTC接口使用

    Harmony鴻蒙南向驅(qū)動開發(fā)-RTC接口使用

    功能簡介 RTC(real-time clock)為操作系統(tǒng)中的實時時鐘設(shè)備,為操作系統(tǒng)提供精準的實時時間和定時報警功能。當(dāng)設(shè)備下電后,通過外置電池供電,RTC繼續(xù)記錄操作系統(tǒng)時間;設(shè)備上電后,RTC提供實時時鐘給操作系統(tǒng),確保斷電后系統(tǒng)時間的連續(xù)性。 運作機制 在HDF框架中,

    2024年04月13日
    瀏覽(30)
  • Harmony鴻蒙南向驅(qū)動開發(fā)-ADC接口使用

    Harmony鴻蒙南向驅(qū)動開發(fā)-ADC接口使用

    ADC(Analog to Digital Converter),即模擬-數(shù)字轉(zhuǎn)換器,可將模擬信號轉(zhuǎn)換成對應(yīng)的數(shù)字信號,便于存儲與計算等操作。除電源線和地線之外,ADC只需要1根線與被測量的設(shè)備進行連接,其物理連線如圖1所示: 圖 1 ?ADC物理連線示意圖 ADC接口定義了完成AD轉(zhuǎn)換的通用方法集合,包括

    2024年04月12日
    瀏覽(40)
  • Harmony鴻蒙南向驅(qū)動開發(fā)-PWM接口使用

    Harmony鴻蒙南向驅(qū)動開發(fā)-PWM接口使用

    功能簡介 PWM即脈沖寬度調(diào)制(Pulse Width Modulation)的縮寫,是一種對模擬信號電平進行數(shù)字編碼并將其轉(zhuǎn)換為脈沖的技術(shù)。 PWM接口定義了操作PWM設(shè)備的通用方法集合,包括: PWM設(shè)備句柄獲取和釋放 PWM周期、占空比、極性的設(shè)置 PWM使能和關(guān)閉 PWM配置信息的獲取和設(shè)置 基本概

    2024年04月13日
    瀏覽(16)
  • [Linux]華為的系統(tǒng) 歐拉 鴻蒙 openEuler HarmonyOS OpenHarmony

    之前整理過《華為機器運行什么桌面系統(tǒng)?EulerOS openEuler LiteOS 鴻蒙 深度 UOS》,但差不多快兩年了,今天再梳理下華為目前提供的主要系統(tǒng): openEuler | open歐拉 定位是服務(wù)器操作系統(tǒng) 是基于CentOS的 Linux 發(fā)行版,開源、免費 其商業(yè)發(fā)行版由麒麟軟件、統(tǒng)信軟件等提供(如:統(tǒng)

    2024年02月09日
    瀏覽(47)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包