No1:
Build Variant = Build Type + Product Flavor
Build Variant:构建的产物
Build Type:构建的类型
Product Flavor:构建的渠道
android{ compileSdkVersion 23 buildToolsVersion "23.0.1" productFlavors{ google{} baidu{} } }
No2:
Flurry多渠道和友盟多渠道构建
Flurry本身没有渠道的概念,它有Application,所以可以把一个Application当成一个渠道,每个Application都有一个Key,称为Flurry Key;友盟本身有渠道的概念,只要我们在AndroidManifest.xml配置标注即可。
android{ compileSdkVersion 23 buildToolsVersion "23.0.1" defaultConfig{ applicationId "org.flysnow.app.example112" minSdkVersion 14 targetSdkVersion 23 versionCode 1 versionName '1.0.0' resConfig 'zh' } buildTypes{ release{ minifyEnabled true projuardFiles getDefaultProguardFile('proguard-android.txt'),'proguard-rules.pro' zipAlignEnabled true } } productFlavors{ google{ buildConfigField 'String','FLURRY_KEY','"BHJKOUASDASFKLZL"' } baidu{ buildConfigField 'String','FLURRY_KEY','"HJSDKHFJDSF23478"' } } }
这样每个渠道的BuildConfig类中都会有名字为FLURRY_KEY常量定义
友盟渠道是在AndroidManifest.xml中配置的
<meta-data android :value="Channel ID" android:name="UMENG_CHANNEL"/>
其中Channel ID就是渠道值
No3:
多渠道构建定制--其实就是对Android Gradle插件的ProductFlavor的配置,通过配置ProductFlavor达到灵活地控制每个渠道的目的
applicationId就是该渠道的包名
android{ ... productFlavors{ google{ applicationId "org.flysnow.app.example112.google" } } }
consumerProguardFiles--只对Android库项目有用
android{ productFlavors{ google{ consumerProguardFiles 'proguard-rules.pro','proguard-android.txt' } } }
testApplicationId--测试包名
android{ ... productFlavors{ google{ testApplicationId "org.flysnow.app.example112.test" } } }
testFunctionalTest--是否为功能测试,testHandleProfiling--是否启用分析功能
android{ productFlavors{ google{ testFunctionalTest true testHandleProfiling true } } }
testInstrumentationRunner--用来配置运行测试使用的Instrumentation Runner的类名
android{ productFlavors{ google{ testInstrumentationRunner 'android.test.InstrumentationTestRunner' } } }
testInstrumentationRunnerArguments--用来配置Instrumentation Runner使用的参数
android{ productFlavors{ google{ testInstrumentationRunnerArguments.put("coverage",'true') } } }
useJack--用于标记是否启用Jack和Jill这个全新的、高性能的编译器
android{ productFlavors{ google{ useJact true } } }
dimension --多维度,理解为对ProdcutFlavor进行分组。用flavorDimensions声明维度,才能在ProductFlavor中使用
android{ flavorDimensions "abi","version"//优先级:abi>version>defaultConfig productFlavors{ free{ dimension 'version' } paid{ dimension 'version' } x86{ dimension 'abi' } arm{ dimension 'abi' } } }
会生成
ArmFreeDebug
ArmFreeRelease
ArmPaidDebug
ArmPaidRelease
x86FreeDebug
x86FreeRelease
x86PaidDebug
x86PaidRelease
No4:
提高多渠道构建的效率-美团方案
1)利用Android Gradle打一个基本包
2)基于该包复制一个,文件名要能区分出产品、打包时间、版本、渠道等
3)对复制出来的apk文件进行修改,在其META-INF目录下新增空文件,但是空文件的文件名要有意义,必须包含能区分渠道的名字,如:mtchannel_google
4)重复步骤2)步骤3生成我们所需的所有渠道包apk,这个可以使用Python这类脚本来做
5)生成了我们所有发布渠道的apk包
使用:
在apk启动(Application onCreate)时候,读取我们写apk中META-INF目录下的前缀mtchannel_文件,如果找到的话,把文件名取出来,然后就可以得到渠道标识(Google)了