后面的系列博客,我将会写一写自己这段时间对于android的学习、认识、体会,希望能够与大家分享。
相信大家从ADT开发切换到android studio最大、最直观的变化就是gradle,因为在android studio里面是利用gradle去构建整个项目的。那么gradle到底是什么东西呢?为什么google官方提供的开发工具android studio里面要集成gradle呢?优势在哪呢?
gradle是一种构建工具,它抛弃了传统的基于xml构建脚本,而是采用基于Groovy的内部领域特定语言。说到这里你也许就会想知道什么是Groovy了吧?其实我自己对Groovy的认识也不是太深,只能简单的说你可以认为它是下一代的java语言,你可以认为它是现在的jvm,所以与java集成度是非常高的。那么下面就让我们来看看基于Groovy构建的gradle语法到底是什么样的?
当我们用android studio新建一个android项目之后,我们可以直观的看到现在的项目结构相比于ADT变化还是挺大的。在该项目结构下面我们同样能够找到java/res文件夹,看名字相信你也应该猜到该文件夹下面到底是放什么文件的。但是有变化的就是AndroidManifest.xml文件的放置位置,以及最下面多出来的build.gradle文件。当我们打开build.gradle文件的时候,会发现里面的语法格式类似于json数据。下面我们可以截取片段代码看一看:
buildscript {
//支持java依赖库管理
repositories {
mavenCentral()
}
dependencies {
classpath 'com.android.tools.build:gradle:1.2.3'
}
}
//项目构建的类型
apply plugin: 'com.android.application'
dependencies {
compile fileTree(include: '*.jar', dir: 'libs')
compile 'com.android.support:recyclerview-v7:22.2.0'
compile 'com.android.support:support-v4:22.2.0'
}
android {
compileSdkVersion 19
buildToolsVersion "22.0.1"
defaultConfig {
applicationId "com.gumpcome"
minSdkVersion 18
targetSdkVersion 19
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_7
targetCompatibility JavaVersion.VERSION_1_7
}
}
buildTypes {
debug {
buildConfigField "Boolean", "DEBUG_MODE", "true"
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
}
release {
buildConfigField "Boolean", "DEBUG_MODE", "false"
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
}
debug {
minifyEnabled true
}
}
sourceSets {
main {
manifest.srcFile 'AndroidManifest.xml'
java.srcDirs = ['src']
resources.srcDirs = ['src']
aidl.srcDirs = ['src']
renderscript.srcDirs = ['src']
res.srcDirs = ['res']
assets.srcDirs = ['assets']
jniLibs.srcDirs = ['libs']
}
// Move the tests to tests/java, tests/res, etc...
instrumentTest.setRoot('tests')
// Move the build types to build-types/<type>
// For instance, build-types/debug/java, build-types/debug/AndroidManifest.xml, ...
// This moves them out of them default location under src/<type>/... which would
// conflict with src/ being used by the main source set.
// Adding new build types or product flavors should be accompanied
// by a similar customization.
debug.setRoot('build-types/debug')
release.setRoot('build-types/release')
}
}
相信如果你之前没有接触过该语法的话,初看起来还真的不知道它到底讲的是什么东西,下面就让我们拆开来分析一下。
首先第一个标签buildscript就是指明该文件的gradle脚本开始,然后在里面我们能够看看repositories和dependencies两个子标签,在第一个子标签里面我们可以看到mavenCentral()。如果我们之前接触过
buildscript {
//支持java依赖库管理
repositories {
mavenCentral()
}
dependencies {
classpath 'com.android.tools.build:gradle:1.2.3'
}
}
maven相信大家就会对该标签不陌生了,它的主要目的就是基于maven构建项目,这样的话我们就可以很方便的管理我们项目依赖的jar包。那么说到这里,你也许会问我们项目里面具体依赖的jar在哪里可以看出来呢?在下面的代码里面,我们可以看到以下代码:
dependencies {
compile fileTree(include: '*.jar', dir: 'libs')
compile 'com.android.support:recyclerview-v7:22.2.0'
compile 'com.android.support:support-v4:22.2.0'
}
dependencies标签就是起到指明依赖jar的作用。
然后我们看一下后面的一段代码,在这句代码里面就是直接指明当前的应用插件就是android app。
apply plugin: 'com.android.application'
最后在android这个标签里面,我们就可以设置android相关的具体属性信息,其中如下代码:
compileSdkVersion 19
buildToolsVersion "22.0.1"
defaultConfig {
applicationId "com.gumpcome"
minSdkVersion 18
targetSdkVersion 19
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_7
targetCompatibility JavaVersion.VERSION_1_7
}
}
我们可以看到sdk/buildTool/id等相关app基本属性设置。在buildTypes标签下面,我们就可以分类指定当前build的类型,比如我们可以在命令行里面通过:gradle assembleDebug/gradle assembleRelease分别编译debug/release版本。在sourceSets标签里面,我们就可以设置具体的代码信息。
这次分享有点贴代码之嫌,如果有什么不对的地方欢迎拍砖。