Gradle實現的兩種簡單的多渠道打包方法
本文原創,轉載請注意在CSDN上的出處:
http://blog.csdn.net/maosidiaoxian/article/details/42000913
目前我掌握的方法有兩種,都非常簡單,用的都是Gradle Android插件里的productFlavors。
以友盟的多渠道打包為例,假設我們需要打包出如下渠道:UMENG, WANDOUJIA, YINGYONGBAO。
第一種方法,是需要創建文件的。
我們在寫完我們的代碼之后,在app/src下面,分別創建和main同級目錄的文件夾umeng, wandoujia, yingyongbao,這三個文件夾里面都各只有一個AndroidManifest.xml文件,文件只需要如下:
<manifest xmlns:android="<meta-data android:name="UMENG_CHANNEL" android:value="UMENG"/> </application>
</manifest></pre>注意,上面的value的值要和你的渠道名所對應。比如wandoujia里面要對應為你豌豆莢上的渠道名(如WANDOUJAI)。
然后在你的build.gradle的android{}節點里面,添加productFlavors節點,代碼如下:
android { // 這里是你的其他配置productFlavors{ umeng{ } wandoujai { } yingyongbao{ } } // 你的其他配置
}</pre>注意這里的flavors的名字要和你的文件夾的名字對應。這樣配置之后,構建的就是多渠道的APK了。
第二種方法,不用創建那些文件,它使用的是Gradle Android插件里的另一個功能,manifestPlaceholders。
在這種方法中,你只需要在AndroidManifest.xml中,對友盟的渠道進行這樣配置:
<meta-data android:name="UMENG_CHANNEL" android:value="${CHANNEL_NAME}" />
然后同樣使用productFlavors,不過這時它的配置是這樣的:
android { // 你的其他配置代碼productFlavors { yingyongbao { manifestPlaceholders = [ CHANNEL_NAME:"YINGYONGBAO"] } umeng { manifestPlaceholders = [ CHANNEL_NAME:"UMENG" ] } wandoujia { manifestPlaceholders = [ CHANNEL_NAME:"WANDOUJIA" ] } } // 你的其他配置代碼
}</pre>
在上面當中,我們也可以指定一個默認的渠道名,如果需要的話。指定默認的值是在defaultConfig節點當中添加如下內容:
manifestPlaceholders = [ CHANNEL_NAME:"Unspecified"]這里的Unspecified換成你實際上的默認的渠道名。使用manifestPlaceholders的這種配置,同樣適用于manifest的其他配置。比如你需要在不同渠道發布的apk里面,指定不同的啟動Activity。比如在豌豆莢里面發布的,啟動的Activity顯示的是豌豆莢首發的界面,應用寶里面啟動的是應用寶首發的界面(哈哈,有點壞),你就可以對你的activity的值使用${activity_name}的方式,然后在productFlavors里面配置這個${activity_name}的值。
本文原創,轉載請注明CSDN博客上的出處:
http://blog.csdn.net/maosidiaoxian/article/details/42000913
或作者:Geek_Soledad