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

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

3天内不再提示

基于OpenHarmony NAPI框架控制板端LED

电子发烧友开源社区 来源:未知 2022-11-01 09:25 次阅读

前言: 自己一直是板端开发也就是南向开发,对于北向应用端开发一直是个短板,九联提供的开发板对南北向开发过程提供了样例,非常感兴趣这一部分,如何实现,下面就自己根据样例实现开发板上使用APP控制板端接口来学习。下面根据Openharmony NAPI框架实现GPIO接口。

一、开发环境

  • 搭载OpenHarmony-3.2-Beat2版本的九联开发板。

  • Ubuntu20.04虚拟机。

  • USB_Burning_Tool烧录工具。

  • 自己准备LED灯及接口线。

以上除4部分,其他都在前面的帖子中搭建完成。第4部分自己准备几根杜邦线和几个LED灯。

二、NAPI框架简介

NAPI(Native API)是OpenHarmony标准系统的一种JS API实现机制,适合封装IO、CPU密集型、OS底层等能力并对外暴露JS接口,实现JS与C/C++代码互相访问。

a7832782-5983-11ed-a3b6-dac502259ad0.png

三、实现NAPI扩展库

1、创建NAPI扩展库

新增子系统napisubsys在OpenHarmony源码目录下创建一个目录napisubsys作为子系统目录(子系统可以在OpenHarmony源码目录任意位置),目前创建在九联开发板目录下sample/napi目录下,具体相对OpenHarmony目录为vendor/unionman/unionpi_tiger/sample/napi/napisubsys,在创建的目录下新建ohos.build文件,构建时会先读取这个文件。将新增子系统配置到OpenHarmony目录下的build/subsystem_config.json文件中参与编译。subsystem_config.json增加如下代码:

"napisubsys": {
"path": "vendor/unionman/unionpi_tiger/sample/napi/napisubsys",
"name": "napisubsys"
},

(左右移动查看全部内容)

2、新增gpioled_part组件

在子系统napisubsys目录下创建一个子组件目录gpioled_part,打开napisubsys目录下的ohos.build文件,在"parts":中添加下列语句:

"gpioled_part": {
  "variants": [
    "phone"
  ],
  "module_list": [    "//vendor/unionman/unionpi_tiger/sample/napi/napisubsys/gpioled_part/gpioled_demo:gpioled"
  ]
}

(左右移动查看全部内容)

3、新增扩展动态库

在组件目录gpioled_part下面新建gpioled_demo目录,作为NAPI扩展库的代码目录。在gpioled_demo目录下创建gpioled.cpp和BUILD.gn文件,编写构建配置也即BUILD.gn文件内容如下:

import("//build/ohos.gni")
ohos_shared_library("gpioled") {
include_dirs = [ "//foundation/ace/napi/interfaces/kits" ]
sources = [
"gpioled.cpp",
"um_gpio.c",
]
deps = [
"//foundation/ace/napi:ace_napi",
"//utils/native/base:utils",
]
external_deps = [ "hiviewdfx_hilog_native:libhilog" ]
relative_install_dir = "module"
subsystem_name = "napisubsys"
part_name = "gpioled_part"
}

(左右移动查看全部内容)

4、将组件添加到产品定义中

打开vendor/unionman/unionpi_tiger/config.json文件,在“subsystems”:中添加如下语句:

{
"subsystem": "napisubsys",
    "components": [
       {
        "component": "gpioled_part",
        "features": []
       }
   ]
},

(左右移动查看全部内容)

四、NAPI接口开发

模块注册

1)添加NAPI框架头文件,引入框架提供的方法。

#include "napi/native_api.h"
#include "napi/native_node_api.h"

(左右移动查看全部内容)

2)定义模块。

3)注册模块,加载动态库时自动调用注册。

/*
* 模块定义
 */


static napi_module gpioled_demoModule = {
.nm_version = 1,
.nm_flags = 0,
.nm_filename = nullptr,
.nm_register_func = registerGpioLed_DemoApis,
.nm_modname = "gpioled_demo", //模块名
.nm_priv = ((void *) 0),
.reserved = {0},
};


/*


* 注册模块
 */
 extern "C" __attribute__((constructor)) void RegisterGpioLed_DemoModule(void) {
 napi_module_register(&gpioled_demoModule); //接口注册函数
 }

(左右移动查看全部内容)

