OpenHarmony鸿蒙( Beta5.0)智能窗户通风设备开发详解

 鸿蒙开发往期必看:

一分钟了解”纯血版!鸿蒙HarmonyOS Next应用开发!

“非常详细的” 鸿蒙HarmonyOS Next应用开发学习路线!(从零基础入门到精通)

 “一杯冰美式的时间” 了解鸿蒙HarmonyOS Next应用开发路径!


样例简介

本文档介绍了安全厨房案例中的相关智能窗户通风设备,本安全厨房案例利用轻量级软总线能力,将两块欧智通V200Z-R/BES2600开发板模拟的智能窗户通风设备和燃气告警设备组合成。当燃气数值告警时,无需其它操作,直接通知软总线网络中的通风设备的电机工作,反之则关闭窗户通风设备中的电机。

运行效果

对于窗户通风系统的单独操作:

组成分布式网络后,检测到燃气超标,自动控制电机工作来通风换气:

样例原理

如上图所示,智能安全厨房整体方案可以分成如下:智能窗户通风设备、智能燃气告警设备、家庭路由器组成。首先窗户通风设备和燃气告警设备链接到同一个路由器下。

其中智能窗户通风设备和智能燃气告警设备不仅可以分别单独操控,还可以在完成相互的软总线设备发现、认证、pin码校验等步骤后组成一个最小的分布式软总线网络后, 利用RPC 能力来时实现设备的相互操作。

工程版本

  • 系统版本/API版本:OpenHarmony 3.1 release
  • hb版本:0.4.6
  • 工具链版本:gcc-arm-none-eabi-10.3-2021.10

快速上手

准备硬件环境

欧智通V200Z-R开发板 *1;

小熊派 hm_nano 开发套件中的E53_1A1 拓展板;

正常工作无线路由一台(请保证预设 热点名称:test_wifi 密码:12345678 ; 是否能连接互联网均可)

硬件连线图:

准备开发环境

开发基础环境由 windows 工作台和 Linux 编译服务器组成。windows 工作台可以通过 samba 服务或 ssh 方式访问 Linux编译服务器。其中 windows 工作台用来烧录和代码编辑,Linux 编译服务器用来编译 OpenHarmony 代码,为了简化步骤,Linux 编译服务器推荐安装 Ubuntu20.04。

安装必备软件
安装和配置Python3
  1. 打开Linux终端。

  2. 输入如下命令,查看python版本号,需要使用python3.7以上版本

    python3 --version
    
  3. 安装并升级Python包管理工具(pip3)。

    sudo apt-get install python3-setuptools python3-pip -y
    sudo pip3 install --upgrade pip
    
  4. 设置pip的国内镜像

    pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple requests
    
安装交叉编译环境

在Linux编译服务器上搭建好基础开发环境后,需要安装OpenHarmony 编译欧智通BES2600平台特有的开发环境。

安装必备库文件和工具
sudo apt-get install -y build-essential gcc g++ make zlib* libffi-dev git git-lfs python
安装编译工具链arm-none-eabi-gcc
  1. 打开Linux终端。

  2. 下载arm-none-eabi-gcc编译工具。

  3. 安装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/
    

    设置环境变量。

    vim ~/.bashrc
    

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

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

    生效环境变量。

    source ~/.bashrc
    
  4. 在命令行中输入如下命令,如果能正确显示编译器版本号,表明编译器安装成功。

    arm-none-eabi-gcc -v
    

准备工程

配置git
  • 提前注册准备码云gitee账号。
  • 生成/添加SSH密钥:生成密钥 使用gitee账号绑定的邮箱生成密钥对
ssh-keygen -t ed25519 -C "xxxxx@xxxxx.com"
  • 查看生成的密钥
cat ~/.ssh/id_ed25519.pub
  • 复制生成后的 ssh key,返回gitee个人主页,通过主页 「个人设置」->「安全设置」->「SSH 公钥」 ,将生成的“SSH密钥”添加到仓库中。
  • 配置git用户信息
