0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

OpenHarmony鸿蒙南向开发案例:【智能燃气检测设备】

jf_46214456 来源:jf_46214456 作者:jf_46214456 2024-04-19 17:17 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

样例简介

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

运行效果

对于燃气检测系统的单独操作:

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

样例原理

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

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

工程版本

  • 系统版本/API版本:OpenHarmony 3.1 release
  • hb版本:0.4.6
  • 工具链版本:gcc-arm-none-eabi-10.3-2021.10
  • 鸿蒙开发指导文档:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

快速上手

准备硬件环境

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

MQ5燃气检测传感器*1

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

硬件连线图:

准备开发环境

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

安装必备软件

HarmonyOS与OpenHarmony鸿蒙文档籽料:mau123789是v直接拿

搜狗高速浏览器截图20240326151450.png

安装和配置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/repo

2)设置环境变量并生效
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-gas_detection源码拷贝

    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-gas_detection ~/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 应用做修改,,应用修改完成后,再次编译此应用。如下图所示:

hap包目录为:FAentrybuildoutputshapdebugentry-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-gas_detection/fs/data/data/js目录下

工程效果

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

image-20211228205514766

编译

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

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

如下图所示,使用键盘上下键选中智能燃气检测系统 “smart_safe_kitchen-gas_detection”(注:工程名字根据实际要编译的工程来):

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

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 检测设备
    +关注

    关注

    0

    文章

    760

    浏览量

    17980
  • 烧录
    +关注

    关注

    8

    文章

    333

    浏览量

    37259
  • 鸿蒙
    +关注

    关注

    60

    文章

    3071

    浏览量

    46277
  • HarmonyOS
    +关注

    关注

    80

    文章

    2157

    浏览量

    36440
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    开源鸿蒙赋能水务智能化,触觉智能IPC3528水务鸿蒙网关

    近期深圳五指耙水厂正式完成鸿蒙智能升级,成为全国首座鸿蒙智慧水厂,标志开源鸿蒙生态在智慧水务领域实现落地,为开源鸿蒙产业生态拓展写下关键一
    的头像 发表于 04-21 10:42 553次阅读
    开源<b class='flag-5'>鸿蒙</b>赋能水务<b class='flag-5'>智能</b>化,触觉<b class='flag-5'>智能</b>IPC3528水务<b class='flag-5'>鸿蒙</b>网关

    正式招生!2026年企业“开源鸿蒙南向设备开发”培训班启动

    ”)组织本次开源鸿蒙南向设备开发培训班。本次培训依托双方共建的“深圳开源鸿蒙开发者培训基地”,旨
    的头像 发表于 03-16 18:10 791次阅读
    正式招生!2026年企业“开源<b class='flag-5'>鸿蒙</b><b class='flag-5'>南向</b><b class='flag-5'>设备</b><b class='flag-5'>开发</b>”培训班启动

    “开放原子校源行师资培训系列——2026年开源鸿蒙北向应用开发南向设备研修班”在深圳成功举办

    龙岗区深龙高层次人才服务中心、深圳数字人才科技有限公司协办的“开放原子校园行师资培训系列——2026年开源鸿蒙北向应用开发南向设备开发研修
    的头像 发表于 01-27 20:20 919次阅读
    “开放原子校源行师资培训系列——2026年开源<b class='flag-5'>鸿蒙</b>北向应用<b class='flag-5'>开发</b>与<b class='flag-5'>南向</b><b class='flag-5'>设备</b>研修班”在深圳成功举办

    报名开启!2026年开源鸿蒙“北向应用”与“南向设备开发研修班等你加入!

    为深化校企合作,推动开源鸿蒙OpenHarmony)技术发展,促进高校教师掌握开源鸿蒙北向应用开发南向
    的头像 发表于 01-08 17:24 1534次阅读
    报名开启!2026年开源<b class='flag-5'>鸿蒙</b>“北向应用”与“<b class='flag-5'>南向</b><b class='flag-5'>设备</b>”<b class='flag-5'>开发</b>研修班等你加入!

    开源鸿蒙生态设备南向分论坛成功举办

    11月28日,开源鸿蒙生态设备南向分论坛在深圳举办,聚焦开源鸿蒙设备端发展与生态共建的最新进展。论坛邀请来自开源
    的头像 发表于 12-04 16:57 1244次阅读

    触觉智能RK3588行业主板通过OpenHarmony5.0 XTS认证

    触觉智能作为开源鸿蒙南向硬件厂家,旗下RK3588行业主板IDO-SBC3588(以下简称SBC3588)通过了OpenHarmony5.0XTS认证,
    的头像 发表于 11-24 13:57 1256次阅读
    触觉<b class='flag-5'>智能</b>RK3588行业主板通过<b class='flag-5'>OpenHarmony</b>5.0 XTS认证

    触觉智能Purple Pi OH开发板率先适配OpenHarmony6.0 Release,鸿蒙明星开发

    2025年9月19日,在官网上线开源鸿蒙OpenHarmony6.0Release仅13天,触觉智能宣布旗下PurplePiOH开发板成功完成Ope
    的头像 发表于 10-29 08:00 1243次阅读
    触觉<b class='flag-5'>智能</b>Purple Pi OH<b class='flag-5'>开发</b>板率先适配<b class='flag-5'>OpenHarmony</b>6.0 Release,<b class='flag-5'>鸿蒙</b>明星<b class='flag-5'>开发</b>板

    触觉智能RK3576开发板通过OpenHarmony5.0 XTS认证

    触觉智能作为开源鸿蒙南向硬件厂家,旗下RK3576开发板及其核心板(模组)PurplePiOH2系列通过了OpenHarmony5.0XTS
    的头像 发表于 10-21 12:48 1298次阅读
    触觉<b class='flag-5'>智能</b>RK3576<b class='flag-5'>开发</b>板通过<b class='flag-5'>OpenHarmony</b>5.0 XTS认证

    【置顶公告】视美泰开源鸿蒙系列产品业务咨询与商务合作通道正式开启!

    合作、高效响应需求,现正式开通开源鸿蒙系列产品专项业务咨询与商务合作通道,诚邀各界伙伴携手共进! 合作内容方向开源鸿蒙硬件定制开发基于OpenHarmony
    发表于 10-20 16:23

    触觉智能RK3576开发OpenHarmony开源鸿蒙系统USB控制传输功能示例

    本文介绍OpenHarmony开源鸿蒙系统的USB控制传输功能实现及相关代码示例,基于触觉智能RK3576开发板PurplePiOH2演示。Open
    的头像 发表于 09-30 16:31 1928次阅读
    触觉<b class='flag-5'>智能</b>RK3576<b class='flag-5'>开发</b>板<b class='flag-5'>OpenHarmony</b>开源<b class='flag-5'>鸿蒙</b>系统USB控制传输功能示例

    触觉智能RK3506开发板通过OpenHarmony 5.1 XTS认证,引领鸿蒙开发新标杆!

    触觉智能作为瑞芯微专业方案商与开源鸿蒙南向硬件厂家,旗下RK3506开发板及其核心板(模组)通过OpenHarmony5.1XTS认证!这一
    的头像 发表于 08-14 23:49 2118次阅读
    触觉<b class='flag-5'>智能</b>RK3506<b class='flag-5'>开发</b>板通过<b class='flag-5'>OpenHarmony</b> 5.1 XTS认证,引领<b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b>新标杆!

    开鸿开发板深度体验:从开源鸿蒙开发到AI场景实践

    的KaihongBoard-3588S-SBC和KaihongBoard-3576-SBC被评为“2025OpenHarmony明星开发板”,可实现设备快速开源鸿蒙化升级、分布式互联协
    的头像 发表于 07-03 17:03 2119次阅读
    开鸿<b class='flag-5'>开发</b>板深度体验:从开源<b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b>到AI场景实践

    开源鸿蒙开发必备!OpenHarmony替换Full SDK全攻略

    本文介绍开源鸿蒙OpenHarmony替换FullSDK的方法,演示设备为触觉智能PurplePiOH鸿蒙
    的头像 发表于 06-06 18:11 1128次阅读
    开源<b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b>必备!<b class='flag-5'>OpenHarmony</b>替换Full SDK全攻略

    触觉智能鸿蒙开发板率先通过OpenHarmony5.0认证(生态产品兼容性证书)

    触觉智能PurplePiOH鸿蒙开发板继4.1版本XTS认证火速出圈后,再次狂飙!成功通过OpenHarmony5.0ReleaseXTS认证,成为首批开放原子基金会生态产品之一。这一
    的头像 发表于 06-06 17:54 1551次阅读
    触觉<b class='flag-5'>智能</b><b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b>板率先通过<b class='flag-5'>OpenHarmony</b>5.0认证(生态产品兼容性证书)

    鸿蒙5开发案例分享揭秘---一多开发实例(商务办公)

    /9 : 21/9) 横竖屏自动切换宽高比,弹幕位置自适应调整,这体验堪比某站! ?️** 四、开发小抄(压箱底技巧)** 断点监听神器 : // 三行代码搞定设备检测 const
    发表于 06-03 16:24