build.gradle文件介绍

对于以前用Eclipse开发安卓的小伙伴来说,Gradle文件是陌生的。
不同于Eclipse,而Android Studio 是采用Gradle来构建项目的。

先来介绍最外层目录下的build.gradle文件,代码如下:

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.2.2'
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

在repositories闭包中:

jcenter():它是一个代码托管仓库,很多的Android开源项目都会选择将代码托管到jcenter上,声明了这行配置后,我们就可以在项目中轻松使用任何的jcenter上的开源项目了

在repositories闭包中:

classpath 'com.android.tools.build:gradle:2.2.2'声明了一个Gradle插件。gradle:2.2.2为Gradle插件的版本号。

下面来介绍app目录下的build.gradle文件,代码如下:

apply plugin: 'com.android.application'

	android {
	    compileSdkVersion 24
	    buildToolsVersion "24.0.2"
	    defaultConfig {
	        applicationId "com.androidtest"
	        minSdkVersion 15
	        targetSdkVersion 24
	        versionCode 1
	        versionName "1.0"
	    }
	    buildTypes {
	        release {
	            minifyEnabled false
	            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
	        }
	    }
	}

	dependencies {
	    compile fileTree(dir: 'libs', include: ['*.jar'])
	    compile 'com.android.support:appcompat-v7:23.4.0'
	    testCompile 'junit:junit:4.12'
	}

介绍

第一行的apply plugin:代表着应用了一个插件。一般来说有两个值可选。

  1. com.android.application 表示这是一个应用程序模块。
  2. com.android.library 表示是一个库模块。

区别:

com.android.application是代表可以直接运行的,

com.android.library是只能作为代码依附在别的应用程序模块来运行。所以在引入一些Model为自己的应用程序所用时,build.gradle文件的第一行就是apply plugin:com.android.library。

android闭包:

compileSdkVersion:用于指定项目的编译版本。这里24表示使用Android7.0系统的SDK进行编译。

buildToolsVersion:用于指定项目的构建工具的版本。

android闭包中有defaultConfig闭包:

applicationId:用于指定项目的包名,在创建项目的时候已经指定了包名,当要改变整个项目的包名时可以在这里改变。

minSdkVersion:项目最低的兼容版本。15表示兼容到API 15 既是android 4.0.

targetSdkVersion:表示你在该目标版本上已经做过了充分的测试,系统将为你的应用开启一些最新的功能和特性。假如targetSdkVersion 为23或者更高,那么在Android6.0中运行这个应用时会开启新的功能和特性;但是设置成了22的话,只能说明你的应用程序在Android5.1系统上做过了充分的测试,Android6.0的新功能就不会启用了。

注意
在以前eclipse中设置这些都是AndroidManifest.xml文件中设置的。

<uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="18" />

而在Android Studio中,即使在AndroidManifest.xml设置了,依然是不起作用的,运行时只承认build.gradle下的设置。

versionCode:项目的版本号

versionName:项目版本号的版本名。

这两个属性在生成安装文件时用到。

android闭包中有buildTypes闭包:

通常这个闭包中会有两个闭包,一个是debug,一个release。

debug闭包用于生成测试版安装文件的配置,release闭包用于生成正式版安装文件的配置。dubug闭包可以忽略不写。

release闭包中的具体内容:

minifyEnabled:用于是否对项目的代码进行混淆。true代表开启,false代表关闭。

proguardFiles:指定混淆时使用的文件。

proguard-android.txt:在Android SDK 目录下的,里面是所有项目通用的混淆规则。

proguard-rules.pro:是在当前项目根目录下的,里面编写当前项目特有的混淆规则。

dependencies闭包

在这个闭包下可以指定当前项目所有的依赖关系。通常Android Studio 项目中一共有三种依赖方式:本地依赖、库依赖和远程依赖。

本地依赖可以对本地的Jar包或目录添加依赖关系

库依赖可以对项目中的库模块添加依赖关系。

远程依赖则可以对jcenter库上的开源项目添加依赖关系。

在本项目中的第一行 compile fileTree(dir: 'libs', include: ['*.jar'])就是本地依赖声明,他把libs目录下的所以.Jar后缀文件全部添加带项目的构建路径中去。同时也可以只指定一个文件,例如:compile files('libs/picasso-2.4.0.jar')

在本项目中并没有使用到库依赖。库依赖的基本格式为 compile project后面加上依赖库的库名称,例如gallery为库名称,那么compile project(':gallery')就能添加这个库的依赖关系。

在本项目中的第二行 ** compile 'com.android.support:appcompat-v7:23.4.0'**这种声明是远程依赖声明。因为是用远程的库,所以Gradle在构建项目的时候会检查一下本地仓库是否已经缓存了,如果没有就自动联网下载,然后再添加到项目的构建路径中去。

远程依赖时每次都要检查是否有这个缓存,所以使编译变的很慢。可以设置成离线的Gradle模式。

posted @ 2017-01-07 20:36  吃枣的事  阅读(13381)  评论(1编辑  收藏  举报