An Android Project with more than one module,the app module(some api developed by jni) depend on an Android Library which has native so.
该项目是一个使用Android Studio创建的,通过gradle编译的,存在多个模块的工程的gradle构建的事例。完整的模拟了第三方SDK,自己SDK以及Demo之前的调用关系以及相关的gradle编译脚本。
该项目重点介绍不同gradle插件版本下的项目的编译脚本怎么编写。提供的多个版本的项目源码完全一致,仅build.gradle有区别。
-
扫码下载APK:
如何修改配置及运行工程,请参考本人博客:终端基于gradle的开源项目运行环境配置指引
由于Google最新的gradle-experimental插件对部分语法有调整,加上最近咨询用标准版怎么搞得人比较多,因此最近对项目内容作了一次调整。具体如下:
Gradle_1_+
:基于Gradle的1.0以上版本实现Gradle_experimental_0_2
:基于Gradle-experimental的0.2版本实现Gradle_experimental_0_6
:基于Gradle-experimental的0.6版本实现
三个个版本的代码内容完全一致,唯一区别就是build.gradle里面的实现。
在项目中存在两个Android Studio的工程
一个普通的Android 工程,他包含java和jni代码,最终打包后对外提供jar包和so。模拟第三方的jar和so提供给GradleTest使用。
GradleTest是核心工程,它里面包含了一个Android Library的模块gradletestlibrary和一个Android Application的模块app。
-
gradletestlibrary
一个Android Library的模块,他引入了第三方的so和jar(MD5工程的编译产出),并对第三方的jar和so做了封装和调用。
-
app
一个Android Application的模块,他引用gradletestlibrary,同时里面包含jni的代码,通过native的方式调用gradletestlibrary提供的方法。
Android-gradle-jni-so
│
├─── build.sh 生成最终产出物的简单构建脚本,直接运行会生成最终的资源、apk和核心文件
│
├─── GradleTest 核心工程,一个存在多个Module的Android工程
│ │
│ ├── app 基于Android Application的模块,引用gradletestlibrary,通过native的方式调用接口。
│ │
│ └── gradletestlibrary 基于Android Library的模块,引入MD5提供的jar和so
│
├─── MD5 普通Android工程,他包含java和jni代码,最终打包后对外提供jar包和so
│
└─── README.md 项目工程介绍
下面用图示简单梳理demo中获取大写md5值的函数调用流程
说实话,这么设计一个工程是有点复杂,但是却存在实实际际的使用场景。上面的工程是自己根据一直以来SDK开发时实际经验总结,下面对该事例中的两个工程以及对应模块做个现实中的身份映射。
首先、这个完整的架构是主要是提供给SDK的开发者或者大型项目存在公共代码库的情况下使用的。如果项目代码很少,确实不用搭建如此复杂的框架。
- MD5 ———— 映射SDK开发者或者项目公共库依赖的第三方库,例如SDK的开发者会用到一些第三方的数据统计、账号登陆SDK等
- GradleTest ———— SDK开发者或者项目的工程
- gradletestlibrary SDK的具体实现,或者公共库的具体实现,最终可能也会以jar、甚至so的方式对外提供
- app 具体的应用工程,可能是SDK的开发者对外提供的配套demo,也可能是具体的开发者的应用工程,这就是一个普通的Android工程。
- 本文档只是重点介绍整个项目的工程架构,对于具体的语法没有做说明,后续会逐步整理增加到博客。
-
目前gradle支持native构建需要使用特定的gradle版本和gradle tools版本以及NDK版本。具体相关说明可以参照Experimental Plugin User Guide中的说明。对于该项目来说,对于每个目录下的完整工程不要修改项目build.gradle中buildscript内对于gradle tools的版本的声明以及根目录gradle下gradle-wrapper.properties中对于gradle版本的说明。也就是说:
-
使用 com.android.tools.build:gradle-experimental:0.2.+ 必须对应 gradle-2.5-all 。使用 com.android.tools.build:gradle-experimental:0.6.+ 必须对应 gradle-2.10-all 。具体以gradle-experimental:0.2和gradle-2.5-all举例如下:
-
build.gradle 代码如下:
buildscript { …… dependencies { classpath "com.android.tools.build:gradle-experimental:0.2.+" } }
-
gradle-wrapper.properties 内容如下:
# Tue Dec 15 16:08:58 CST 2015 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists distributionUrl=http\://services.gradle.org/distributions/gradle-2.5-all.zip
-
当时写这个事例的时候gradle-experimental插件的0.2版本刚出,发现他对一些语法规则做了调整,不兼容Android gradle插件标准版的语法。也是因为这个原因当时写了对应的文档和事例。
前段时间再去看官方关于gradle experimental的介绍的时候惊诧的发现,最新版本的gradle-experimental插件的语法又部分改回了主流版本的语法规则,就悲催的发现这篇文章仅供参考了。因此这几天彻底重新调整了目录,方便后续编译。