git config --global user.name "yourname"
git config --global user.email "your-email-address"
git config --global credential.helper store
准备repo
1)下载repo工具
mkdir ~/bin
curl https://gitee.com/oschina/repo/raw/fork_flow/repo-py3 > ~/bin/repo
chmod a+x ~/bin/repo2)设置环境变量并生效
vim ~/.bashrc
export PATH=~/bin:PATH

生效环境变量。

source ~/.bashrc
  1. 在命令行中输入如下命令,如果能正确显示编译器版本号,表明编译器安装成功。

    arm-none-eabi-gcc -v
    

准备工程

配置git
  • 提前注册准备码云gitee账号。
  • 生成/添加SSH密钥:生成密钥 使用gitee账号绑定的邮箱生成密钥对
ssh-keygen -t ed25519 -C "xxxxx@xxxxx.com"
  • 查看生成的密钥
cat ~/.ssh/id_ed25519.pub
  • 复制生成后的 ssh key,返回gitee个人主页,通过主页 「个人设置」->「安全设置」->「SSH 公钥」 ,将生成的“SSH密钥”添加到仓库中。
  • 配置git用户信息
git config --global user.name "yourname"
git config --global user.email "your-email-address"
git config --global credential.helper store
准备repo
1)下载repo工具
mkdir ~/bin
curl https://gitee.com/oschina/repo/raw/fork_flow/repo-py3 > ~/bin/repo
chmod a+x ~/bin/repo2)设置环境变量并生效
vim ~/.bashrc
export PATH=~/bin:PATH
source ~/.bashrc 
准备系统源码
#特别注意:请下载OpenHarmony 3.1 Release 版本代码
mkdir ~/OpenHarmony-3.1-Release
cd ~/OpenHarmony-3.1-Release
repo init -u git@gitee.com:openharmony/manifest.git -b refs/tags/OpenHarmony-v3.1-Release --no-repo-verify
repo sync -c
repo forall -c 'git lfs pull'

注意:

1.权限问题请参考生成/添加SSH公钥。

2.若在已安装python3.8后,执行repo init 时,仍显示如下错误:

/usr/bin/env: ‘python’: No such file or directory

执行如下命令后,进行重试:

sudo ln -s /usr/bin/python3.8 /usr/bin/python
安装hb
  1. 输入如下命令确认hb是否为version 0.4.4 版本以上

    hb -v
    

    a. 若提示如下内容,则表示未安装可以从第2步开始操作。

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

    b.若提示如下内容,需要先卸载该版本,然后再执行第2步操作步骤。

    [OHOS INFO] hb version 0.4.3
    

    卸载命令:

    pip3 uninstall ohos-build
    
  2. 运行如下命令安装hb

    pip3 install build/lite   // 该命令需在OpenHarmony源码根目录下执行
    
  3. 设置环境变量

    vim ~/.bashrc
    

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

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

    执行如下命令更新环境变量。

    source ~/.bashrc
    
  4. 再次执行”hb -v“,有以下版本显示则表示安装的hb 0.4.4 以上版本正确。

    [OHOS INFO] hb version 0.4.6
    
准备设备侧应用代码
  1. 代码拷贝

    smart_safe_kitchen-smart_window源码拷贝

    cd ~
    git clone git@gitee.com:openharmony-sig/knowledge_demo_smart_home.git 
    mkdir ~/OpenHarmony-3.1-Release/vendor/team_x
    cp -rfa ~/knowledge_demo_smart_home/dev/team_x/smart_safe_kitchen-smart_window ~/OpenHarmony-3.1-Release/vendor/team_x
    

    common库拷贝

    cp -rfa ~/knowledge_demo_smart_home/dev/team_x/common ~/OpenHarmony-3.1-Release/vendor/team_x
    
  2. communicationkit相关修改

