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中

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

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

官网地址:班级学习地址

相关推荐
HwJack207 小时前
HarmonyOS APP开发中Feature模块小案例:动态化开发的“瑞士军刀“
华为·harmonyos
鸿蒙程序媛8 小时前
【知识汇总】PixelMap 和 ArrayBuffer 详解
harmonyos
程序猿追8 小时前
HarmonyOS 6.0 网络请求深度解析:从基础调用到生产级封装
网络·华为·harmonyos
互联网散修11 小时前
鸿蒙应用开发UI基础第三十四节:媒体查询核心解析 —— 响应式布局与工具类封装
ui·harmonyos·媒体查询
性感博主在线瞎搞11 小时前
【鸿蒙开发】OpenHarmony与HarmonyOS调用C/C++教程
华为·harmonyos·鸿蒙·鸿蒙系统·openharmony
大雷神12 小时前
HarmonyOS APP<玩转React>开源教程二十三:面试题库功能
harmonyos
程序猿追12 小时前
HarmonyOS 5.0 自定义组件与状态管理实战:用 RelationalStore 构建可复用的任务看板
华为·harmonyos
程序猿追12 小时前
HarmonyOS 6.0 实战:用 Native C++ NDK 开发一款本地计步器应用
c++·华为·harmonyos
程序猿追14 小时前
HarmonyOS 6.0 PC端蓝牙开发全攻略:从设备扫描到数据收发
华为·harmonyos