首页 > 代码库 > Android studio第一次使用配置(三)gradle项目构建
Android studio第一次使用配置(三)gradle项目构建
1、gradle的概念
2、gradle配置jar包。和libs目录导入jar包的差别
3、签名打包:
(1)Studio
(2)命令行
(3)gradle wrapper的原理
4、BuildConfig的使用
5、简介module中build.gradle文件參数含义
一、gradle的概念:
- gradle是一个构建工具
- gradle是以Groovy语言为基础的
- gradle主要面向的是Java语言
打开Android Studio内置的终端,在输入例如以下命令查看gradle版本号:
gradlew -v
假设是第一次执行这个命令,系统会帮我们下载gradle到本地,下载到的路径是:
输入上述命令后,查看到gradle的版本号2.2.1,例如以下图所看到的:
二、通过gradle来导入jar包:
我们在上一篇文章中第二段的第3小节中讲到了通过复制文件到libs目录来导入jar包。这次来讲一下怎么通过gradle来配置jar包。我们还是以谷歌的gjson.jar为例,假设之前已经通过复制文件方式倒入过了。请先自行删掉。
1、通过gradle配置第三方jar包
我们看到,每一个module都有一个build.gradle文件,它事实上是相应module的配置文件。关于build.gradle文件里详细内容的含义,我们将在最后一段进行解说。
我们先来看一下名为app的这个module,它的build.gradle相应的图形界面事实上是以下这个Project Stucture:
上图中。切换到dependencies标签下,例如以下图所看到的:
上图中。点击加入。然后选择"Library dependency"。弹出例如以下界面:
上图中,我们在搜索框中输入“gson”,然后确定。就弹出了箭头处的我们须要的jar包。加入它就可以:
之后我们会发现。app这个module的build.gradle中多了一行代码,表示引入了gson.jar:
事实上。假设你能记得住上方这行代码,直接写出代码来也是能够导入的。
此时,gson这个jar包不再是出如今libs这个目录下了,而是出如今最下方的External Libraries中,例如以下图所看到的:(并且是最新版本号哦)
2、gradle导入jar包的特点:(和libs目录导入jar包的差别)
- gradle导入jar包更方便,一行代码即可搞定。不像后者那样还要自己去官方下载。
- 假设官方将jar包更新了,我们仅仅须要在build.gradle中改一下版本即可了,不用又一次去官网下载。
3、通过gradle导入的jar包是从哪里来的:
须要注意的是:不是全部的jar包都是能够通过gradle来导入的。
那通过gradle导入的jar包是从哪里来的呢?解释例如以下:
我们发现HelloWorld这个project的文件夹下有一个build.gradle文件,打开它:
上图中第17行的"jcenter()"的意思是,全部通过gradle导入的jar包都是从http://bintray.com/bintray/jcenter这个中央仓库上扒下来的。假设你须要的jar包在这个站点上没有。那就无法通过gradle的方式来导入哦。
顺便提一下,上图中第8行的classpath中的gradle 1.1.0是android的一个gradle插件(也是从中央仓库扒下来的)。
而我们自己使用的gradle版本号例如以下图所看到的:
我们自己下载好的gradle的路径例如以下:
三、签名打包的两种方式:
注:给我们自己开发的app签名,就代表着我自己的版权,以后要进行升级。也必需要使用同样的签名才行。签名就代表着自己的身份(即keystore),多个app能够使用同一个签名。
假设不知道签名是啥意思,请自行百度哦。在eclipse中签名的方法是:选中project,邮件选择"export-android-export android application",
1、方式1:通过Android Studio进行签名:
选中app这个module,选择菜单条"Build-Generate signed apk":
弹出例如以下界面:
上图中。假设你是第一次使用签名,就单击红框部分创建一个新的签名;假设你之前有过签名的文件,就选择蓝框部分进行导入就可以。那我就先选择红框部分吧:
上图中,点击"finish"之后,能够看到Android Studio的最下方显示:Gradle正在运行assembleRelease这样一个任务,例如以下图所看到的:
生成签名好的apk之后,会弹出提示:
2、方式2:通过命令行的方式进行签名:
(1)载入Key Store:
我们先删掉上面的通过第一种方式所签名的apk文件。接下来进行另外一种方式来签名,即命令行的方式。
打开Project Stucture图形化界面:
上图中。选中app这个module,然后切换到singning标签栏。紧接着点击加入。然后生成release签名信息。紧接着点击"OK"。接着做例如以下操作:
上图中,切换到Build Types标签,将Signing config选择为"release"。即将刚刚生成的release签名信息配置进去。
操作完毕之后,我们能够看到app这个module的build.gradle文件多出了例如以下红框部分的代码:
然后运行菜单条的"build-clean Project":
(2)生成realease版本号的apk:
紧接着在命令行Terminal输入例如以下命令:(AS已经将命令行Terminal集成到了软件其中)
gradlew assembleRelease
假设执行成功,效果例如以下:
生成的签名好的apk在例如以下位置:
3、为什么要使用gradlew命令而不是gradle命令:
在HelloWorldproject文件夹下有一个gradle文件夹,在gradle/wrapper文件夹下有一个gradle-wrapper.properties文件,打开它:
上图代表着HelloWorld这个project所依赖的gradle的版本号信息。上图的红线表示。假设我们的project中没有gradle,软件会依据这个url去下载gradle。最终知道为啥第一次打开AS时会这么慢了吧?
假设我们运行了gradlew命令,实际上是运行上面的gradle wrapper。然后找到我们已经下载好的gradle 2.2.1。假设如今有非常多个project,可是每一个project的gradle版本号都不一样,我就必需要将每一个版本号的gradle都要配置到环境变量其中,而运行了gradlew命令,就会避免这个麻烦。
四、BuildConfig文件:
BuildConfig是IDE自己主动生成的一个类。在elipse中即存放在gen文件夹下(如R文件)。而在Adroid Studio中,BuildConfig文件存放的位置是:app/build/generated/source/buildconfig/dubug/<packagename>/BuildConfig.java中。
例如以下图所看到的:
五、module中build.gradle文件參数含义:
主要是module的build.gradle,截图例如以下:
01行:apply plugin: ‘com.android.application‘ 表示该module是这个应用程序的module
15行:applicationId "com.smyhvae.helloworld" 应用程序的包名
16、17行:向下兼容的最小版本号、编译版本号。 注:在app/src/main/AndroidManifest.xml中不再出现这个信息了。
23行:需不须要利用24行的proguard文件来混淆代码。
在release状态下。最好改为true。
图文来源:http://www.cnblogs.com/smyhvae/p/4456420.html
Android studio第一次使用配置(三)gradle项目构建