参考下方代码修改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..d0cc5d2 100644
--- a/frameworks/module_manager/ohos_module_config.h
+++ b/frameworks/module_manager/ohos_module_config.h
@@ -45,6 +45,7 @@ extern void InitDialogModule(JSIValue exports);#if (FEATURE_MODULE_STORAGE == 1)extern void InitNativeApiFs(JSIValue exports);extern void InitNativeApiKv(JSIValue exports);
+extern void InitNativeApiCommunicationKit(JSIValue exports);#endif#if (FEATURE_MODULE_DEVICE == 1)
@@ -102,6 +103,7 @@ const Module OHOS_MODULES[] = {#if (FEATURE_MODULE_STORAGE == 1){"file", InitNativeApiFs},{"storage", InitNativeApiKv},
+    {"CommunicationKit", InitNativeApiCommunicationKit},#endif#if (FEATURE_MODULE_DEVICE == 1){"device", InitDeviceModule},
  1. 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];// 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, 11];
+            config = [5, 2, 5];
+            pinNum = 3;}i2c_config {i2c0 {
  1. flash_size 配置项确认

    如果V200Z-R 开发板上相关 版本编号丝印为"V200Z-R EVB V1.0", 则在如下代码中配置flash_size选项为16,如果相关丝印编号为"V200Z-R EVB V2.0" , 则保持默认的flash_size = 32不变。

    device/board/fnlink/v200zr/liteos_m/config.gni
    flash_size = 16 
    
  2. JS应用代码更新(可选)

本步骤为可选章节,忽略本节内容不影响智能通风设备的的展示和运行,如果需要对相关JS 应用做修改,请参考智能窗户JS应用开发文档,应用修改完成后,再次编译此应用。如下图所示:

hap包目录为:FA\entry\build\outputs\hap\debug\entry-debug-lite-unsigned.hap。

将entry-debug-lite-unsigned.hap修改后缀为zip并解压。在解压后的目录:entry-debug-lite-unsigned/assets/js/default目录中除app.js.map外的的数据全部拷贝到OpenHarmonySDK中的vendor/team_x/smart_safe_kitchen-smart_window/fs/data/data/js目录下

工程效果

整合并修改完成后的代码目录结构如下图:

image-20211228205514766

编译

进入到OpenHarmony系统源码根目录下,输入hb set命令即可看到我们的应用,选择并确认即可。

cd ~/OpenHarmony-3.1-Release
hb set  // 如果是第一次编译,Input code path 命令行中键入"./" 指定OpenHarmony工程编译根目录后回车。

如下图所示,使用键盘上下键选中智能窗户通风系统 “smart_safe_kitchen-smart_window”(注:工程名字根据实际要编译的工程来):

hb build // 如果需要全量编译,可以添加-f 选项

出现"build success"字样,则表示编译生成固件成功,如下图所示:

image-20211228205659402

安装

因为欧智通BES2600/V200Z-R 开发板的烧录程序是包含在对应out文件夹对应product目录下的,无需使用额外的烧录工具,在安装了相应驱动文件后,执行烧录可执行文件即可,下面是具体的操作步骤:

1.安装CP2102驱动,解压后双击与自己window 版本相匹配的可执行文件,并按相关提示安装驱动文件即可;

2.固件编译完成以后拷贝~/OpenHarmony-3.1-Release/out/v200zr/smart_safe_kitchen-smart_window/write_flash_gui文件夹到windows下(或者利用samba服务直接访问该目录),并双击可执行文件Wifi_download_main.exe

3.点击工具上的文件夹图标

4.选择List按钮

5.在显示出来的串口列表中选择需要烧录的串口,并点击开始按钮。

6.在开发板上点击reset按键,或者重新上电。

7.进入烧录状态

8.烧录成功

​ 注意:固件烧录完成后需将烧录窗口关闭,再按下设备Reset键设备才能启动。如果未将烧录窗口关闭,设备会再次进行烧写状态。

操作体验

  1. 提前准备好安全厨房场景中的智能燃气检测设备 ,并完成相关的编译和应用安装动作;

  2. 提前准备好正常工作的无线路由设备(请保证预设 热点名称:test_wifi 密码:12345678 ; 是否能连接互联网均可)

  3. 将窗户通风设备和燃气检测设备上电,确认两个设备应用启动正常和操作正常;

  4. 按如下步骤将通风设备、燃气检测设备组成一个软总线网络

    1)分别点击两个设备应用界面右上角的软总线配置图标,进入软总线配置界面;

    2)点击智能燃气检测设备应用发现图标 ,间隔3S后点击发起认证图标;

    3)点击智能通风设备软总线配置界面下的 允许认证图标,正常情况下会显示一个6位数的PIN 码;

    4)点击智能燃气检测设备应用输入PIN 码按钮,进入数字键盘输入PIN 码;

    5)分别点击两个应用软总线配置图标左上角的返回按键,进入设备控制界面。

  5. 设置燃气检测设备的阈值低于实际读取的燃气数值,燃气检测应用进入警报界面的同时会调用相关接口控制智能通风系统的电机工作,自动通风换气,保证家居的安全。待到实际燃气数值低于设置的阈值时,则关闭智能通风系统的电机。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/421761.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springboot luttuc redis 集成protobuf,手动序列化反序列化

