作者:蔡奇
本文档旨在解说新建 Helloworld 我的项目步骤、固件包烧录到 BES2600WM 开发板、实现 js 和 C 代码的通信。该 Demo 重点体现的是 OpenAtom OpenHarmony(以下简称“OpenHarmony”) 3.1 Beta 零碎轻量设施 js 和 C 的交互能力,
成果如图
(注:BES2600WM 是 V200Z-R 开发板外围芯片,欧智通是 V200Z-R 开发板厂商,BES2600WM 开发板为轻量设施,移植 OpenHarmony 3.1 Beta 版本零碎)
欧智通 V200Z-R 是一款可带一块 480*480 显示屏的开发板,其特点如下:
① V200Z-R 是高度集成的无线模块,具备语音和音频性能。基于 BES2600WM 解决方案实现,具备 Cortex-M33 Star 双核 MCU 子系统和 Cortex-A7 双核 AP 子系统;
② 该模块反对低功耗 Wi-Fi4(1T1R 802.11a/b/g/n 双频段)和蓝牙 5.2 双模(反对 BT/BLE、LE 音频)。此外,它还提供了一个高性能的板载天线,从而升高了硬件设计的复杂性;
③ V200Z-R 还提供了一个语音和音频编解码器子系统和一个显示 2D 图形引擎子系统。它反对 MIPI DSI 高清显示 (720P@ 60fps),反对高达 2MPixel 的 MIPICSI 摄像头,并反对最多 3 个模仿麦克风或 6 个数字麦克风用于远场语音利用的麦克风阵列。单片机子系统运行蓝牙协定栈,AP 子系统和 2D 硬件图形引擎能够减速 GUI 和 VUI、语音和音频解决以及人工智能工作。如图:
1、新建工程、抉择模板
因为 BES2600WM 开发板为轻量设施,移植的是 OpenHarmony 3.1 Beta 版本零碎,且该零碎版本反对在轻设施开发 js 利用,故这里抉择代表轻设施的: "[Lite]Empty Ability"模板,如图:
2、填写工程信息
顺次实现如下信息填写:
①:填好工程名称(Project name)
②:抉择工程类型 Application
③:填写包名
④:批改保留门路
⑤:抉择开发语言 JS
⑥:抉择API版本 Version 7
⑦:抉择设施类型
抉择 “Finish”,至此,新建工程结束,如图:
此时,该新建的工程构造,如下图:
其中:
a) .hml 结尾的 HML 模板文件,这个文件用来形容以后页面的文件布局构造;
b) .css 结尾的 CSS 款式文件,这个文件用于形容页面样;
c) .js 结尾的 JS 文件,这个文件用于解决页面和用户的交互。
3、增加js和C代码之间的交互
3.1 js如何传数据给C
首先,在hml 文件中增加按钮 button,如图:
在 index.css 文件中定义中该按钮大小、文字色彩、字体等,如图:
而后,在 index.js 文件中定义按钮响应事件:onButtonClick() ,它调用 SetKey() 能将 key 为 “JSAction“,value 为 “Hello World” 的字符串发送给 C 端,如图:
SetKey 函数的具体写法如下:
SetKey(key1, value1) { CommunicationKit.set({ key: key1, value: value1, success: function() { console.log('call storage.set success.'); }, fail: function(data, code) { console.log('call storage.set fail, code: ' + code + ', data: ' + data); }, });},
注:SetKey 函数中的 CommunicationKit 模块申明文件须要拷贝到 DevEcoStudio 所装置的:“/DevEcoToolSdk/js/3.0.0/api/common/” 目录上面,如图:
该 CommunicationKit 模块申明文件在和本 README.md 文件同级目录的文件夹“CommunicationKit_Tool/”,如图:
最初,点击该按钮,如图:
此时,C 端通过 JsSetClang 办法获取 JS 端发送过去的 key 为: “JSAction“,value 为: “Hello World” 的字符串数据,如图:
并且,该函数增加了 LOG_I 打印 JS 端发过来的数据,如图:
该函数定义如下:
static int JsSetClang(const char *key, char *value){ if (NULL == key || NULL == value) { return -1; } if ((0 == strcmp(key, "JsAction")) && (0 == strcmp(value, "Hello World"))) { g_recvJsDataFlag = !g_recvJsDataFlag; LOG_I("Get JS string information -> %s.\r\n", value); } return 0;}
C 端收到 JS 端数据后,该 LOG_I 所打印信息如图所示:
(注:C端的代码门路(https://gitee.com/openharmony...))
3.2 C如何传数据给js
首先,轻量设施端的 C 程序通过 JsGetClang 办法向 JS 发送 key 为 ”ResponseFromC“ ,value 为 “Hello World from BES2600!” 的字符串,如图:
该函数定义如下:
static int JsGetClang(const char *key, char *value){ char buf[1024] = {0}; memset(buf, 0, sizeof(buf)); if(0 != g_recvJsDataFlag) { memcpy(buf, "{\"ResponseFromC\":\"Hello World from BES2600!\"}", strlen("{\"ResponseFromC\":\"Hello World from BES2600!\"}") + 1); buf[strlen("{\"ResponseFromC\":\"Hello World from BES2600!\"}")] = '\0'; } memcpy(value, buf, strlen(buf) + 1); return 0;}
而后,JS 页面初始化的时候,JS 曾经通过设置定时器来轮询 GetKey() 办法,一直获取 C 程序传过来的数据,当收到数据后,在界面显示进去,如图:
GetKey() 办法的具体写法如下,如图:
GetKey() { CommunicationKit.get({ key: 'storage_key', success: (data)=> { console.log('call storage.get success: ' + data); let res = JSON.parse(data) if (res.ResponseFromC) { this.title = res.ResponseFromC; } }, fail: function(data, code) { console.log('call storage.get fail, code: ' + code + ', data: ' + data); }, complete: function() { console.log('call complete'); }, });},
最初,C 端发送过去的数据 “Hello World from BES2600!” 在界面显示如下:
4、生成Hap文件
下载/新建结束 js 端代码后,在 DevEcoStudio 开发环境关上如下代码,如图:
(注:js端的代码门路(https://gitee.com/openharmony...))
顺次抉择:
①:“Build”
②:“Build Hap(s)/APP(s)"
③:“Build Haps(s)",如图:
编译通过,生成 Hap 文件结束,点击“Build”可查看后果,如图所示:
5、提取Hap文件内js相干文件
进入到新建的 HelloWrold 工程下 “\entry\build\outputs\hap\debug”目录,找到 hap 包:“entry-debug-lite-unsigned.hap”,如图:
(注:因为目前轻量设施的包不须要签名,所以间接应用unsigned的hap包)
将该.hap 文件复制一份,并将后缀名批改成 “.zip”,如图:
解压该 zip 包,顺次进入“asset/js/default/” 目录,删除 app.js.map,残余的文件是 js 相干文件,如图:
6、生成Bes2600固件
6.1 OpenHarmony v3.1-Beta 代码下载
关上虚拟机,输出如下repo命令
• 首先,在虚拟机输出:
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'
如图:
执行结束后,如图:
这三条命令执行结束,即可实现 OpenHarmony V3.1 Beta 版本代码下载,其工程构造如下图:
为了和后续的 bes2600 辨别开,可将上图"vendor/"文件夹下层的“Bes2600/”文件夹改成“OpenHarmony3.1_Beta/”,而后,顺次进入“OpenHarmony3.1_Beta/vendor/team_x”,如下图:
6.2 增加Bes2600 c端代码下载
关上 HelloWorld C端的代码门路(https://gitee.com/openharmony...)(该源码可运行于 Bes2600 开发板),顺次点击 “克隆/下载” 和 “下载zip”,如图:
下载结束,解压 zip 后,进入如下目录,复制:“knowledge_demo_temp\dev\team_x\bes2600_app_jsi_helloworld” 文件夹下全部内容,如图:
粘贴到 “OpenHarmony3.1_Beta/vendor/team_x/bes2600” 门路下,如图:
(注:“bes2600”文件夹不存在的话,能够新建,OpenHarmony3.1_Beta为刚刚下载的零碎代码)
关上 “bes2600/fs/data/data/js/” 文件夹, 如图:
复制刚刚从 Hap 文件中提取的 js 文件:即 "default/" 文件夹下全部内容,如图:
粘贴到“smart_door_bell/fs/data/data/js” 门路(注:同名文件能够笼罩),如图:
该门路在虚拟机显示成果,如图:
6.3 Bes2600 固件生成
在虚拟机进入 OpenHarmony3.1_Beta/ 目录,输出命令:“hb set”,抉择编译的工程名字,如图:
抉择方才的工程名字:“bes2600”,开始编译,如图:
编译通过,Bes2600 开发板固件生成胜利,如图:
7、烧录固件
7.1 下载CP210x串口驱动
在浏览器关上下载链接,点击下载,如图:(注:该串口驱动官网下载链接 :https://www.silabs.com/docume... )
7.2 装置CP210x串口驱动
解压“CP210x_Windows_Drivers.zip”,点击: “CP210xVCPInstaller_x64.exe”,如图:
(注:32位零碎能够装置x86版本,64位零碎能够装置x64版本)
装置结束,点击“实现”,如图:
链接好开发板(Bes2600 开发板的“烧录”和“电源”接口能够别离通过 type_c 连贯到电脑),如图:
关上 WIFI 烧录工具,如图:
(注:当编译结束、固件生成胜利后,该烧录工具 “Wifi_download_main.exe” 就会主动被生成在:工程"bes2600/write_flash_gui"文件夹下)
关上后,如图:
7.3 开始烧录固件
鼠标右键点击 PC 右下角,关上:“设施管理器(M)”,如图:
(注: 关上设施管理器前,请确保CP210x串口驱动是否装置)
搜寻 “端口 -> USB SERIAL Port(COM10*)",须要记住COM,每台设施的不一样,如图:
(注:如果端口没显示,请拔掉usb口再插上或更换usb线)
抉择对应的 com 口,点击“OK”,如图:
按下 BES2600WM 开发板反面的复位 Reset 按钮,如图:
开始烧录,如图:
烧录胜利,如图:
按下轻量设施反面的复位 Reset 按钮,如图:
此时,BES2600WM 开发板将重新启动,在屏幕上点击 “js 调用 c” 按钮后,界面胜利显示 C 端传过来的字符串:“Hello World from BES2600!”,如图:
智能门铃样例也基于恒玄开发板
https://growing.openharmony.c...
更多样例请参考官网
https://growing.openharmony.c...