首先咱們學習幾個gradle 的腳本語法,掌握了這幾個語法,你就能很是簡單的用gradle構建打包android項目了。 首先,咱們來看下一個最簡單android build.gradle
。java
build.gradleandroid
//設置腳本的運行環境 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']) }
gradle 做爲構建工具,可以很方便的使用本地jar包,如下爲使用的代碼塊。git
dependencies { //單文件依賴 compile files('libs/android-support-v4.jar') //某個文件夾下面所有依賴 compile fileTree(dir: 'libs', include: '*.jar') } android { }
gradle 同時支持maven,ivy,因爲ivy我沒用過,因此用maven 做爲例子,如下爲代碼塊:github
repositories { //從中央庫裏面獲取依賴 mavenCentral() //或者使用指定的本地maven 庫 maven{ url "file://F:/githubrepo/releases" } //或者使用指定的遠程maven庫 maven{ url "遠程庫地址" } } dependencies { //應用格式: packageName:artifactId:version compile 'com.google.android:support-v4:r13'} android { }
對於項目依賴 android library的話,就不是依賴一個jar,那麼簡單了,在這裏須要使用gradle mulit project 機制。在過去,android library並無一個很好的包管理方式,簡單來講,在gradle出現之前,官方並無一種用於管理android library 依賴包的方式,通常咱們都是直接下載別人的android library project 源碼進行集成,而對於第三方的android-maven-plugin 用的是apklib 格式。app
而如今,官方終於推出一種android library的打包格式,擴展名爲*.aar
。前面提到,目前android gradle插件並不支持本地直接使用*.aar
文件,不過,支持包管理庫的引用方式,下面,我爲你們說一下,怎麼對android library 發佈使用。maven
打包android library工具
對android library 進行打包直接在library項目下面使用gradle build
便可,而後,你就會在 build/libs 目錄下看到兩個*.aar
文件,一個debug包用的,一個是release 下用的,看我的需求使用,這裏咱們用的是release 版本的 .aar 文件。學習
引用腳本跟前面講的依賴庫類似測試
dependencies { compile(name: 'pulltorefresh', ext: 'aar') }
最後,分享個maven庫地址:http://mvnrepository.com/和gradle版本地址:http://tools.android.com/tech-docs/new-build-systemgradle
另外,gradle文件配置部分更新:http://my.oschina.net/u/1471093/blog/354442
在此添加,最新grad了配置地址爲:http://my.oschina.net/u/1471093/blog/539075