当前位置: 首页 > article >正文

openharmony napi调试笔记

一、动态库的编译

第一种openharmony交叉编译链配置方法

使用的编译环境是ubuntu20.04

1、使用vscode配置openharmony sdk交叉编译环境

首先下载openharmony的sdk,如native-linux-x64-4.1.7.5-Release.zip

解压后native目录下就是交叉编译用的sdk

  1. 在要编译的源代码目录下新建.vscode目录,进入该目录新建settings.json文件文件内容如下,根据自己的sdk目录修改cmake的路径

{

 "cmake.cmakePath":"/home/xxx/native/build-tools/cmake/bin/cmake"

}

2、在vscode中也需要安装cmake插件

3、在插件中配置交叉编译器

打开cmake-tools-kits.json文件:

vim .local/share/CMakeTools/cmake-tools-kits.json

这个文件的作用就是:告诉VSCode当前系统中都有哪些编译器可供使用,一般是CMakeTools插件自动获取到的,但是CMakeTools插件无法自动获取到我们的交叉编译器。

所以我们手动将交叉编译器添加到cmake-tools-kits.json文件中(必须添加到文件末尾),因为我们使用的是CMake,所以只需将toolchain.cmake文件的路径配置进去就可以了:

{

    "name": "arm_corss_compiler",

    "toolchainFile": "/home/fhc/myWorkspace/cmake_project/cmake_cross_complie_base/toolchain.cmake"

}

4、Ctrl+Shift+p打开VSCode的指令面板,然后输入cmake:q,VSCode会根据输入自动提示,然后选择

CMake: Quick Start

5、然后选择我们自己配置的交叉编译器

6、编写cmake文件

cmake_minimum_required(VERSION 3.5.0)
project(TESTLIB VERSION 0.1.0 LANGUAGES C CXX)

set(ROOTDIR ..) #设置变量
set(SRCDIR ${ROOTDIR}/src)  
include_directories(${SRCDIR} ${SRCDIR}/..) #设置头文件搜索路径
aux_source_directory(${SRCDIR}/src CPP_SRC)
aux_source_directory(${SRCDIR}/others CPP_SRC) #将目录下的所有源文件包含变量CPP_SRC
add_library(TESTLIB SHARED ${CPP_SRC}) #设置库名称位TESTLIB 包含的源文件:CPP_SRC

set(LIBRARY_OUTPUT_PATH ${ROOTDIR}/../Lib/linuxLib) #设置库的导出目录

target_link_libraries(TESTLIB PUBLIC ${PROJECT_BINARY_DIR}/../../Lib/linuxLib/libusb_shared.z.so) #设置需要依赖的库

7、点击左下脚的build按钮

第二种、vscode安装及openharmony交叉编译链配置方法

sudo apt update
sudo snap install --classic code

安装cmake插件
安装cmake tools插件

mkdir .vscode
cd .vscode
vi setting.json
输入
{
    "cmake.cmakePath":"/home/{你的用户名}/native/build-tools/cmake/bin/cmake"
        "cmake.configureArgs": [
        "-DOHOS_ARCH=armeabi-v7a",
        "-DCMAKE_TOOLCHAIN_FILE=/home/{你的用户名}/native/build/cmake/ohos.toolchain.cmake",
      ]
}
其中的目录使用自己的工具链保存目录
进入工程所在目录
打开控制台
输入code . 打开vscode
在vscode中按下键盘的 ctrl+shift+p
在指令窗口输入cmake
选择quick statrt
根据提示输入工程名称和等设置
点击vscode界面左侧的extensions按钮,找到安装好的CMake Tools,点击右下角的齿轮设置按钮,在下拉菜单中选择settings在弹出的窗口中添加Additional compiler search dirs和Additional kits路径设置为鸿蒙sdk目录下的 native/llvm/bin 这样CMakeTools就可以搜索到sdk的交叉编译联工具了。

在vscode中按下键盘的 ctrl+shift+p 在命令窗口中输入cmake 选择select a kit
如果下面没有native下的交叉编译链就点击第一个多扫描几次。

