Android studio gradle配置
Gradle 基本概念
首先我們學習幾個gradle 的腳本語法,掌握了這幾個語法,你就能非常簡單的用gradle構建打包android項目了。 首先,我們來看下一個最簡單android build.gradle
。
build.gradle
//設置腳本的運行環境 buildscript { //支持java 依賴庫管理(maven/ivy),用于項目的依賴。 repositories { mavenCentral() } //依賴包的定義。支持maven/ivy,遠程,本地庫,也支持單文件 dependencies { classpath 'com.android.tools.build:gradle:0.4' } } //聲明構建的項目類型,這里當然是android了 apply plugin: 'android' //設置編譯android項目的參數 android { compileSdkVersion 17 buildToolsVersion "17" defaultConfig { minSdkVersion 8 targetSdkVersion 17 } //Android默認配置 sourceSets { main { manifest.srcFile 'AndroidManifest.xml' java.srcDirs = ['src'] resources.srcDirs = ['src'] aidl.srcDirs = ['src'] renderscript.srcDirs = ['src'] res.srcDirs = ['res'] assets.srcDirs = ['assets'] } //測試所在的路徑,這里假設是tests文件夾,沒有可以不寫這一行 instrumentTest.setRoot('tests') } //這個是解決lint報錯的代碼 lintOptions { abortOnError false } / 簽名設置 / signingConfigs { myConfigs { storeFile file("簽名文件地址") keyAlias "..." keyPassword "..." storePassword "..." } } / 混淆設置 / buildTypes { release { signingConfig signingConfigs.myConfigs runProguard true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } / 渠道打包(不同包名) / productFlavors { qqqq { applicationId = '包名' } hhhhh { applicationId='包名' } } } / .so文件的導入 / task copyNativeLibs(type: Copy) { from fileTree(dir: 'libs', include: 'armeabi/*.so') into 'build/lib' }tasks.withType(Compile) { options.encoding = "UTF-8" } tasks.withType(Compile) { compileTask -> compileTask.dependsOn copyNativeLibs } clean.dependsOn 'cleanCopyNativeLibs' tasks.withType(com.android.build.gradle.tasks.PackageApplication) { pkgTask -> pkgTask.jniFolders = [new File(buildDir, 'lib')] } //依賴庫 dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) }</pre>
本地依賴
gradle 作為構建工具,能夠很方便的使用本地jar包,以下為使用的代碼塊。
dependencies { //單文件依賴 compile files('libs/android-support-v4.jar')
//某個文件夾下面全部依賴 compile fileTree(dir: 'libs', include: '*.jar') }android {
}</pre>
遠程依賴
gradle 同時支持maven,ivy,由于ivy我沒用過,所以用maven 作為例子,以下為代碼塊:
repositories { //從中央庫里面獲取依賴 mavenCentral()
//或者使用指定的本地maven 庫 maven{ url "file://F:/githubrepo/releases" }
//或者使用指定的遠程maven庫 maven{ url "遠程庫地址" } }dependencies { //應用格式: packageName:artifactId:version compile 'com.google.android:support-v4:r13'}
android {
}</pre>
android library 依賴
對于項目依賴 android library的話,就不是依賴一個jar,那么簡單了,在這里需要使用gradle mulit project 機制。在過去,android library并沒有一個很好的包管理方式,簡單來說,在gradle出現以前,官方并沒有一種用于管理android library 依賴包的方式,一般我們都是直接下載別人的android library project 源碼進行集成,而對于第三方的android-maven-plugin 用的是apklib 格式。
而現在,官方終于推出一種android library的打包格式,擴展名為
*.aar
。前面提到,目前android gradle插件并不支持本地直接使用*.aar
文件,不過,支持包管理庫的引用方式,下面,我為大家說一下,怎么對android library 發布使用。打包android library
對android library 進行打包直接在library項目下面使用
gradle build
即可,然后,你就會在 build/libs 目錄下看到兩個*.aar
文件,一個debug包用的,一個是release 下用的,看個人需求使用,這里我們用的是release 版本的 .aar 文件。引用腳本跟前面講的依賴庫相似
dependencies { compile(name: 'pulltorefresh', ext: 'aar') }最后,分享個maven庫地址:http://mvnrepository.com/
來自:http://my.oschina.net/u/1471093/blog/341990