前置需知: 1.本文章和网上大部分博客配置不太一样,各位看官要分析一下自己的需求。集成protobuf 本文章主要是手动调用protobuf的序列化方法,而不是交由springboot 去做,会偏向原生java 使用方式 2.由于为了和公司其他的项目达成…

工业机器人9公里远距离图传模块,无人机低延迟高清视界,跨过距离限制

在科技日新月异的今天,无线通信技术正以未有的速度发展,其中,图传模块作为连接现实与数字世界的桥梁,正逐步展现出其巨大的潜力和应用价值。今天,我们将聚焦一款引人注目的产品——飞睿智能9公里远距离图传模块&#x…

前端Excel热成像数据展示及插值算法

🎬 江城开朗的豌豆:个人主页 🔥 个人专栏:《 VUE 》 《 javaScript 》 📝 个人网站 :《 江城开朗的豌豆🫛 》 ⛺️生活的理想,就是为了理想的生活! 目录 📘 前言 📘一、热成像数…

Linux s3c2440 开发板上的操作系统实现 ubuntu

使用s3c2440开发板 使用ubuntu 1.ubuntu中的tftp,和nfs Trivial File Transfer Protocol,简单文件 传输协议。 通过网络在客户端与服务器之间进行简单文件 传输。提供不复杂、开销不大的文件传输服务。 Network File System,网络文件系统。通过 网络…

如何显示Dialog窗口

文章目录 1. 概念介绍2. 使用方法2.1 Overlay效果2.1 Dialog效果 3. 示例代码4. 内容总结 我们在上一章回中介绍了"使用get显示snackBar"相关的内容,本章回中将介绍使用get显示Dialog.闲话休提,让我们一起Talk Flutter吧。 1. 概念介绍 我们在…

深入剖析嵌套调用和链式访问,以及函数的声明和定义(超全面覆盖)

1. 前情提要 在上一篇博客中,我们大致了解了函数的种类,以及自定义函数中形参和实参的具体区别 我们知道实参是需要传递给形参的,但其实形参和实参占据的是完全独立的内存空间 x,y在执行过程中会得到a和b的值,但是x…

Redis的数据类型以及应用场景

Redis - 数据类型 Redis是一种开源的内存数据结构存储,用作数据库、缓存和消息代理。 它支持多种数据结构,如字符串、哈希、列表、集合、有序集合等。 1. 字符串(String) Redis 的字符串(String)数据类型…

SQL(结构性查询语句)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、SQL是什么?二、DDL三、DML四、DQL五、DCL总结 提示:以下是本篇文章正文内容,下面案例可供参考 一、SQL是什么&#xff…

Linux之Shell编程规范与变量

Shell编程规范与变量 本章结构 Shel脚本概述 Shell的作用Shel编程规范重定向与管道 Shell脚本变量 自定义变量特殊变量 Shel脚本概述 Shel脚本的概念 将要执行的命令按顺序保存到一个文本文件给该文件可执行权限可结合各种Shell控制语句以完成更复杂的操作 Shel脚本应…