使用DECLARE_NAPI_FUNCTION("js函数名", c++实现函数名)定义接口函数、DECLARE_NAPI_PROPERTY、 DECLARE_NAPI_STATIC_PROPERTY等定义属性,再通过napi_define_properties赋给exports对象,最后返回exports对象。

/*
* 注册接口
 */


static napi_value registerGpioLed_DemoApis(napi_env env, napi_value exports) {
napi_value gpioValHigh = gpioValHigh;
napi_value gpioValLow = nullptr;
napi_create_int32(env, UM_GPIO_HIGH_LEVE, &gpioValHig);
napi_create_int32(env, UM_GPIO_LOW_LEVE, &gpioValLow);
napi_property_descriptor desc[] = {
DECLARE_NAPI_FUNCTION("setLedStatusWithCallback", setLedStatusWithCallback),
DECLARE_NAPI_FUNCTION("getLedStatusWithCallback", getLedStatusWithCallback),
DECLARE_NAPI_FUNCTION("setLedStatusWithPromise", setLedStatusWithPromise),
DECLARE_NAPI_FUNCTION("getLedStatusWithPromise", getLedStatusWithPromise),
DECLARE_NAPI_FUNCTION("setLedStatus", setLedStatus),
DECLARE_NAPI_FUNCTION("getLedStatus", getLedStatus),
DECLARE_NAPI_STATIC_PROPERTY("LED_ON", gpioValHigh),
DECLARE_NAPI_STATIC_PROPERTY("LED_OFF", gpioValLow),
};
NAPI_CALL(env, napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc));
return exports;
}

(左右移动查看全部内容)

具体实现代码可去代码仓库进行下载学习。

修改deviceoardunionmanunionpi_tigerconfiginitarminit.A311D.cfg 文件,在cmds中添加相关命令

"write /sys/class/gpio/export 380",
"write /sys/class/gpio/export 381",
"write /sys/class/gpio/export 382",
"write /sys/class/gpio/export 383",
"write /sys/class/gpio/export 384",
"write /sys/class/gpio/export 385",
"write /sys/class/gpio/export 386",
"write /sys/class/gpio/export 387",
"write /sys/class/gpio/export 388",
"write /sys/class/gpio/export 389",
"chmod 666 /sys/class/gpio/gpio380/direction",
"chmod 666 /sys/class/gpio/gpio381/direction",
"chmod 666 /sys/class/gpio/gpio382/direction",
"chmod 666 /sys/class/gpio/gpio383/direction",
"chmod 666 /sys/class/gpio/gpio384/direction",
"chmod 666 /sys/class/gpio/gpio385/direction",
"chmod 666 /sys/class/gpio/gpio386/direction",
"chmod 666 /sys/class/gpio/gpio387/direction",
"chmod 666 /sys/class/gpio/gpio388/direction",
"chmod 666 /sys/class/gpio/gpio389/direction",
"chmod 666 /sys/class/gpio/gpio380/value",
"chmod 666 /sys/class/gpio/gpio381/value",
"chmod 666 /sys/class/gpio/gpio382/value",
"chmod 666 /sys/class/gpio/gpio383/value",
"chmod 666 /sys/class/gpio/gpio384/value",
"chmod 666 /sys/class/gpio/gpio385/value",
"chmod 666 /sys/class/gpio/gpio386/value",
"chmod 666 /sys/class/gpio/gpio387/value",
"chmod 666 /sys/class/gpio/gpio388/value",
"chmod 666 /sys/class/gpio/gpio389/value"

(左右移动查看全部内容)

五、Ubuntu下进行编译NAPI

将以上文件修改完成后,编译镜像文件,前面帖子中已有编译方法,自行查阅,如有问题帖子留言,我会进行回答。进入到Ubuntu下进行编译,编译指令如下:

./build.sh --product-name unionpi_tiger –ccache

(左右移动查看全部内容)

编译完成如下图所示:

a79cb5bc-5983-11ed-a3b6-dac502259ad0.png

编译完成后需要,进行对镜像进行打包,然后进行烧写。执行以下命令固件打包

./device/board/unionman/unionpi_tiger/common/tools/packer-unionpi.sh

(左右移动查看全部内容)

打包完成如下图所示,打包最终烧录程序目录为out/unionpi_tiger/packages/phone/images/OpenHarmony.img

a7c371a2-5983-11ed-a3b6-dac502259ad0.png

