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中

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

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

官网地址:班级学习地址

相关推荐
TrisighT12 小时前
DevEco Code 写鸿蒙 ArkTS 确实快,但我试了三天后把默认引擎换成了 Cursor
ai编程·harmonyos·cursor
liz7up12 小时前
鸿蒙原生流程图 & 审批流组件 hmflowkit
harmonyos
网易云信1 天前
全框架覆盖!网易智企IM鸿蒙生态适配再进一步
人工智能·aigc·harmonyos
TrisighT1 天前
我用 AI 逆向了 ArkTS @Builder 的编译产物,看完再也不敢乱写嵌套了
ai编程·harmonyos·arkts
ONEDAY3 天前
HarmonyOS 深色模式适配实践:从资源、WebView 到网络图统一处理
harmonyos
鸿蒙开发3 天前
鸿蒙(HarmonyOS NEXT)表单校验别再手撸正则了 —— 我写了个 ArkTS 版 zod
harmonyos
TrisighT3 天前
ArkTS 的 @BuilderParam 你八成只用了皮毛——那个尾随闭包写法差点被我当 bug 删了
harmonyos·arkts·arkui
ONEDAY4 天前
HarmonyOS 多 Product 构建实践:一套代码生成多个产物
harmonyos
TT_Close4 天前
别劝退了!5秒搞定 Flutter 鸿蒙 FVM 起跑线
flutter·harmonyos·visual studio code
TrisighT4 天前
ArkTS 列表滚动时为什么会闪现旧数据?我扒了 LazyForEach 的复用逻辑
harmonyos·arkts·arkui