Android.bp 文件中引入aar、jar、so库正确编译方法(值得收藏)

简介: Android.bp 文件中引入aar、jar、so库正确编译方法(值得收藏)

引入 aar


在模块源码根文件下新建文件夹 libs,复制要引入的 arr文件至此,新建 Android.bp

新增如下语句,这里以 lottie.arr 为例


android_library_import {
    name: "lib-lottie",
    aars: ["lottie-2.8.0.aar"],
    sdk_version: "current",
}


然后在模块目录下 Android.bp 文件中的 android_app {} 中 static_libs 引入 “lib-lottie”,

android_app {
    name: "LiveTv",
    srcs: ["src/**/*.java"],
  static_libs: [
    "lib-lottie",
        "android-support-annotations",
        "android-support-compat",
        "android-support-core-ui",
        "androidx.tvprovider_tvprovider",
        "android-support-v4",
    ....


这样编译就ok了,如果编译报错,


Error: Compilation can’t be completed because some library classes are missing.


Compilation failed


可以尝试将 “lib-lottie”, 移动到 libs: [] 中再次尝试


如果aar中带资源文件,需要将aar解压拷贝资源文件,不然编译时会提示找不到资源,运行时会报错


解压 lottie-2.8.0.aar,在模块源码根文件夹下新建 res-lottie 文件夹,将资源文件拷贝到此目录


模块目录下 Android.bp 文件中的 resource_dirs: [] 引入

android_app {
    name: "LiveTv",
    srcs: ["src/**/*.java"],
  resource_dirs: [
        "res",
        "res_ext",
        "res-lottie",
    ],
  static_libs: [
    "lib-lottie",
        "android-support-annotations",
        "android-support-compat",
        "android-support-core-ui",
        "androidx.tvprovider_tvprovider",
        "android-support-v4",
    ....
  ],
  aaptflags: [
        "--extra-packages",
        "com.airbnb.lottie",
    ],


同时增加 aar 对应的包名 aaptflags,以便生成对应包名 R 文件

aaptflags --extra-packages com.airbnb.lottie, 编译时会生成 com.airbnb.lottie.R

多个aar增按照如上操作配置多个即可


引入 jar


在模块源码根文件下新建文件夹 libs,复制要引入的 jar 包至此,新建 Android.bp

新增如下语句,这里以 opencv.jar 为例


java_import {
    name: "face-opencv-jar",
    jars: ["opencv.jar"],
    sdk_version: "current",
}


然后在模块目录下 Android.bp 文件中的 android_app {} 中 libs 引入 “face-opencv-jar”,


android_app {
    name: "LiveTv",
    libs: [
        "telephony-common",
        "mediatek-framework",
        "ims-common",
    "face-opencv-jar",
    ],



这样编译就ok了, jar包相对简单一些


引入 so


在模块源码根文件下新建文件夹 armeabi,复制要引入的 so 至此,在libs中新建 Android.bp


新增如下语句,这里以 libjniopencv_face.so 为例, arm 和 arm64 分别对应32/64的so库,针对源码环境

位数都是确定的,所以我们就写成一样了

cc_prebuilt_library_shared {
    name: "libjniopencv_face",
    arch: {
        arm: {
            srcs: ["armeabi/libjniopencv_face.so"],
        },
        arm64: {
            srcs: ["armeabi/libjniopencv_face.so"],
        },
    },
}

然后在模块目录下 Android.bp 文件中的 android_app {} 中 jni_libs 引入 “libjniopencv_face”,

android_app {
    name: "LiveTv",
     jni_libs: [
        "libjniopencv_face",
  ]
]

一个完整的包含 aar/jar/so Android.bp

libs


----Android.bp
----lottie-2.8.0.aar
----face-opencv-jar
----armeabi
  -----libjniopencv_face.so
  -----libopencv_text.so


libs/Android.bp

android_library_import {
    name: "lib-lottie",
    aars: ["lottie-2.8.0.aar"],
    sdk_version: "current",
}
java_import {
    name: "face-opencv-jar",
    jars: ["opencv.jar"],
    sdk_version: "current",
}
cc_prebuilt_library_shared {
    name: "libjniopencv_face",
    arch: {
        arm: {
            srcs: ["armeabi/libjniopencv_face.so"],
        },
        arm64: {
            srcs: ["armeabi/libjniopencv_face.so"],
        },
    },
}
cc_prebuilt_library_shared {
    name: "libopencv_text",
    arch: {
        arm: {
            srcs: ["armeabi/libopencv_text.so"],
        },
        arm64: {
            srcs: ["armeabi/libopencv_text.so"],
        },
    },
}


模块根路径Android.bp


android_app {
    name: "LiveTv",
    srcs: ["src/**/*.java"],
    // TODO(b/122608868) turn proguard back on
    optimize: {
        enabled: false,
    },
    // It is required for com.android.providers.tv.permission.ALL_EPG_DATA
    privileged: true,
    sdk_version: "system_current",
    min_sdk_version: "23", // M
    resource_dirs: [
        "res",
        "material_res",
    "res-lottie",
    ],
    libs: [
    "face-opencv-jar",
  ],
    static_libs: [
        "android-support-compat",
        "android-support-core-ui",
        "androidx.tvprovider_tvprovider",
        "android-support-v4",
        "android-support-v7-appcompat",
        "android-support-v7-palette",
        "android-support-v7-preference",
        "android-support-v7-recyclerview",
        "android-support-v14-preference",
        "android-support-v17-leanback",
        "android-support-v17-preference-leanback",
        "lib-lottie",
    ],
   jni_libs: [
        "libjniopencv_face",
    "libopencv_text",
  ]
    javacflags: [
        "-Xlint:deprecation",
        "-Xlint:unchecked",
    ],
    aaptflags: [
        "--version-name",
        version_name,
        "--version-code",
        version_code,
        "--extra-packages",
        "com.android.tv.tuner",
        "--extra-packages",
        "com.airbnb.lottie",
    ],
}



小技巧


一般需要引入的so库都会是几十个,每一个都需要在Android.bp配置对应的 cc_prebuilt_library_shared


挨个复制会很浪费时间,自信观察格式都是固定的,我们可以通过遍历文件夹来生成这个json串

将所有 so 库文件拷贝至 sdcard/Android/armeabi/,遍历读取文件名,按默认格式写入txt文件即可

private void getSoJson() {
        String fileAbsolutePath = Environment.getExternalStorageDirectory().getPath() + "/Android/armeabi/";
        Log.e("eee", "fileAbsolutePath : " + fileAbsolutePath);
        File file = new File(fileAbsolutePath);
        File[] subFile = file.listFiles();
        String json = "";
        String soName = "";
        for (int iFileLength = 0; iFileLength < subFile.length; iFileLength++) {
            if (!subFile[iFileLength].isDirectory()) {
                String filename = subFile[iFileLength].getName();
                String name = filename.split("\\.")[0];
                Log.e("eee", "filename : " + filename + "  name=" + name);
                json += "cc_prebuilt_library_shared {\n" +
                        "    name: \"" + name + "\",\n" +
                        "    arch: {\n" +
                        "        arm: {\n" +
                        "            srcs: [\"armeabi/" + filename + "\"],\n" +
                        "        },\n" +
                        "        arm64: {\n" +
                        "            srcs: [\"armeabi/" + filename + "\"],\n" +
                        "        },\n" +
                        "    },\n" +
                        "}" + "\r\n";
                soName += "\""+name+"\"," + "\r\n";
            }
        }
        Log.e("eee", "soJson =" + json);
        write2File("so.txt", json);
        write2File("libs.txt", soName);
    }
    private void write2File(String fileName, String data) {
        String strFilePath = Environment.getExternalStorageDirectory().getPath() + "/Android/" + fileName;
        String strContent = data + "\r\n";
        try {
            File sfile = new File(strFilePath);
            if (!sfile.exists()) {
                Log.d("TestFile", "Create the file:" + strFilePath);
                sfile.getParentFile().mkdirs();
                sfile.createNewFile();
            }
            RandomAccessFile raf = new RandomAccessFile(sfile, "rwd");
            raf.seek(sfile.length());
            raf.write(strContent.getBytes());
            raf.close();
        } catch (Exception e) {
            Log.e("TestFile", "Error on write File:" + e);
        }
    }

Android.mk语法规范

目录
相关文章
|
3月前
|
Java Android开发 C++
Android Studio JNI 使用模板:c/cpp源文件的集成编译,快速上手
本文提供了一个Android Studio中JNI使用的模板,包括创建C/C++源文件、编辑CMakeLists.txt、编写JNI接口代码、配置build.gradle以及编译生成.so库的详细步骤,以帮助开发者快速上手Android平台的JNI开发和编译过程。
234 1
|
3月前
|
JavaScript 前端开发 Java
[Android][Framework]系统jar包,sdk的制作及引用
[Android][Framework]系统jar包,sdk的制作及引用
82 0
|
21天前
|
缓存 Java Shell
Android 系统缓存扫描与清理方法分析
Android 系统缓存从原理探索到实现。
45 15
Android 系统缓存扫描与清理方法分析
|
29天前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
81 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
1月前
|
编译器 Android开发
配置环境变量,使CMakeLists.txt可直接使用Android NDK工具链编译项目
配置环境变量,使CMakeLists.txt可直接使用Android NDK工具链编译项目
|
1月前
|
Ubuntu Shell API
Ubuntu 64系统编译android arm64-v8a 的openssl静态库libssl.a和libcrypto.a
Ubuntu 64系统编译android arm64-v8a 的openssl静态库libssl.a和libcrypto.a
|
2月前
|
ARouter 测试技术 API
Android经典面试题之组件化原理、优缺点、实现方法?
本文介绍了组件化在Android开发中的应用,详细阐述了其原理、优缺点及实现方式,包括模块化、接口编程、依赖注入、路由机制等内容,并提供了具体代码示例。
45 2
|
3月前
|
开发工具 uml git
AOSP源码下载方法,解决repo sync错误:android-13.0.0_r82
本文分享了下载AOSP源码的方法,包括如何使用repo工具和处理常见的repo sync错误,以及配置Python环境以确保顺利同步特定版本的AOSP代码。
423 0
AOSP源码下载方法,解决repo sync错误:android-13.0.0_r82
|
4月前
|
Java
[JarEditor]可直接修改jar包的IDEA插件
### 修改JAR包变得更简单:JarEditor插件简介 **背景:** 开发中常需修改JAR包中的class文件,传统方法耗时费力。JarEditor插件让你一键编辑JAR包内文件,无需解压。 **插件使用:** 1. **安装:** 在IDEA插件市场搜索JarEditor并安装。 2. **修改class:** 打开JAR文件中的class,直接编辑,保存后一键构建更新JAR。 3. **文件管理:** 右键菜单支持在JAR内新增/删除/重命名文件等操作。 4. **搜索:** 使用内置搜索功能快速定位JAR包内的字符串。
457 2
[JarEditor]可直接修改jar包的IDEA插件
|
4月前
|
弹性计算 Java Serverless
Serverless 应用引擎操作报错合集之上传自定义JAR包,启动时报错,是什么导致的
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。

热门文章

最新文章