打开烧录工具,使用Micro USB数据线连接PC与开发板OTG口并接通电源,导入烧录包后开始烧录即可(可关闭校验IMG)。具体如何烧录可参考我的其他博文。

六、应用程序编译

打开DevEco Studio 3.0.0.993版本的软件,打开vendor_unionman/unionpi_tiger/sample/app/gpioled_app/gpioled-javascript目录,如下图所示程序代码

a81df35c-5983-11ed-a3b6-dac502259ad0.png

将目录vendor_unionman/unionpi_tiger/sample/napi/napisubsys下的@ohos.gpioled.d.ts文件拷贝到OpenHarmony的SDK下面,如图所示具体路径:

a8325e0a-5983-11ed-a3b6-dac502259ad0.png

设置自动签名,如图所示:

a8591414-5983-11ed-a3b6-dac502259ad0.png

编译Hap文件,如下图所示:

a86c344a-5983-11ed-a3b6-dac502259ad0.png

将编译后的hap文件拷贝到USB中,因SDK中的hdc_std.exe不运行,用USB安装应用程序了,文件如下图所示,可自行修改文件名。

a88ea4bc-5983-11ed-a3b6-dac502259ad0.png

七、板端安装应用控制LED灯

将USB插入USB3.0接口,串口端显示如下所示:

a8c0bc4a-5983-11ed-a3b6-dac502259ad0.png

挂载/dev/block/sda1到/mnt/usb目录,如果没有/mnt/usb目录进行自建,运行如下命令进行安装hap,如图所示:

bm install -p 包名.hap

(左右移动查看全部内容)

a8d5b94c-5983-11ed-a3b6-dac502259ad0.png

安装后屏幕界面如图所示:

a9216f5e-5983-11ed-a3b6-dac502259ad0.png

连接GPIO_05到LED的正极,如下图所示:

a94adf24-5983-11ed-a3b6-dac502259ad0.png

打开gpioled的app运行如视频所示。

弄了hdc_std.exe,但它不运行,有问题。正在查找问题。有了hdc,直接连接板子OTG将hap运行到板子上看app效果,可以看调试信息,一口两用。

提示:本文由电子发烧友社区发布,转载请注明以上来源。如需社区合作及入群交流,请添加微信EEFans0806,或者发邮箱liuyong@huaqiu.com。

更多热点文章阅读

END

想了解更多开源技术?后台留言,立刻安排!

就喜欢奖励一个“”和“在看”呗~


原文标题:基于OpenHarmony NAPI框架控制板端LED

文章出处:【微信公众号:电子发烧友开源社区】欢迎添加关注!文章转载请注明出处。

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

    关注

    237

    文章

    22621

    浏览量

    647462
  • NAPIT
    +关注

    关注

    0

    文章

    2

    浏览量

    2113
  • OpenHarmony
    +关注

    关注

    24

    文章

    3480

    浏览量

    15426

原文标题:基于OpenHarmony NAPI框架控制板端LED

