epeg集成到应用hap

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

开发环境

编译三方库

  • 下载本仓库

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

    tpc_c_cplusplus/thirdparty/epeg       #三方库epeg的目录结构如下
    ├── docs                              #三方库相关文档的文件夹
    ├── test                              #测试图片
    ├── HPKBUILD                          #构建脚本
    ├── HPKCHECK                          #测试脚本
    ├── OAT.xml                           #扫描结果文件
    ├── SHA512SUM                         #三方库校验文件
    ├── README.OpenSource                 #说明三方库源码的下载地址,版本,license等信息
    ├── README_zh.md                      #三方库简介
    
  • 在lycium目录下编译三方库 编译环境的搭建参考准备三方库构建环境

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

    epeg/arm64-v8a      epeg/armeabi-v7a
    jpeg/arm64-v8a      jpeg/armeabi-v7a
    libexif/arm64-v8a   libexif/armeabi-v7a
    
  • 测试三方库

应用中使用三方库

  • 在IDE的cpp目录下新增thirdparty目录,将三方库及其依赖库编译生成的头文件拷贝到该目录下

     epeg_install

  • 在最外层(cpp目录下)CMakeLists.txt中添加如下语句:

    #将三方库头文件和库文件加入工程中
    target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/epeg/${OHOS_ARCH}/lib/libepeg.a)
    target_include_directories(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/epeg/${OHOS_ARCH}/include)
    #将三方库依赖库的头文件和库文件加入工程中
    target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/jpeg/${OHOS_ARCH}/lib/libjpeg.a)
    target_link_libraries(entry PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/libexif/${OHOS_ARCH}/lib/libexif.a)
    

测试三方库

  • 编译出可执行的文件进行测试,准备三方库测试环境

  • 进入到构建目录执行测试用例(注意arm64-v8a-build为构建64位的目录,armeabi-v7a-build为构建32位的目录)

    cd data/thirdparty/epeg/epeg-0.9.3/$ARCH-build
    ./epeg -m 180 ../../test/input.jpg ../../test/thumb.jpg
    
  • 测试结果如图所示:

     epeg_tests

参考资料