多渠道打包

栏目: 编程工具 · 发布时间: 8年前

内容简介:多渠道打包

Gradle 简单配置多渠道打包。 转载请声明出处

这段时间,公司项目集成了第三方行为分析SDK,并且希望对各个渠道的信息做一些统计,这就必然会设计到多渠道打包。

多渠道打包思路其实也很简单,通过 Gradle 配置修改 Manifest 中 meta-data 的值,这样打包生成的多个包中 meta-data 就可以不一样,在代码中获取到不同的 meta-data 值,由此来区分不同的渠道。

1.配置 Gradle

在项目主工程的 build.gradle 中,添加如下配置:

android {
    productFlavors {
        xiaomi {
            manifestPlaceholders = [CHANNEL_VALUE: "xiaomi"]
        }
        tencent {
            manifestPlaceholders = [CHANNEL_VALUE: "tencent"]
        }
        baidu {
            manifestPlaceholders = [CHANNEL_VALUE: "baidu"]
        }
        ...
}

这里的 CHANNEL_VALUE 是后面 Manifest 中对应的值。如果一个项目要在 meta-data 中配多个参数,每增加一个渠道难免会多写很多行代码,可以参考下面的简便写法:

android {
    productFlavors {
        xiaomi {}
        tencent {}
        baidu {}
        ...
    }  
    productFlavors.all { 
        flavor -> flavor.manifestPlaceholders = [CHANNEL_VALUE: name] 
    }
}

这样写可以直接把 productFlavors 的 name 配到 meta-data 中。

2.配置 Manifest

在 Manifest 的 application 下配置 meta-data ,如下:

<application
        android:name="..."
        android:icon="..."
        android:label="...">

        <meta-data
            android:name="channel_value"
            android:value="${CHANNEL_VALUE}" />

        <activityandroid:name="..."
            android:label="..." />
        ...
</application>

这里的 CHANNEL_VALUE 就会被赋值为上面 gradle 中配的 name(CHANNEL_VALUE: name),而 channel_value 可以在 java 中获取到。

3.获取 meta-data 值

在 java 中可以获取到 meta-data 配置的值,通过这个值,我们就可以区分不同的渠道信息了。

String channelValue = "";
try {
    ApplicationInfo appInfo = getPackageManager().getApplicationInfo(getPackageName(),
            PackageManager.GET_META_DATA);
    channelValue = appInfo.metaData.getString("channel_value");
} catch (PackageManager.NameNotFoundException e) {
    e.printStackTrace();
}

以上所述就是小编给大家介绍的《多渠道打包》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据密集型应用系统设计

数据密集型应用系统设计

Martin Kleppmann / 赵军平、李三平、吕云松、耿煜 / 中国电力出版社 / 2018-9-1 / 128

全书分为三大部分: 第一部分,主要讨论有关增强数据密集型应用系统所需的若干基本原则。首先开篇第1章即瞄准目标:可靠性、可扩展性与可维护性,如何认识这些问题以及如何达成目标。第2章我们比较了多种不同的数据模型和查询语言,讨论各自的适用场景。接下来第3章主要针对存储引擎,即数据库是如何安排磁盘结构从而提高检索效率。第4章转向数据编码(序列化)方面,包括常见模式的演化历程。 第二部分,我们将......一起来看看 《数据密集型应用系统设计》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

URL 编码/解码
URL 编码/解码

URL 编码/解码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具