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中

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

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

官网地址:班级学习地址

相关推荐
Georgewu7 小时前
【 技术开源共建 】开源日历组件ossimplecalendarview快速集成
harmonyos
2501_919749037 小时前
鸿蒙:侧边栏显示与隐藏
华为·harmonyos
SuperHeroWu77 小时前
【鸿蒙开源技术共建】用@luvi/lv-markdown-in在HarmonyOS上打造高性能Markdown编辑体验
华为·开源·harmonyos
猫林老师7 小时前
HarmonyOS 5 Native与ArkTS混合开发实战:跨语言高性能组件开发
华为·harmonyos
Georgewu7 小时前
【鸿蒙开源技术共建】用@luvi/lv-markdown-in在HarmonyOS上打造高性能Markdown编辑体验
harmonyos·markdown
前端世界8 小时前
鸿蒙应用内存优化全攻略:从泄漏排查到对象池实战
华为·harmonyos
特立独行的猫a9 小时前
梦回童年,将JSNES 游戏模拟器移植到 HarmonyOS 移植指南
游戏·华为·harmonyos
it奔跑在路上16 小时前
DevEco Studio 编辑器的使用
华为·编辑器·harmonyos·harmonyos next
Devil枫17 小时前
鸿蒙系统敏感文件安全存储:从系统机制到 ArkTS 实现
安全·华为·harmonyos
安卓开发者17 小时前
鸿蒙Next密码自动填充服务:安全与便捷的完美融合
安全·华为·harmonyos