Android Studio 使用Gradle 打渠道包

    我们都知道Android Studio使用了Gradle。Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化建构工具。Gradle是一种依赖管理工具,基于Groovy语言,面向Java应用为主,它抛弃了基于XML的各种繁琐配置,取而代之的是一种基于Groovy的内部领域特定(DSL)语言。

   今天我们就来看看如何使用Gradle打渠道包。具体步骤如下所示:

1. 首先在AndroidManifest.xml中写入渠道信息,这里以友盟统计为例。

      <meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VALUE}"/>
2. 打开该Module下的build.gradle文件,配置productFlavors。


   在‘android’中加入如下代码,

 productFlavors {
        wandoujia {
            manifestPlaceholders = [UMENG_CHANNEL_VALUE: "wandoujia"]
        }
		baidu {
            manifestPlaceholders = [UMENG_CHANNEL_VALUE: "baidu"]
        }
        xiaomi {
            manifestPlaceholders = [UMENG_CHANNEL_VALUE: "xiaomi"]
        }
    } 
或者以下代码,

  productFlavors{
        wandoujia{}
        baidu{}
        xiaomi{}
        productFlavors.all{
            flavor->flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
        }
    }
其中的wandoujia{}、 baidu{}... ...这些就是需要的渠道名字,而这里的UMENG_CHANNEL_VALUE就是对于我们在AndroidManifest.xml中配置渠道信息的那个value,加好这些东西之后就构建一下项目:


3. 签名打包。选择Build->Generate Signed APK

填写签名、别名、密码等,点击下一步,就会看到如下截图,


全选Flavors所有选项,然后就Finish。就OK啦,在该module的目录下就可以看到签完名的apk列表。截图如下所示,

PS: 如果你想生成的app应用名称包含时间、版本号以及渠道号,那么还需要增加代码,

apply plugin: 'com.android.application'
//定义 时间
def releaseTime() {
    return new Date().format("yyyy-MM-dd", TimeZone.getTimeZone("UTC"))
}
ext{
//定义app前缀名称
 appName="test1"
}
android {
    compileSdkVersion 23
    buildToolsVersion "23.0.3"

    defaultConfig {
        applicationId "xinxing.test"
        minSdkVersion 14
        targetSdkVersion 23
        versionCode 1
        versionName "1.0.0"
    }

    productFlavors{
        wandoujia{}
        baidu{}
        xiaomi{}

        productFlavors.all{
            flavor->flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
        }
    }

    buildTypes {
        release {
    minifyEnabled false
    proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    applicationVariants.all { variant ->
        variant.outputs.each { output ->
            def outputFile = output.outputFile
            def fileName = "${appName}_${defaultConfig.versionName}_${releaseTime()}_${variant.productFlavors[0].name}.apk"
            output.outputFile = new File(outputFile.parent, fileName)
        }
    }
}

}


}
打包截图如下,

pps: 如果想一次生成不同环境下的安装包(测试环境、生成环境),那么代码修改如下,

apply plugin: 'com.android.application'

def releaseTime() {
    return new Date().format("yyyyMMddHHmm", TimeZone.getTimeZone("GMT+8:00"))
}
ext{
    appName="test"
}
android {
    compileSdkVersion 23
    buildToolsVersion "23.0.3"

    defaultConfig {
        applicationId "xinxing.test"
        minSdkVersion 14
        targetSdkVersion 23
        versionCode 1
        versionName "1.0.0"
    }
// 不同环境下的服务地址
    productFlavors{

        demo {
            manifestPlaceholders = [API_HOST_VALUE            : "http://192.168.1.120:8888/mserver"]
        }
        product {
            manifestPlaceholders = [API_HOST_VALUE            : "http://www.xinxing.cn/mserver" ]
        }
    }

    buildTypes {
        release {
    minifyEnabled false
    proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    applicationVariants.all { variant ->
        variant.outputs.each { output ->
            def outputFile = output.outputFile
            def fileName = "${appName}_${defaultConfig.versionName}_${releaseTime()}_${variant.productFlavors[0].name}.apk"
            output.outputFile = new File(outputFile.parent, fileName)
        }

    }
}

}


}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:23.4.0'
    compile 'com.android.support:design:23.4.0'
}
在AndroidManifest.xml中加入如下代码,

    <!-- api host -->
        <meta-data
            android:name="API_HOST"
            android:value="${API_HOST_VALUE}" />
最后打包的结果如下所示,


使用Gradle打包就是这么快,准,美!偷笑

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值