HarmonyOS中调用C/C++代码(NDK)

开发工具准备

下载最新的编辑器

下载中心 | 华为开发者联盟-HarmonyOS开发者官网,共建鸿蒙生态

选择合适的版本下载

​编辑下载完成以后解压 然后全程下一步安装

安装教程

安装完毕以后 开始创建Native项目

第一步 新建项目

​编辑

第二步 选择 Native C++ 别选第一个

​编辑第三步 创建项目名称 包名 保存路径 切记别用中文

​编辑第四步 查看整个项目结构和预览效果

ps:不要觉得很难 动手操作起来就还好

​编辑

第五步:查看CPP文件

​编辑

其中1 表示描述C++ API接口行为,如接口名、入参、返回参数等

切记是描述 类似Arkts中interface 用来声明的 而不具体实现的

其中2 表示 C++源码编译配置文件,提供CMake构建脚本

别看后缀是txt,功能很强大的

其中3表示 C++源文件

c++的代码都写在cpp结尾的文件中 ,页面要调用的也就是C++中代码

第六步 在napi_init.cpp中定义一个求和的方法

ini 复制代码
#include "napi/native_api.h"

static napi_value Add(napi_env env, napi_callback_info info)
{
    size_t argc = 2;
    napi_value args[2] = {nullptr};

    napi_get_cb_info(env, info, &argc, args , nullptr, nullptr);

    napi_valuetype valuetype0;
    napi_typeof(env, args[0], &valuetype0);

    napi_valuetype valuetype1;
    napi_typeof(env, args[1], &valuetype1);

    double value0;
    napi_get_value_double(env, args[0], &value0);

    double value1;
    napi_get_value_double(env, args[1], &value1);

    napi_value sum;
    napi_create_double(env, value0 + value1, &sum);

    return sum;

}

第七步:在 Index.d.ts 中 定义方法 并且导出

typescript 复制代码
export const add: (a: number, b: number) => number;

第八步 :回到page下面的Arkt中

先导入

javascript 复制代码
import testNapi from 'libentry.so';

这个so就是​编辑默认表示index文件

使用的地方 testNapi获取到对应的方法

scss 复制代码
import testNapi from 'libentry.so';

@Entry
@Component
struct Index {
  @State message: string = 'Hello World';

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize($r('app.float.page_text_font_size'))
          .fontWeight(FontWeight.Bold)
          .onClick(() => {
              this.message =String( testNapi.add(8,10))
          })
      }
      .width('100%')
    }
    .height('100%')
  }
}

点击页面文字就能看到变化 工作中鸿蒙应用开发者只关注页面层和接口层,接口层的定义libentry中

回顾这种图 看能否给您不一样的收获

​编辑请点击下面链接加入班级 获取最新鸿蒙学习免费资料

官网地址:班级学习地址

相关推荐
ilmari5 小时前
HarmonyOS 基于Network Kit封装的网络请求工具
android·flutter·harmonyos
simple_lau6 小时前
鸿蒙资源加载深度解析:$r与$rawfile的性能差异与最佳实践
harmonyos·arkts·arkui
zkmall8 小时前
移动商城平台适配:ZKmall开源商城鸿蒙 / 小程序端开发要点
小程序·开源·harmonyos
前端菜鸟日常14 小时前
鸿蒙组件装饰器深度解析:@Component vs @ComponentV2
华为·harmonyos
AlbertZein16 小时前
HarmonyOS5 源码分析 —— ‘状态管理’如何管理的(1)?
架构·harmonyos
鹿鸣天涯18 小时前
鸿蒙OS 系统安全
华为·系统安全·harmonyos
kymjs张涛1 天前
HarmonyOS Next 全兼容,三端统一的路由跳转方案
harmonyos
前端世界1 天前
鸿蒙系统下的动态负载均衡实战:让分布式任务调度更智能
分布式·负载均衡·harmonyos
HarmonyOS小助手1 天前
餐饮服务与软件创新的融合:解析海底捞 APP 的 Flutter 鸿蒙开发之路
harmonyos·鸿蒙·鸿蒙生态