Gradle是一種基于Groovy的動態(tài)DSL罐农,而Groovy語言是一種基于jvm的動態(tài)語言。這里只分享實(shí)際開發(fā)中會用到的場景催什,您不需要去學(xué)習(xí)Groovy語言涵亏,知道Java的您是很容易閱讀Groovy語言的。
系列博客涉及的知識點(diǎn)有:Gradle基本配置蒲凶、依賴管理气筋、全局設(shè)置、自定義BuildConfig旋圆、混淆宠默、多渠道打包、配置簽名信息灵巧、單元測試搀矫,是不是迫不及待了啊抹沪,快來學(xué)習(xí)學(xué)習(xí)。
基本配置
新建項(xiàng)目艾君,目錄結(jié)構(gòu)如下:
app/build.gradle
初始化的Gradle配置:
apply plugin: 'com.android.application'
android {
compileSdkVersion 23
buildToolsVersion "23.0.2"
defaultConfig {
applicationId "com.wuxiaolong.gradle4android"
minSdkVersion 15
targetSdkVersion 23
versionCode 1
versionName "1.0"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompat-v7:23.2.1'
compile 'com.android.support:design:23.2.1'
}
apply plugin: ‘com.android.application’采够,表示該module是一個(gè)app module,應(yīng)用了com.android.application插件冰垄,如果是一個(gè)android library蹬癌,那么這里寫apply plugin: ‘com.android.library’
compileSdkVersion:基于哪個(gè)SDK編譯,這里是API LEVEL
buildToolsVersion:基于哪個(gè)構(gòu)建工具版本進(jìn)行構(gòu)建的虹茶。
defaultConfig:默認(rèn)配置逝薪,如果沒有其他的配置覆蓋,就會使用這里的蝴罪。
applicationId:配置包名的
versionCode:版本號
versionName:版本名稱
buildTypes是構(gòu)建類型董济,常用的有release和debug兩種,可以在這里面啟用混淆要门,啟用zipAlign以及配置簽名信息等虏肾。
dependencies:不屬于Android專有的配置了,它定義了該module需要依賴的jar欢搜,aar封豪,jcenter庫信息。
gradle-wrapper.properties
聲明了gradle的目錄與下載路徑以及當(dāng)前項(xiàng)目使用的gradle版本炒瘟,這些默認(rèn)的路徑我們一般不會更改的
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-2.8-all.zip
根目錄的build.gradle
定義在這個(gè)工程下的所有模塊的公共屬性
buildscript {
repositories {
jcenter()//使用jcenter庫
}
dependencies {
classpath 'com.android.tools.build:gradle:1.5.0'// 依賴android提供的1.5.0的gradle build
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
//為所有的工程的repositories配置為jcenters
allprojects {
repositories {
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
setting.gradle
包含哪些模塊吹埠,比如有app和library:
include ':app',':library'
依賴管理
本地依賴
jar
默認(rèn)情況下,新建的Android項(xiàng)目會有一個(gè)lib文件夾
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])//即添加所有在libs文件夾中的jar
//compile files('libs/WuXiaolong.jar')//不需要這樣一個(gè)個(gè)去寫了
}
so包
用c或者c++寫的library會被叫做so包疮装,Android插件默認(rèn)情況下支持native包缘琅,你需要把.so文件放在對應(yīng)的文件夾中
app
├── AndroidManifest.xml
└── jniLibs
├── armeabi
? ? │ └── WuXiaolong.so
├── armeabi-v7a
? ? │ └── WuXiaolong.so
├── mips
? ? │ └── WuXiaolong.so
└── x86
? ? │?└── WuXiaolong.so
aar文件
library庫輸出文件是.aar文件,包含了Android 資源文件廓推,在library工程build/output/aar/下
直接依賴library庫
dependencies {
compile project(':library名字')
compile project(':libraries:library名字')//多個(gè)library刷袍,libraries是文件夾名字
}
依賴.aar文件
創(chuàng)建一個(gè)aars文件夾,然后把.aar文件拷貝到該文件夾里面樊展,然后添加該文件夾作為依賴庫:app/bulid.gradle
repositories {
flatDir {
dirs 'aars'
}
}
dependencies {
compile(name:'libraryname', ext:'aar')
}
注意:如果你的library依賴了第三方庫做个,須app再次依賴。
遠(yuǎn)程倉庫
dependencies {
compile 'com.wuxiaolong.pullloadmorerecyclerview:library:1.0.4'
}