鸿蒙Native输出so动态库,并提供给第三方导入使用

这篇具有很好参考价值的文章主要介绍了鸿蒙Native输出so动态库,并提供给第三方导入使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言:

DevEco Studio版本:4.0.0.600

API:9

最近在学习鸿蒙的Native输出so动态库,下面就给大家分享下我的学习心得及在实现过程中遇到的问题。

实现需求:通过so库输出文本内容 “你好,鸿蒙!”

参考资料:OpenHarmony Native API

实现过程:

1、创建Native工程

File-->New-->create Project,选择Native C++项目

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

正常点击Finish后,在项目中会自动生成一个示例模板代码,hello.cpp

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

2、创建C++文件,实现需求

我们有两种方式,一个是直接修改模板hell0.cpp,另外一种是自己新建一个.cpp文件。这边以新建方式来实现。

在cpp目录右键新建c++文件

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

show.cpp代码实现:(C代码能力有限,只能参考hello.cpp写个简单的文本输出!!!)

#include "napi/native_api.h"
#include <string.h>

static napi_value show(napi_env env, napi_callback_info info) {
    char *returnStr = "你好 鸿蒙!";
    napi_value result;
    napi_create_string_utf8(env, returnStr, strlen(returnStr), &result);

    return result;
}

EXTERN_C_START
static napi_value Init(napi_env env, napi_value exports) {
    napi_property_descriptor desc[] = {{"show", NULL, show, NULL, NULL, NULL, napi_default, NULL}};
    napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
    return exports;
}
EXTERN_C_END

static napi_module demoModule = {
    .nm_version = 1,
    .nm_flags = 0,
    .nm_filename = NULL,
    .nm_register_func = Init,
    .nm_modname = "cjson",
    .nm_priv = ((void *)0),
    .reserved = {0},
};

extern "C" __attribute__((constructor)) void RegisterEntryModule(void) { napi_module_register(&demoModule); }

3、CMakeLists.txt中添加对show.cpp的引用

# the minimum version of CMake.
cmake_minimum_required(VERSION 3.4.1)
project(NativeShow)

set(NATIVERENDER_ROOT_PATH ${CMAKE_CURRENT_SOURCE_DIR})

include_directories(${NATIVERENDER_ROOT_PATH}
                    ${NATIVERENDER_ROOT_PATH}/include)

#add_library(entry SHARED hello.cpp)
#target_link_libraries(entry PUBLIC libace_napi.z.so)

add_library(show SHARED show.cpp)
target_link_libraries(show PUBLIC libace_napi.z.so)

4、编译并导出so库

执行build-->build Hap,进行编译

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

然后在build--> intermediates --> libs -->default中可以看到arm64-v8a、armeabi-v7a、x86_64这三个默认的架构。

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

可以在项目的build-profile.json5中添加abiFilters输出的架构

"abiFilters": [
  'armeabi-v7a',
  'arm64-v8a'
]

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

重新执行build-->build Hap

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

5、在第三方应用中引用

新建一个应用,并在entry目录下新建libs目录,将上一步中的so库拷贝到新建的libs中

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

在index.ets中添加使用

import show from 'libshow.so'

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

  aboutToAppear(){
    this.message = show.show()
  }

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
      }
      .width('100%')
    }
    .height('100%')
  }
}

效果:

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

实现中遇到的坑:

1、libc++_shared.so没有导入,引起的‘undefined’错误

libc++_shared是C++运行时库,因此必须要引入。

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API

2、so库架构放置错误,引起的‘undefined’错误

测试中,我在分开测试arm64-v8a、armeabi-v7a时误将v8a的so复制到v7a中进行使用导致。因此在实际使用中,尽量连带着文件夹目录一起拷贝避免出现目录放置错误的情况

鸿蒙Native输出so动态库,并提供给第三方导入使用,鸿蒙,harmonyos,OpenHarmony,Native API文章来源地址https://www.toymoban.com/news/detail-846827.html

