全局设置、自定义BuildConfig
2017-04-18 10:59
399 查看
http://www.cnblogs.com/xinmengwuheng/p/5797048.html
如果有很多项目,可以设置全局来统一管理版本号或依赖库,根目录下build.gradle下:
app/build.gradle
可以在根目录下建个config.gradle,然后只需在根目录下build.gradle最顶部加上下面一行代码,然后同步下,意思就是所有的子项目或者所有的modules都可以从这个配置文件里读取内容。
config.gradle
app/build.gradle
实际开发中服务器可能有正式环境和测试环境,gradle可以通过buildConfigField来配置。
buildConfigField 一共有3个参数,第一个是数据类型,和Java的类型是对等的;第二个参数是常量名,这里是API_SERVER_URL;第三个参数就是你要配置的值。[/code]
如图路径下就有个常量API_SERVER_URL,如何在代码取得这个常量值:
一般release发布版本是需要启用混淆的,这样别人反编译之后就很难分析你的代码,而我们自己开发调试的时候是不需要混淆的,所以debug不启用混淆。对release启用混淆的配置如下:
minifyEnabled为true表示启用混淆,proguardFile是混淆使用的配置文件,这里是module根目录下的proguard-rules.pro文件
全局设置
如果有很多项目,可以设置全局来统一管理版本号或依赖库,根目录下build.gradle下:ext { compileSdkVersion = 23 buildToolsVersion = "23.0.2" minSdkVersion = 14 targetSdkVersion = 23 }
app/build.gradle
android { compileSdkVersion rootProject.ext.compileSdkVersion buildToolsVersion rootProject.ext.buildToolsVersion defaultConfig { applicationId "com.example.android" minSdkVersion rootProject.ext.minSdkVersion targetSdkVersion rootProject.ext.targetSdkVersion versionCode 1 versionName "1.0" }
可以在根目录下建个config.gradle,然后只需在根目录下build.gradle最顶部加上下面一行代码,然后同步下,意思就是所有的子项目或者所有的modules都可以从这个配置文件里读取内容。
apply from: "config.gradle"
config.gradle
ext { android = [ compileSdkVersion: 23, buildToolsVersion: "23.0.2", minSdkVersion : 14, targetSdkVersion : 22, ] dependencies = [ appcompatV7': 'com.android.support:appcompat-v7:23.2.1', design : 'com.android.support:design:23.2.1' ] }
app/build.gradle
android { compileSdkVersion rootProject.ext.android.compileSdkVersion buildToolsVersion rootProject.ext.buildToolsVersion defaultConfig { applicationId "com.example.android" minSdkVersion rootProject.ext.android.minSdkVersion targetSdkVersion rootProject.ext.android.targetSdkVersion versionCode 1 versionName "1.0" } ... dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) testCompile 'junit:junit:4.12' compile rootProject.ext.dependencies.appcompatV7 compile rootProject.ext.dependencies.design }
自定义BuildConfig
实际开发中服务器可能有正式环境和测试环境,gradle可以通过buildConfigField来配置。defaultConfig { buildConfigField 'String','API_SERVER_URL','"http://url/"' }
buildConfigField 一共有3个参数,第一个是数据类型,和Java的类型是对等的;第二个参数是常量名,这里是API_SERVER_URL;第三个参数就是你要配置的值。[/code]
如图路径下就有个常量API_SERVER_URL,如何在代码取得这个常量值:
Log.d("wxl", "API_SERVER_URL=" + BuildConfig.API_SERVER_URL);
启用proguard混淆
一般release发布版本是需要启用混淆的,这样别人反编译之后就很难分析你的代码,而我们自己开发调试的时候是不需要混淆的,所以debug不启用混淆。对release启用混淆的配置如下:android { buildTypes { release { minifyEnabled true//是否启动混淆 proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } }
minifyEnabled为true表示启用混淆,proguardFile是混淆使用的配置文件,这里是module根目录下的proguard-rules.pro文件
相关文章推荐
- Gradle for Android(二)全局设置、自定义BuildConfig、混淆
- Gradle全局变量设置、自定义BuildConfig
- Gradle for Android(二)全局设置、自定义BuildConfig
- Gradle for Android(二)全局设置、自定义BuildConfig、混淆
- Gradle for Android(二)全局设置、自定义BuildConfig、混淆
- Gradle for Android(二)全局设置、自定义BuildConfig、混淆
- iOS---自定义返回按钮 (全局设置)
- 为Mac设置几个重要的自定义全局快捷键
- Android自定义属性为应用程序设置全局背景
- Android 中怎么设置全局自定义字体样式
- linux 自定义全局环境变量设置
- recvfrom sendto的解释 多线程编程需要注意的地方 全局变量的设置 自定义消息 大杂烩inet_
- 将自定义组件设置为全局组件
- win2000,xp,2003 如何使用自定义,设置默认纸张
- ASP.Net全局变量的设置和读取方法--非常好的一篇文章!
- 关于自定义设置聚合计算的解决方案
- ASP.Net全局变量的设置和读取方法
- 设置Swing的全局字体(sun jdk)
- 自定义DataGrid分页设置
- ASP.Net全局变量的设置和读取方法