文章出处:【微信号:HarmonyOS_Community,微信公众号:电子发烧友开源社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    FS2722 LED化妆镜控制板的相关资料分享

    FS2722 LED化妆镜控制板1、LED化妆镜控制板,FS2722 三挡触摸调光LED台灯控制板
    发表于 02-14 07:40

    使用NAPI实现openharmony APP网络开发的接口

    1.设计背景当前openharmony标准系统通过 JS、eTS 开发貌似还没支持网络开发的接口,故JS、eTS方式开发只能通过NAPI调用C/C++才能使用到网络,本次我就使用NAPI开发
    发表于 04-02 09:56

    基于OpenHarmony的智能金属探测器

    )基于 eTS 扩展的声明式开发范式编写页面,通过 NAPI 接口接收设备 Geek_Lite_Board 开发的检测信息,使用 OpenHarmony 媒体子系统中的音频播放功能
    发表于 07-05 10:52

    如何通过OpenHarmony系统中集成的ffmpeg库和NAPI机制,实现更多的多媒体功能?

    能。一、NAPI实现以下是源码分析的内容,核心的模块主要代码是myffmpegsys,为应用提供了js的接口。1. myffmpegsys作为一个新的子系统集成到OpenHarmony源码中,放置在
    发表于 07-07 10:08

    如何通过OpenHarmony系统中集成的ffmpeg库和NAPI机制,实现更多的多媒体功能?

    OpenHarmony社区建设,不断推动开源事业的发展。身为深开鸿的一名OS框架开发工程师,我在OpenHarmony 开源项目成立伊始便积极加入OpenHarmony 社区建设,负责
    发表于 07-12 17:13

    如何通过OpenHarmony系统中集成的ffmpeg库和NAPI机制,实现更多的多媒体功能?

    OpenHarmony社区建设,不断推动开源事业的发展。身为深开鸿的一名OS框架开发工程师,我在OpenHarmony 开源项目成立伊始便积极加入OpenHarmony 社区建设,负责
    发表于 07-25 16:57

    【润和软件DAYU200开发体验】三方库移植之NAPI开发[1]—Hello OpenHarmony NAPI

    本文通过一个Hello OpenHarmony NAPI样例讲述了NPAI接口开发基础知识。开发基于最新的OpenHarmony3.2Beta3版本及其对应SDK。标准系统开发为润和
    发表于 10-06 22:27

    【九联科技Unionpi Tiger开发试用体验】基于OpenHarmony NAPI框架控制板LED

    前言: 自己一直是开发也就是南向开发,对于北向应用开发一直是个短板,九联提供的开发对南北向开发过程提供了样例,非常感兴趣这一部分,如何实现,下面就自己根据样例实现开发
    发表于 10-28 18:46

    触觉智能RK3568使用体验—NAPI 类对象导出及其生命周期管理(上)

    本篇知识点,下半部分将对源码进行解析。通过本文您将熟悉:NAPI 导出类对象NAPI 对象生命周期管理往期回顾:三方库移植之NAPI开发[1]—Hello OpenHarmony
    发表于 02-08 17:10

    OpenHarmonyNAPI框架介绍

    NAPI OpenAtom OpenHarmony(以下简称“OpenHarmony”)应用层基于 javascript 语言开发,而系统框架层则基于 C++语言。它们之间需要一个
    发表于 11-23 15:36

    【润和软件DAYU200开发板体验】三方库移植之NAPI开发[1]—Hello OpenHarmony NAPI

    子) 将C/C++ 三方库移植到OpenHarmony标准系统后,需要通过NAPI框架将其C/C++ 接口转换成JS/ETS接口给应用层调用。 通过本文您将熟悉 : 如何注册NAPI
    的头像 发表于 10-12 10:38 1584次阅读
    【润和软件DAYU200开发板体验】三方库移植之<b class='flag-5'>NAPI</b>开发[1]—Hello <b class='flag-5'>OpenHarmony</b> <b class='flag-5'>NAPI</b>

    教程分享!OpenHarmonyNAPI框架介绍

    是 C++语言实现的,这些接口可以帮助 C++代码创建 JS 变量,或访问 JavaScript 运行环境中的 JS 变量与方法。 OpenHarmony 中的 NAPI OpenAtom OpenHarmony(以下简称“
    的头像 发表于 11-30 12:15 858次阅读
    教程分享!<b class='flag-5'>OpenHarmony</b>之<b class='flag-5'>NAPI</b><b class='flag-5'>框架</b>介绍

    鸿蒙OpenHarmony NAPI技术-基础学习

    NAPI(Native API)是OpenHarmony系统中的一套原生模块扩展开发框架,它基于Node.js N-API规范开发,为开发者提供了JavaScript与C/C++模块之间相互调用的交互能力。可以在NodeJs官网
    的头像 发表于 01-19 16:57 557次阅读
    鸿蒙<b class='flag-5'>OpenHarmony</b> <b class='flag-5'>NAPI</b>技术-基础学习

    OpenHarmonyNAPI 框架介绍

    环境中的 JS 变量与方法。 OpenHarmony 中的 NAPI OpenAtom OpenHarmony(以下简称 “OpenHarmony”)应用层基于 javascript
    的头像 发表于 02-01 17:34 416次阅读
    <b class='flag-5'>OpenHarmony</b> 之 <b class='flag-5'>NAPI</b> <b class='flag-5'>框架</b>介绍

    【鸿蒙】NAPI 框架生成工具实现流程

    NAPI 框架生成工具 可以根据用户指定路径下的 ts(typescript)接口文件一键生成 NAPI 框架代码、业务代码框架、GN 文件
    的头像 发表于 02-28 17:00 391次阅读
    【鸿蒙】<b class='flag-5'>NAPI</b> <b class='flag-5'>框架</b>生成工具实现流程