到了这里,关于鸿蒙Native输出so动态库,并提供给第三方导入使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • AndroidStudio调用第三方so库

    背景         最近公司设备换了新的触摸屏(为I2C接口),该触摸屏有个app,app中可以显示触摸屏固件的版本。我需要做的是在自己的app中读取到触摸屏固件版本。         反编译了apk,得到了源码,发现对方app是通过jni调用so库的方式获取到的触摸屏固件版本。所以

    2024年04月26日
    浏览(26)
  • React Native第三方组件库汇总

    UI套件 1, NativeBase NativeBase 是一个广受欢迎的 UI 组件库,为 React Native 提供了数十个跨平台组件。在使用 NativeBase 时,你可以使用任意开箱即用的第三方原生库,而这个项目本身也拥有一个丰富的生态系统,从有用的入门套件到可定制的主题模板。 NativeBase 项目地址: https:/

    2024年04月28日
    浏览(22)
  • ROS2学习(三)colcon编译某个包并提供给其他包依赖使用

        简单的ROS2的例子学习可能不会遇到这个问题。但是我们仍然难免会思考为什么ROS2官方提供的包比如rclcpp,这些包我们使用的时候可以直接添加依赖,使用find_package(rclcpp REQUIRED),就可以找到。我们自己编译的包是否也可以提供给其他包使用。     如果稍微大一

    2024年02月15日
    浏览(24)
  • Flutter 与第三方 Native-SDK 的交互代理方案

    场景 在使用 Flutter 进行功能模块或者整体项目的开发时,如果需要(阶段性)频繁地和某个第三方 Native-SDK 进行交互,而该 Native-SDK 没有实现 Flutter 插件版本的情况下,如果直接把这部分交互 API 加入到原有的 channel 类里面,会使得该 channel 类变得臃肿,造成代码维护及迭代

    2024年02月02日
    浏览(26)
  • Android基于JNA集成调用第三方C/C++的so库

    Android基于JNA集成调用第三方C/C++的so库 (1)引入JNA。 基于JNA开源项目,JNA对Android NDK的封装,简化Android层JNI集成调用C/C++的so库。 GitHub - java-native-access/jna: Java Native Access Java Native Access. Contribute to java-native-access/jna development by creating an account on GitHub. https://github.com/java-native-ac

    2024年02月02日
    浏览(32)
  • 记录--@click和@click.native有什么区别,如何阻止第三方组件内部的冒泡

    vue @click.native 原生点击事件: 1,给vue组件绑定事件时候,必须加上native ,不然不会生效(监听根元素的原生事件,使用 .native 修饰符) 2,等同于在子组件中: 子组件内部处理click事件然后向外发送click事件: $emit(\\\"click\\\".fn) 不多说看代码: 直接在封装组件上使用@click,看看

    2024年02月10日
    浏览(35)
  • Qt Creator导入第三方so库和jar包——Qt For Android

    之前了解了在Android Studio下导入so库和jar包,现在实现如何在Qt上导入so库和jar包。 下面是我安卓开发(需调用安卓接口的代码)的目录(图1),此目录结构和原生态环境(Android Studio)下开发的结构很相似: 图1 在Qt  Creator上导入so库和jar包,比在Android Studio上简单很多,只需

    2024年04月29日
    浏览(27)
  • HarmonyOS基础(七)- 详细剖析鸿蒙引入第三方库案例篇(1)

    大家好!我是黑臂麒麟(起名原因:一个出生全右臂自带纹身的高质量程序员😏),也是一位6+(约2个半坤年)的前端; 学习如像练武功一样,理论和实践要相结合,学一门只是也是一样; 这里会用两周的时间把所学的常用ArkUI基础的常用组件输出在网; 如需深究可前往高

    2024年04月23日
    浏览(21)
  • 第三方应用调用系统SO 库失败Caused by: java.lang.UnsatisfiedLinkError: dlopen failed: library

    在Android 31平台,尝试使用第三方应用调用系统SO 库,会报如下的错误 Caused by: java.lang.UnsatisfiedLinkError: dlopen failed: library \\\" /system/lib64/XXX.so \\\" needed or dlopened by \\\"/apex/com.android.art/lib64/libnativeloader.so\\\" is not accessible for the namespace \\\"classloader-namespace\\\" 大体原因是,Android N 开始限制 第三方

    2024年02月12日
    浏览(54)
  • 华为鸿蒙开发(HarmonyOs开发):超详细的:DevEco Studio 的安装和配置 、华为第三方包依赖:SDK软件包的安装、Nodejs的导入配置

    2023年11月28日20:00:00 ⚠️⚠️HarmonyOs 开发工具 ⚠️⚠️ ⚠️⚠️DevEco Studio 的安装和配置⚠️⚠️ ⚠️⚠️⚠️❤️❤️ 关注了解更多 一、打开鸿蒙开发工具官网 下面是安装DevEco Studio 的详细步骤:希望大家给个关注,祝大家:踏上HarmonyOs 之旅,步步高升! 下载地址:官

    2024年02月03日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包