先认认项目主要文件作用
- 项目最外层
build.gradle
(gradle版本修改,配置公共配置的地方)
// Top-level build file where you can add configuration
// options common to all sub-projects/modules.
// 添加公共配置作用于所有子module的地方
buildscript {
repositories {
jcenter()
}
dependencies {
// gradle改版本的地方,有时候从github导下来的项目没法编译运行起来
// 缺少某个方法,很大概率就是gradle版本的问题,修改下版本号,就能跑起来
classpath 'com.android.tools.build:gradle:2.2.3'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
// 声明仓库的源,之前版本则是mavenCentral()
// jcenter() 兼容以前的mavenCentral(),性能更优
jcenter()
}
}
settings.gradle
(整个Project包含的module, 一般情况下我们用Android Studio创建工程会包含一个主module,也就是如下的app
)
include ':app'
当我们想引入其他module时会这么写( 这里用:
代表路径分隔符,类似util,view就和app不同等级,都放在modules目录里,modules和app同级):
include ':app', ':common', ':glide', ':net', ':protobuf', ':wa',
':modules:util', ':modules:view'
gradle.properties
主要添加编译过程中需要定制的参数,还能配置编译运行的内存等
// 在gradle.properties配置
paramConfig1=true
// 在主modules的build.gradle里这么取
if (project.hasProperty("paramConfig1")) {
config_paramConfig1= new Boolean("${paramConfig1}")
}
其他不改动项:
gradlew.bat
window运营脚本
gradlew
unix运行脚本
- 主module app文件夹里
这里又有一个build.gradle
,这个build.gradle
是作用于主module app,一般也是整个项目最主要的gradle配置文件(多module情况下,每个module都会有个对应的build.gradle
,最外层路径的build.gradle
是作用于所有module的)
// 新gradle写法,以前是apply plugin: ‘android’
// 特殊指出如果项目为类似以前 Android Library
// 要改为apply plugin: ‘com.android.library’
apply plugin: 'com.android.application'
android {
// apk的使用的编译版本及编译工具的版本
// 有时某个网上下载的项目运行找不到api方法,可以尝试修改这里
compileSdkVersion 23
buildToolsVersion "24.0.0"
// app包名,版本号版本名都迁移到此处,不在放于AndroidManifest.xml
defaultConfig {
applicationId "com.example.money.a360floatwindowdemo"
minSdkVersion 15
targetSdkVersion 23
versionCode 1
versionName "1.0"
}
// java版本
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_7
targetCompatibility JavaVersion.VERSION_1_7
}
// 打包debug,release,beta等环境,签名,多渠道打包等
// 修改编译类型,一般情况下只有release和debug
// 真正实战项目会有很多个类型,这些类型会出现在Build Variant里,编译的时候可以切换选择
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
beta {
// 是否混淆,新写法,以前是runProguard
minifyEnabled false
// 混淆文件proguard-android.txt,系统默认,在**/tools/proguard/proguard-android.txt**
//proguard-rules.pro我们项目里的,名称扩展名改变不关紧要
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
// 移除lint检查的error
lintOptions {
abortOnError false
}
}
dependencies {
// 编译libs目录下的所有jar包
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
// 引入jcenter里提供的线上库,项目构建会下载,展开External Libraries可见
// 现在github项目支持被线上引入,
compile 'com.android.support:appcompat-v7:23.4.0'
// 类似eclipse依赖本地类型Android Library
// 对应settings.gradle里的include的
compile project(':modules:view')
}
- gradle/wrapper文件夹里
gradle-wrapper.properties
声明了gradle的目录与下载路径以及当前项目使用的gradle版本,这些默认的路径我们一般不会更改的,这个文件里指明的gradle版本不对也是很多导包不成功的原因之一
#Mon Dec 28 10:00:20 PST 2015
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-2.10-all.zip