Gradle系列之Android Gradle插件

Android Gradle 插件分类
Android 插件的分类是根据 Android 工程的属性进行分类的,Android 工程分为三类,具体如下:

App 应用工程:可生成可运行的 apk ;
Library 库工程:可生成 aar 共其他 App 应用工程使用,使用方式和 jar 一样,里面有相关的 Android 资源文件
Test 测试工程:用于 App 应用过程或 Library 工程进行测试。
对应的就有三种不同的 Android Gradle 插件,三类插件分别是 App 插件、Library 插件和 Test 插件,其插件 id 如下:

//App插件id
com.android.application
//Library插件id
com.android.library
//Test插件
com.android.test
使用最多的肯定就是 App 插件和 Library 插件,使用这几个插件在 Android Studio 中就可以构建 Android 工程了。

使用 Android Gradle 插件
Gradle 插件使用时以插件的 id 作为唯一标识,如果是第三方的插件,还必须在 buildscript{} 中指定其 classpath,Android Gradle 插件就属于第三方插件,使用时要指定其 classpath,Android Gradle 插件托管到 jcenter 上,所以使用时要指定对应仓库,具体参考如下:

buildscript {
//配置插件仓库
repositories {
google()
jcenter()
}
//配置依赖
dependencies {
classpath ‘com.android.tools.build:gradle:3.0.1’
}
}
配置好第三方插件的仓库和依赖,然后使用 apply 使用该插件,具体如下:

//使用App插件
apply plugin: ‘com.android.application’

android {
//编译所依赖的Android SDK的版本
compileSdkVersion 26
//构建工具的版本
buildToolsVersion ‘26.0.2’
//…
}

dependencies {
//…
}
在 Android 开发中一般将插件的仓库和依赖配置到根项目下的 build.gradle 文件中,其子 Module 项目将不需要在配置了,可直接使用,这里仅仅是 App 插件的使用,当然 Libray 插件的使用和 Test 插件的使用也是一样,使用时指定对应的 plugin id 即可。

Android Gradle 工程目录
下面是 Android Studio 创建 Android 工程的 Module 的目录,这也是 Android 工程的基本目录结构,参考如下:

app
├─libs
├─proguard-rules.pro
├─build.gradle
└─src
├─androidTest
│ └─java

├─main
│ ├─AndroidManifest.xml
│ ├─java
│ └─res

└─test
└─java
上述目录中 src 下面的 main、androidTest、test 是三个 SourceSet,main 表示 App 的源代码及资源目录,android 和 test 表示 Android 相关测试代码目录,此外 proguard-rules.pro 是当前项目的混淆文件,libs 用于存放 jar、aar 等库文件,build。gradle 文件用于当前配置文件。

Android Gradle 基本配置
为了介绍 Android Gradle 插件基本配置,使用 Android Studio 创建一个 Android 项目,下面的 app 的一个配置文件,具体如下:

//使用Android Gradle插件
apply plugin: ‘com.android.application’
//android{}是Android工程配置的入口
android {
/**
* 指定编译依赖的Android SDK的版本,同
* compileSdkVersion android-26
* android.compileSdkVersion = 26
* android.compileSdkVersion = ‘android-26’
/
compileSdkVersion 26
//指定构建工具的版本,也可以使用属性值buildToolsVersion设置其版本
buildToolsVersion ‘26.0.2’
/
*
* 默认配置,defaultConfig是一个ProductFlavor,可根据不同需求生成不同的Apk
* 如果不自定义ProductFlavor进行单独配置,则该productFlavor会采用默认配置生成Apk
* 这些具体配置,如applicationID都是ProductFlavor的属性
/
defaultConfig {
//配置唯一包名
applicationId “com.manu.androidgradleplugin”
//最低支持的Android系统版本
minSdkVersion 19
//配置应用的目标Android系统版本
targetSdkVersion 26
//用于控制应用升级的版本号
versionCode 1
//用户看到的版本名称
versionName “1.0”
//测试时用到
testInstrumentationRunner “android.support.test.runner.AndroidJUnitRunner”
}
/
*
* buildTypes是一个NamedDomainObjectContainer类型,是一个域对象,类似SourceSet(源集)
* buildTypes中可自定义需要构建的类型,Gradle会自动创建一个相应的BuildType,如默认的release、debug
/
buildTypes {
release {
//设置是否为构建类型启用混淆
minifyEnabled false
//如果启用混淆则使用相应的混淆文件
proguardFiles getDefaultProguardFile(‘proguard-android.txt’), ‘proguard-rules.pro’
}
}
productFlavors {
}
}
//依赖配置
dependencies {
implementation fileTree(include: [’
.jar’], dir: ‘libs’)
implementation ‘com.android.support:appcompat-v7:26.1.0’
implementation ‘com.android.support.constraint:constraint-layout:1.1.2’
testImplementation ‘junit:junit:4.12’
androidTestImplementation ‘com.android.support.test🏃1.0.2’
androidTestImplementation ‘com.android.support.test.espresso:espresso-core:3.0.2’
implementation files(‘libs/plugin.jar’)
}

上述配置文件中已经标注了一些 Android Gradle 插件需要配置的地方,也算是对 Android Gradle 插件及项目配置文件 build.gradle 的一次理解与学习,关于 Android Gradle 插件的基本配置就到此为止,以后陆续补充。
龙华大道1号http://www.kinghill.cn/LongHuaDaDao1Hao/index.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值