二叉树(中)

目录 二叉树的基本操作 设置基本变量 获取树中结点的个数 获取叶子结点个数 获取第K层结点的个数 获取二叉树高度 检测值为value的元素是否存在 二叉树的基本操作 如果需要了解树和二叉树的基本内容,可以转至:二叉树(上)-CSDN…

[论文笔记]LLM.int8(): 8-bit Matrix Multiplication for Transformers at Scale

引言 今天带来第一篇量化论文LLM.int8(): 8-bit Matrix Multiplication for Transformers at Scale笔记。 为了简单,下文中以翻译的口吻记录,比如替换"作者"为"我们"。 大语言模型已被广泛采用,但推理时需要大量的GPU内…

CentOS7 使用yum报错:[Errno 14] HTTP Error 404 - Not Found 正在尝试其它镜像。

CentOS7 使用yum报错:[Errno 14] HTTP Error 404 - Not Found 正在尝试其它镜像。 CentOS镜像下载、VM虚拟机下载 下载地址:www.macfxb.cn 一、问题描述 安装完CentOS7 后 使用yum报错 如下图 二、解决方案 1.查看自己的系统架构 我的是aarch64 uname …

CCPC赛后补题-线性基

模板题:https://www.luogu.com.cn/problem/P3812 线性基可以用一个长度为$ \log_2N $的数组描述值域[1,N],0的情况需要特判。 一个长度为64的线性基可以描述所有的64位整数。 在2024年CCPC网络赛中,考到了线性基。没学过,追悔莫…

Vulnhub靶场 DC-2

靶机地址:https://www.vulnhub.com/entry/dc-2,311/ 导入到VMware里面去, 设置NAT模式 namp扫描一下c段获取ip地址, 然后再扫描ip地址获取详细的信息 得到ip 192.168.75.134 无法访问 按照下面这个方法可以访问了 在kali上的处理 flag1 网站上就存在 提示了一个cewl工具,…

特斯拉的底牌

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

对抗性EM用于变分深度学习:在低剂量PET和低剂量CT中的半监督图像质量增强应用|文献速递--Transformer架构在医学影像分析中的应用

Title 题目 Adversarial EM for variational deep learning: Application to semi-supervised image quality enhancement in low-dose PET and low-dose CT 对抗性EM用于变分深度学习:在低剂量PET和低剂量CT中的半监督图像质量增强应用 01 文献速递介绍 医学影…

【MySQL】从0开始在Centos 7环境安装MySQL

🦄个人主页:修修修也 🎏所属专栏:MySQL ⚙️操作环境:Xshell (操作系统:CentOS 7.9 64位) 目录 准备步骤 卸载原有环境 安装步骤 获取MySQL官方yum源 安装MySQL yum源 结语 准备步骤 卸载原有环境 第一步登录云服务器(注意安装yum需要在root身份下…

CC工具箱使用指南:【字段计算器学习版】

一、简介 这个工具算是Pro自带的字段计算器的扩展版。 工具预制了几种计算模式,通过可视化操作,帮你自动生成代码。 生成代码后,可以直接运行,也可以将代码复制到Pro自带的字段计算器中进行计算。 总之,这是给不会…

基于准静态自适应环型缓存器(QSARC)的taskBus万兆吞吐实现

文章目录 概要整体架构流程技术名词解释技术细节1. 数据结构2. 自适应计算队列大小3. 生产者拼接缓存4. 高效地通知消费者 小结1. 性能表现情况2. 主要改进和局限3. 源码和发行版 概要 准静态自适应环形缓存器(Quasi-Static Adaptive Ring Cache)是task…

【R语言】删除数据框中所有行中没有大于200的数值的行

在Perl中还需要循环按行读入文件&#xff0c;而在R中&#xff0c;一行代码解决问题&#xff1a; df <- df[apply(df, 1, function(x) any(x > 200)), ]这是一个使用apply函数对数据框df进行操作的表达式。apply函数用于对数据框、矩阵或数组进行元素级别的操作。 df&am…