Android:通过build gradle中的buildTypes设置自动log开关(一)

应用场景

通常情况下我们的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模式下该文件的内容:

 
1
2
3
4
5
6
7
8
9
10
11
12
/**
  * 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" ;
1
public  static  final  boolean  LOG_DEBUG = true ;
1
}

怎样自定义BuildConfig字段

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
buildTypes {
         release {
             // 不显示Log, 在java代码中的调用方式为:BuildConfig.LOG_DEBUG
             buildConfigField  "boolean" "LOG_DEBUG" "false"
 
             minifyEnabled  true
             zipAlignEnabled  true
             shrinkResources  true
             proguardFiles getDefaultProguardFile( 'proguard-android.txt' ),  'proguard-rules.pro'
 
             signingConfig signingConfigs.release
         }
 
         debug {
             // 显示Log
             buildConfigField  "boolean" "LOG_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环境。例如:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
@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()" );
         }
     }

你可能感兴趣的:(Android:通过build gradle中的buildTypes设置自动log开关(一))