中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android Studio多渠道打包的配置方法

發布時間:2020-08-26 09:42:03 來源:腳本之家 閱讀:187 作者:franksight 欄目:移動開發

說到多渠道,這里不得不提一下友盟統計,友盟統計是大家日常開發中常用的渠道統計工具,而我們的打包方法就是基于友盟統計實施的。按照友盟官方文檔說明,渠道信息通常需要在AndroidManifest.xml中配置如下值:

<meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/>

上面的value值Channel_ID就是渠道標識。我們的期望的就是在編譯時候這個值能夠自動變化以滿足區分多渠道的需求。

(一)在AndroidManifest.xml里設置動態渠道變量

<meta-data
  android:name="UMENG_CHANNEL"
  android:value="${UMENG_CHANNEL_VALUE}" />

(二)在build.gradle設置productFlavors

這里假定我們需要打包的渠道為360、小米、百度、豌豆莢

android { 
  productFlavors {
    xiaomi {
      manifestPlaceholders = [UMENG_CHANNEL_VALUE: "xiaomi"]
    }
    qh460 {
      manifestPlaceholders = [UMENG_CHANNEL_VALUE: "qh460"]
    }
    baidu {
      manifestPlaceholders = [UMENG_CHANNEL_VALUE: "baidu"]
    }
    wandoujia {
      manifestPlaceholders = [UMENG_CHANNEL_VALUE: "wandoujia"]
    }
  } 
}

或者批量修改

android { 
  productFlavors {
    xiaomi {}
    qh460 {}
    baidu {}
    wandoujia {}
  } 
  productFlavors.all { 
    flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name] 
  }
}

所謂ProductFlavors其實就是可定義的產品特性,配合 manifest merger 使用的時候就可以達成在一次編譯過程中產生多個具有自己特性配置的版本。上面這個配置的作用就是,為每個渠道包產生不同的 UMENG_CHANNEL_VALUE 的值。

(三)執行打包操作

在AndroidStudio菜單欄點擊Build菜單–>Generate signed APK–>選擇key,并輸入密碼 

Android Studio多渠道打包的配置方法

然后下一步,選擇打包渠道

Android Studio多渠道打包的配置方法

最后點擊完成按鈕,我們已經成功的將五個渠道包打好。

(四)執行打包命令 ./gradlew assembleRelease

除了使用AndroidStudio圖形打包操作以外,我們也可以使用命令行進行打包操作,具體步驟如下:

  • 在AndroidStudio窗口左下角打開Terminal面板,輸入gradlew assembleRelease命令
  • 如果系統中沒有安裝Gradle,則會自動下載完成安裝及初始化
  • 打包成功后控制臺會提示BUILD SUCCESSRUL
  • 在app–>build–>outputs–>apk路徑中就可以看到打包成功后的APK

注意,此時這里的APK包名顯示為unsigned,也就是說未簽名,我們可以繼續在build.gradle文件中配置簽名信息

signingConfigs {
    release{
      storeFile file("../wooyun_keystore") //簽名文件路徑
      storePassword "your password"
      keyAlias "your alias"
      keyPassword "your password" //簽名密碼
    }
  }

然后再次執行gradlew assembleRelease命令

這次生成的就是含有簽名的渠道包。

當我們的渠道包版本比較多時,可以自定義所打APK包名稱,用以區分

// 自定義輸出配置,這里我們加上APK版本號1.0
      applicationVariants.all { variant ->
        variant.outputs.each { output ->
          def outputFile = output.outputFile
          if (outputFile != null && outputFile.name.endsWith('.apk')) {
            // 輸出apk名稱為frank_v1.0_wandoujia.apk
            def fileName = "frank_v${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk"
            output.outputFile = new File(outputFile.parent, fileName)
          }
        }
      }

assemble是Gradle中的編譯打包命令,有如下用法:

如果我們想打包wandoujia渠道的release版本,執行如下命令就好了:

gradlew assembleWandoujiaRelease

如果我們想打包wandoujia渠道的debug版本,執行如下命令就好了:

gradlew assembleWandoujiaDebug

如果我們只打wandoujia渠道版本,則:

gradlew assembleWandoujia

此命令會生成wandoujia渠道的Release和Debug版本

同理我想打全部Release版本:

gradlew assembleRelease

這條命令會把Product Flavor下的所有渠道的Release版本都打出來。

下面是我個人的build.gradle配置文件,分享給大家,以作參考

apply plugin: 'com.android.application'
android {
  compileSdkVersion 23
  buildToolsVersion "23.0.2"
  defaultConfig {
    applicationId "com.frank.example"
    minSdkVersion 15
    targetSdkVersion 23
    versionCode 1
    versionName "1.0"
  }
   //簽名
  signingConfigs {
    debugConfig {
      storeFile file("../frank_keystore")   //簽名文件
      storePassword "your password"
      keyAlias "your alias"
      keyPassword "your password" //簽名密碼
    }
    release{
      storeFile file("../wooyun_keystore")   //簽名文件
      storePassword "your password"
      keyAlias "your alias"
      keyPassword "your password" //簽名密碼
    }
  }
  buildTypes {
    release {
      minifyEnabled false
      proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
      // 自定義輸出配置
      applicationVariants.all { variant ->
        variant.outputs.each { output ->
          def outputFile = output.outputFile
          if (outputFile != null && outputFile.name.endsWith('.apk')) {
            // 輸出apk名稱為frank_v1.0_wandoujia.apk
            def fileName = "frank_v${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk"
            output.outputFile = new File(outputFile.parent, fileName)
          }
        }
      }
    }
  }
  productFlavors {
    xiaomi {}
    qh460 {}
    baidu {}
    wandoujia {}
  }
  productFlavors.all {
    flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
  }
}
dependencies {
  compile fileTree(dir: 'libs', include: ['*.jar'])
  testCompile 'junit:junit:4.12'
  compile 'com.android.support:appcompat-v7:23.3.0'
}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

辛集市| 彭阳县| 汤原县| 吴忠市| 吉木萨尔县| 三明市| 海伦市| 镇雄县| 永修县| 札达县| 岳西县| 麻阳| 利津县| 荔波县| 东平县| 阳城县| 华蓥市| 新闻| 普陀区| 郑州市| 开江县| 宜君县| 萨迦县| 昌黎县| 台北市| 泸西县| 封开县| 石首市| 固镇县| 鄢陵县| 九江市| 连城县| 乌鲁木齐市| 介休市| 宣威市| 铜鼓县| 嘉义市| 安化县| 定兴县| 定安县| 潢川县|