刚才的CMake插件的quickstatrt已经创建好了cmake文件,在cmake文件中按需修改配置,点击左下角的build按钮即可完成编译

二、openharnony应用调用动态库

1、安装 deveco studio 4.1或5.0,5.0目前编译的时候不能只编译32位版本,不知道为什么,如果编译一个需要在cmake中做条件编译和依赖。比如:

if(OHOS_ARCH STREQUAL armeabi-v7a)
add_library(entry SHARED napi_init.cpp)

else()

add_library(entry SHARED napi_init_64.cpp)

endif()

2、修改 build-profile.json5 文件中的products目录,以下是5.0版本的

"products": [
  {
    "name": "default",
    "signingConfig": "default",
    "compileSdkVersion": 11,
    "compatibleSdkVersion": 11,
    "runtimeOS": "OpenHarmony",
    "buildOption": {
      "externalNativeOptions": {
        "abiFilters": [
          "armeabi-v7a",
          "arm64-v8a"
        ]
      },
      "strictMode": {
        "caseSensitiveCheck": true,
      }
    }
  }
],

3、按官网的教程把so库和头文件放入相应的目录。

4、最后应用打开以后一调用napi可能会闪退,检查日志看是否有依赖的库没有放到目录中,可以使用needed by进行关键字筛选。

5、如果打开应用后界面显示不正常,只有应用图标,检查日志看是否有其他问题。可能需要修改动态库的源码,重新编译动态库。

6、如果涉及到一些硬件操作可能会打不开设备,需要修改设备的操作权限,比如usb设备可以使用下面的指令

chmod -R 777 /dev/bus/usb/

7、添加日志

在cmake文件中添加hilog的依赖库

target_link_libraries(entry PUBLIC libace_napi.z.so  libhilog_ndk.z.so)

在cpp文件中添加头文件

#include "hilog/log.h"

日志函数用法

OH_LOG_Print(LOG_APP,LOG_INFO, LOG_PRINT_DOMAIN,"Init","uvc open fail%{public}d",res);


http://www.kler.cn/a/405386.html

相关文章:

  • node报错:Error: Cannot find module ‘express‘
  • AspectJ 对于 AOP 的实现
  • 【2024亚太杯亚太赛APMCM C题】数学建模竞赛|宠物行业及相关产业的发展分析与策略|建模过程+完整代码论文全解全析
  • 嵌入式面试八股文(九)·FreeRTOS与Linux的区别与相同点、多进程与多线程的区别、为什么项目使用多线程
  • MySQL - 数据库基础 | 数据库操作 | 表操作
  • 笔记记录 k8s-RBAC
  • 科研深度学习:如何精选GPU以优化服务器性能
  • React事件处理机制详解
  • C#-利用反射自动绑定请求标志类和具体执行命令类
  • Parker派克防爆电机在实际应用中的安全性能如何保证?
  • k8s常见问题及解决办法
  • 【python基础巩固】引用、浅深拷贝你分清了吗?
  • 【单元测试】【Android】JUnit 4 和 JUnit 5 的差异记录
  • 私有化部署视频平台EasyCVR宇视设备视频平台如何构建视频联网平台及升级视频转码业务?
  • 前端:HTML (学习笔记)【2】
  • 提升性能测试效率与准确性:深入解析JMeter中的各类定时器
  • jdk各个版本介绍
  • java学习-集合
  • 数据新时代:如何选择现代数据治理平台(上)
  • 数据结构及算法--排序篇
  • 如何能让安全责任更清晰——构建清晰安全责任体系策略与实践
  • 数字IC后端实现时钟树综合系列教程 | Clock Tree,Clock Skew Group之间的区别和联系
  • 【工程记录】vscode+ssh远程配置python环境方法
  • 嵌入式:STM32的启动(Startup)文件解析
  • 生成式AI在教育技术中的应用:变革与创新
  • 开源生态发展合作倡议