djvulibre集成到应用hap

本库是在RK3568开发板上基于OpenHarmony3.2 Release版本的镜像验证的,如果是从未使用过RK3568,可以先查看润和RK3568开发板标准系统快速上手

开发环境

编译三方库

  • 下载本仓库

    git clone https://gitee.com/openharmony-sig/tpc_c_cplusplus.git --depth=1
    
  • 三方库目录结构

    tpc_c_cplusplus/thirdparty/djvulibre  #三方库djvulibre的目录结构如下
    ├── docs                              #三方库相关文档的文件夹
    ├── HPKBUILD                          #构建脚本
    ├── SHA512SUM                         #三方库校验文件
    ├── djvulibre_oh_pkg.patch            #补丁
    ├── README.OpenSource                 #说明三方库源码的下载地址,版本,license等信息
    ├── README_zh.md   
    
  • 在lycium目录下编译三方库 编译环境的搭建参考准备三方库构建环境

    cd lycium
    ./build.sh djvulibre
    
  • 三方库头文件及生成的库 在lycium目录下会生成usr目录,该目录下存在已编译完成的32位和64位三方库

    djvulibre/arm64-v8a   djvulibre/armeabi-v7a
    
  • 测试三方库

应用中使用三方库

  • 在IDE的cpp目录下新增thirdparty目录,将编译生成的库拷贝到该目录下,如下图所示  thirdparty_install_dir
  • 在最外层(cpp目录下)CMakeLists.txt中添加如下语句
    #将三方库加入工程中
    target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/djvulibre/${OHOS_ARCH}/lib/libdjvulibre.a)   
    #将三方库的头文件加入工程中
    target_include_directories(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/djvulibre/${OHOS_ARCH}/include)
    
    djvulibre_usage

测试三方库

三方库的测试使用原库自带的测试用例来做测试,准备三方库测试环境

  • 将编译生成的c44、djvm可执行文件及测试文件a.pbm、b.pbm准备好,备注:素材在source目录下,最终结果merge.djuv文件可通过windjview 浏览

  • 将准备好的文件推送到开发板,在windows命令行进行如下操作

    hdc_std shell mount -o remount,rw /     #修改系统权限为可读写
    hdc_std file send c44 /data         #将可执行文件推入开发板data目录
    hdc_std file send djvm /data
    hdc_std file send libc++_shared.so /system/lib64 
    hdc_std file send a.pbm /data  #将测试文件推入开发板data目录
    hdc_std file send b.pbm /data
    hdc_std shell               #进入开发板
    chmod 777 c44               #添加权限
    chmod 777 djvm              #添加权限
    ./c44 a.pbm a.djuv
    ./c44 b.pbm b.djuv
    ./djvm -c merge.djuv a.djuv b.djuv
    

 djvulibre_test  djvulibre_test2

参考资料