码迷,mamicode.com
首页 > 其他好文 > 详细

Gradle build设置自动log开关

时间:2015-04-22 20:33:19      阅读:109      评论:0      收藏:0      [点我收藏+]

标签:

应用场景

通常情况下我们的apps发布后也就是release模式下log是不显示的,debug模式下是显示log的,但是在特殊情况下我们测试release包的时候需要log的时候,就无法使用BuildConfig.DEBUG来达到要求,因为在release模式下自动设置为false,debug模式下是true,这个时候我们需要自定义可控制的log开关。

Android Studio 对应的BuildConfig.java位置

在Studio中生成的目录: /app/build/generated/source/buildConfig/ 文件下的产品目录里面,找到想要的包名下会自动生成BuildConfig.java文件。我们可以看看下release模式下该文件的内容:

 
/**
 * Automatically generated file. DO NOT MODIFY
 */
package com.leo.kang.cetfour;

public final class BuildConfig {
  public static final boolean DEBUG = false;
  public static final String APPLICATION_ID = "com.leo.demo";
  public static final String BUILD_TYPE = "release";
  public static final String FLAVOR = "baidu";
  public static final int VERSION_CODE = 47;
  public static final String VERSION_NAME = "3.6.1";
  public static final boolean LEO_LOG = false;
}

怎样自定义BuildConfig字段

在我们的build.gradle里面加入如下代码:

buildTypes {
        release {
            // 不显示Log, 在java代码中的调用方式为:BuildConfig.LOG_DEBUG
            buildConfigField "boolean", "LEO_DEBUG", "false"

            minifyEnabled true
            zipAlignEnabled true
            shrinkResources true
            proguardFiles getDefaultProguardFile(‘proguard-android.txt‘), ‘proguard-rules.pro‘

            signingConfig signingConfigs.release
        }

        debug {
            // 显示Log
            buildConfigField "boolean", "LEO_DEBUG", "true"

            versionNameSuffix "-debug"
            minifyEnabled false
            zipAlignEnabled false
            shrinkResources false
            signingConfig signingConfigs.debug
        }
    }

  

语法为:

buildConfigField "boolean", "LEO_DEBUG", "true"

上述语法就定义了一个boolean类型的LEO_DEBUG字段,值为true,之后我们就可以在程序中使用BuildConfig.LEO_DEBUG字段来判断我们所处的api环境。例如:

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);

        CommonUtils.getVersionName(this);

        initViews();

        if(BuildConfig.LEO_DEBUG) {
            Log.i("leo", "MainActivity.onCreate()");
        }
    }

Gradle build设置自动log开关

标签:

原文地址:http://www.cnblogs.com/kangyi/p/4448398.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!