Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Android App Bundle:动态功能模块

Android App Bundle:动态功能模块

作者头像
BennuCTech
发布于 2021-12-10 06:44:27
发布于 2021-12-10 06:44:27
2.3K01
代码可运行
举报
文章被收录于专栏:BennuCTechBennuCTech
运行总次数:1
代码可运行

自 2021 年 8 月起,Google Play 将开始要求新应用使用 Android App Bundle 进行发布。该格式将取代 APK 作为标准发布格式。虽然这个政策目前还无法影响到国内应用,但是作为Android开发者,对于新的动态还是要有一定的认识。本文并不是介绍Android App Bundle,因为它不是新的事物,相关的文章也有很多了,本文重点介绍的是Android App Bundle中“动态功能模块”的实际应用。

Android App Bundle

Android App Bundle是基于google play的分发技术,可以有效的减少apk的大小。

Android App Bundle可以自动将不同的分辨率、语言、平台(CPU)的资源分别打包,这样当安装时只根据当前设备安装对应的资源,这样大大的节省了内存空间。

除了这些资源,Android App Bundle还支持动态功能模块(Dynamic Feature Module),这样如果用户不需要这部分功能,则不安装这个模块,这样就更加高度优化了下载和安装。

创建动态功能模块

下面就来看看如何创建动态功能模块:

1、从菜单栏中依次选择 File > New > New Module。这一步与创建普通模块一样。

2、在 Create New Module 对话框中,选择 Dynamic Feature Module,然后点击 Next。

3、在 Configure your new module 部分中,完成以下操作:

  • 从下拉菜单中选择应用项目的 Base application module。(一般就是main主模块)
  • 指定 Module name。IDE 会使用此名称在 Gradle 设置文件中将该模块标识为 Gradle 子项目。当您构建 app bundle 时,Gradle 会使用子项目名称的最后一个元素在功能模块的清单中注入 <manifest split> 属性。
  • 指定该模块的 package name。默认情况下,Android Studio 会建议一个软件包名称,该名称由基本模块的根目录软件包名称和您在上一步中指定的模块名称组合而成。
  • 选择您希望该模块支持的 Minimum API level。此值应与基本模块的值一致。
  • 点击 Next。

4、在 Module Download Options 部分中,完成以下操作:

1)指定最多包含 50 个字符的 Module title。(这个会展示给用户)

2)在 Install-time inclusion 下的下拉菜单中,选择分发时机,有下面三种:

  • Include module at install-time 安装时分发(与普通模块类似)
  • Do not include module at install-time 按需分发(安装时不分发,后面单独说)
  • Only include module at app install for devices with specified features 按条件分发

按条件分发还需要配置条件,如下图

点击“+ device-feature”可以添加一个条件(可以添加多个条件)。在 每个device-feature 旁边,从下拉菜单中选择以下选项之一,然后为其指定值:

  • Name:用于指定设备为在安装应用时下载模块所需具备的硬件或软件功能。按条件分发所支持的功能与被 PackageManager 列为 FEATURE_* 常量的功能相同。如果您选择此选项,请先在下拉菜单旁边的字段中输入相应功能的常量值的任意部分(例如“bluetooth”),然后在所显示的建议中选择一个。
  • OpenGL ES Version:用于指定设备为在安装应用时下载模块所需的 OpenGL ES 版本。如果您选择此选项,请先在下拉菜单旁边的字段中输入相应版本(例如“0x00030001”),然后在所显示的建议中选择一个。

3)如果您希望此模块可提供给搭载 Android 4.4(API 级别 20)及更低版本的设备并包含在多 APK 中,请选中 Fusing 旁边的复选框。这意味着,您可以从不支持下载和安装拆分 APK 的设备上将其省略。

(这部分的配置最终会在模块下的Manifest中体现,下面会提到)

5、点击 Finish即可创建模块

动态功能模块

创建出的模块目录如下:

可以看到与正常模块一样,但是这里的Manifest内容有差异,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:dist="http://schemas.android.com/apk/distribution"
    package="com.huichongzi.dynamicfeature">

    <dist:module
        dist:instant="false"
        dist:title="@string/title_dynamicfeature">
        <dist:delivery>
            <dist:on-demand />
        </dist:delivery>
        <dist:fusing dist:include="true" />
    </dist:module>
</manifest>

可以看到这里出现了一个dist标签,这个标签下就是动态功能模块的一些配置。比如dist:instant="false"就是不支持免安装(免安装后面会细说),而title就是上面4步中设置的module title。而

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dist:delivery>
    <dist:on-demand />
</dist:delivery>

就是分发时机,on-demand就是Do not include module at install-time即按需分发(后面单独说),如果改成install-time就是Include module at install-time即安装时分发,按条件分发则不太一样,如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 <dist:delivery>
      <dist:install-time>
          <dist:conditions>
              <dist:device-feature dist:name="android.hardware.camera.ar"/>
              ...
          </dist:conditions>
      </dist:install-time>
  </dist:delivery>

模块创建后可以在这里添加新的分发条件。

这里也可以根据国家/地区指定条件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dist:conditions>
   <!-- Set to "true" to specify countries to exclude from downloading
   this module at app install-time. By default, modules are available
   for download to all user countries. -->
  <dist:user-countries dist:exclude="true">
    <!-- Specifies the two-letter  CLDR country code for regions that should
    not download the module at app install-time. -->
    <dist:country dist:code="CN"/>
    <dist:country dist:code="HK"/>
  </dist:user-countries>
</dist:conditions>

根据 API 级别指定条件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dist:conditions>
    <!-- Specifies the minimum API level that the device must satisfy
         in order to download your module at app install-time. The API level you
         specify must be greater or equal to the module's own minSdkVersion. -->
   <dist:min-sdk dist:value="21"/>
    <!-- Specifies the maximum API level that the device cannot exceed
         in order to download your module at app install-time. The API level you
         specify must be less than or equal to the module's own maxSdkVersion. -->
   <dist:max-sdk dist:value="24"/>
</dist:conditions>

与主模块建立关联

当 Android Studio 创建功能模块时,它会自动在基本模块的 build.gradle 文件添加 android.dynamicFeatures 属性,以使该功能模块对基本模块可见,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// In the base module’s build.gradle file.
android {
    defaultConfig {
        ...
    }
    ...
    // Specifies feature modules that have a dependency on
    // this base module.
    dynamicFeatures = [":dynamic_feature", ":dynamic_feature2"]
}

此外,Android Studio 还会将基本模块添加为功能模块的依赖项,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// In the feature module’s build.gradle file:
...
dependencies {
    ...
    // Declares a dependency on the base module, ':app'.
    implementation project(':app')
}

部署应用

在开发支持功能模块的应用时,您可以像往常一样,从菜单栏中依次选择 Run > Run(或点击工具栏中的 Run 图标 ),将该应用部署到连接的设备。

如果您的应用项目包含一个或多个功能模块,您可以通过修改现有的运行/调试配置以选择需要在部署应用时包含的功能,具体操作步骤如下:

  • 从菜单栏中依次选择 Run > Edit Configurations。
  • 在 Run/Debug Configurations 对话框的左侧面板中,选择所需的 Android App 配置。
  • 在 General 标签页中的 Dynamic features to deploy 下,选中需要在部署应用时包含的每个功能模块旁边的复选框。
  • 点击 OK。

默认情况下,Android Studio 不会使用 app bundle 部署您的应用,而是由 IDE 构建针对部署速度(而非 APK 大小)进行了优化的 APK,并将其安装到设备中。如需将 Android Studio 配置为通过 app bundle 构建和部署 APK 以及免安装体验,请修改运行/调试配置。

按需分发On-Demand

上面我们提到了三种分法模式:安装时分发,按需分发和按条件分发。

安装时分发比较好理解,即在google play下载安装应用的时候就会下载该模块;按条件分发也比较好理解,下载安装应用时,如果当前设备满足条件才会下载该模块;只有按需分发,并不是很容易理解。

按需分发与国内很多应用的插件化类似,就是在功能被使用的时候才会去下载那部分代码和资源。官方描述是这样的:

如果在使用购物平台应用的用户中,只有 20% 的人发布待售商品,有一个不错的策略可以减少大多数用户的初始下载大小,那就是将拍照、输入商品描述及上架商品的功能配置为按需下载。也就是说,您可以为应用的销售功能配置功能模块,使该功能仅在用户希望在购物平台上销售商品时才下载。此外,如果用户在一段时间后不再出售商品,应用可以通过请求卸载该功能减小其安装大小。 https://developer.android.google.cn/guide/app-bundle/dynamic-delivery#dynamic_feature_modules

但是通过上面创建部署动态模块的流程,我们发现没有关于按需下载的这部分逻辑。这是因为如果要使用动态模块,还需要配合google的play core library才可以:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
implementation "com.google.android.play:core:${versions.playcore}"

通过这个library中的SplitInstallManager这个类来实现判断模块是否安装,如果没有安装则下载安装等逻辑。

这部分内容很多,受本文篇幅所限就不展开了,官方有一篇很详细的教程:https://developer.android.com/codelabs/on-demand-dynamic-delivery#0,有兴趣的同学可以自行阅读。以后有时间我会单独出一篇中文教程。

免安装分发

还有一种动态功能模块,即免安装分发。Google Play 免安装体验让用户无需在设备上安装 APK 即可与您的应用互动。用户可以通过 Google Play 商店中的“立即体验”按钮或您创建的网址体验您的应用。这种内容分发形式可让您更轻松地提高用户与应用的互动度。

仅当应用的基本模块也支持免安装体验时,您才能使功能支持免安装体验。这是因为,如果用户想要体验您的应用中某个支持免安装体验的功能模块,他们的设备还必须下载应用的基本模块以获取通用代码和资源。请注意,为了支持 Google Play 免安装体验,基本模块和功能的下载必须满足几个条件:

最大大小:支持免安装体验的基本模块和支持免安装体验的功能模块的总大小不得超过 10 MB。如需了解详情,请阅读通过缩减应用或游戏大小支持免安装体验。

后台活动:支持免安装体验的模块无法使用后台服务。此外,此类模块在后台运行时无法发送通知。

如果您使用 Android Studio 3.5 或更高版本创建支持免安装体验的功能模块(如本部分所述),IDE 会在每个模块的清单中添加以下内容,从而自动使基本模块和功能模块支持免安装体验:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<manifest xmlns:dist="http://schemas.android.com/apk/distribution"
    ... >
    <dist:module dist:instant="true" />
    ...

此外,在下载并安装您的应用时,系统会随该应用的基本 APK 自动下载并安装支持免安装体验的功能模块。因此,IDE 还会在支持免安装体验的功能模块中添加以下内容。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    <dist:module ...>
        <dist:delivery>
            <dist:install-time />
        </dist:delivery>
    </dist:module>

此行为意味着,当您设置 dist:instant="true" 时,不能同时包含<dist:on-demand />。不过,您可以根据需要使用 Play Core 库在免安装体验中请求支持免安装体验的模块。

创建免安装模块

与创建动态模块过程一样,只不过有几处不同:

1、创建选择module类型的时候,选Instant Dynamic Feature Module

2、没有选择分发时机的选项了,所以第四步Module Download Options没有了,剩余的选项合并到第三步Configure your new module中了,所以Configure your new module设置完就finish了。

部署应用

部署与其他动态功能模块一样。

总结

Android App Bundle可以有效的减少安装包体积,而如果利用好动态功能模块(Dynamic Feature Module)更是可以极大的压缩安装包大小,这样可以大幅减少用户下载安装的等待时间,用户可以更快的体验到应用,提高用户的体验。但是动态功能模块(尤其按需分发)一定要设计好,否则用户在使用过程中还要频繁的下载模块也会降低用户体验。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-07-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 BennuCTech 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
为您的应用配置 Play Feature Delivery
这是一个新的系列文章,我们称之为 "Modern Android Development 技巧",简称为 "MAD Skills"。本系列文章致力于帮助开发者们打造更好的现代 Android 开发体验,敬请关注。
Android 开发者
2022/03/09
8421
Android动态化框架App Bundles
在今年的Google I/O大会上,Google向 Android 引入了新 App 动态化框架(即Android App Bundle,缩写为AAB),与Instant App不同,AAB是借助Split Apk完成动态加载,使用AAB动态下发方式,可以大幅度减少应用体积。现在只须在 Android Studio 中构建一个应用束 (app bundle),就可以将应用所需的全部内容 (适用于所有设备) 都涵盖在内:所有语言、所有设备屏幕大小、所有硬件架构。
xiangzhihong
2022/11/30
1.6K0
在功能模块中使用导航 | MAD Skills
这是关于导航 (Navigation) 的第二个 MAD Skills 系列,本文是导航组件系列的第四篇文章,如果您想回顾过去发布的内容,请通过下面链接查看:
Android 开发者
2022/03/09
5670
在功能模块中使用导航 | MAD Skills
Android App瘦身新姿势——Android App Bundle
由于博主长期从事海外App的开发,所以心系谷歌爸爸的动向呀,最近谷歌爸爸推出了一个Android App Bundle的东西,据说可以压缩包体,当然这仅限于上传Google Play的应用,国内市场不支持,当然我们也可以学习谷歌爸爸的思想。
老马的编程之旅
2022/06/22
1.2K0
Android App瘦身新姿势——Android App Bundle
Google I/O 之 Android App Bundles 是个啥
Android App Bundles(以下简称AAB)是今年Google I/O大会带来的一款全新动态化框架,与Instant App不同,AAB是借助Split Apk完成动态加载。介绍AAB之前,先来了解下SplitApk。 Split Apks split apks是Android 5.0开始提供多apk构建机制,借助split apks可以将一个apk基于ABI和屏幕密度两个维度拆分城多个apk,这样可以有效减少apk体积。当用户下载应用程序安装包时,只会包含对应平台的so和资源。因为需要goog
用户1907613
2018/07/20
2.5K0
重要变更: Android App Bundle 的未来计划
自 2018 年 5 月发布 Android App Bundle 以来,我们见证了开发者社区积极拥护这一全新发布格式,并受益于其简化的发布管理和高级分发功能。现在,有逾一百万款正式版应用在使用 App Bundle,Google Play 上排名前 1,000 的大多数应用和游戏均在此列,例如 Adobe、Duolingo、Gameloft、Netflix、redBus、Riafy 和 Twitter。
Android 开发者
2022/03/09
1.2K0
重要变更: Android App Bundle 的未来计划
如何获得更小的应用文件尺寸?来了解下 Android App Bundle
传统的 Android Package Kit (APK) 包含应用支持的所有设备的代码和资源 (布局文件、图像等)。因此,您在安装 APK 时可能装上了一些您永远不会用到的资源。您的屏幕尺寸不会改变,您的 CPU 也不会; 您通常不会说应用所支持的所有语言。很明显,APK 里的内容的比您要求的更多,占用的空间也比实际需要的更多。
Android 开发者
2018/10/18
2K0
如何获得更小的应用文件尺寸?来了解下 Android App Bundle
Dynamic Feature 上线 1 年实践分享
Dynamic Feature,官方全称为 Dynamic Feature Modules,是基于 Multiple APK + Google Play services 的官方动态下发方案。
sickworm
2024/08/06
4980
Dynamic Feature 上线 1 年实践分享
浅谈Android App Bundle
项目中一个定制版本,需要上架Google Play。 我们和上架国内的应用市场一样提供了一个apk,收到了如下的提示:
艳龙
2021/12/16
1.6K0
浅谈Android App Bundle
打造您的首个 app bundle | MAD Skills
这是一个新的系列文章,我们称之为 "Modern Android Development 技巧",简称为 "MAD Skills"。本系列文章致力于帮助开发者们打造更好的现代 Android 开发体验,敬请关注。
Android 开发者
2022/03/09
9190
打造您的首个 app bundle | MAD Skills
【Google Play】App Bundle 使用详解 ( 按条件分发 | 国家地区 | SDK 版本 | 设备功能 | 按需分发 | 资源分发 )
【Google Play】创建 Google 开发者账号 ( 注册邮箱账号 | 创建开发者账号 ) 【Google Play】创建并设置应用 ( 访问权限 | 内容分级 | 受众群体 | 类别及联系方式 | 商品详情 )
韩曙亮
2023/03/29
3.1K0
【Google Play】App Bundle 使用详解 ( 按条件分发 | 国家地区 | SDK 版本 | 设备功能 | 按需分发 | 资源分发 )
Android 大型工程 App Bundle 模块化实践
导言 Android App Bundle 是 Android 新推出的一种官方发布格式,可让您以更高效的方式开发和发布应用。企业微信基于 App Bundle 采用低入侵、业务代码基本零重构的技术方案,实现了全业务模块采用动态模块(dynamic feature)开发。最后展示并行编译方案,进一步加速持续集成。 一、项目背景 Android App Bundle 是 Android 新推出的一种官方发布格式,可让您以更高效的方式开发和发布应用。和国内开发者已经熟知的 Kotlin 开发语言、Androi
微信终端开发团队
2021/05/26
5.1K0
Flutter 动态化新知识
作者:rayszhang,腾讯 PCG 客户端开发工程师 背景 Flutter 的 release 产物会生成 libapp.so 以及放入 assets 的资源,包含了所有业务代码及所用资源。而随着业务越来越多,产物也越来越大。 某业务如要做下发,需要整体更新,牵一发而动全身,流量消耗也很可观。这时自然会产生一个想法,各业务能否独自生成产物,在用到时才下载运行。 而在 Flutter 的官方 git 上,已有不少的 issue 提出了这个问题,比如: https://github.com/flutt
腾讯技术工程官方号
2021/05/17
2.8K0
[译] 谷歌寻踪圣诞老人应用(Santa Tracker)迁移到 Android App Bundle 记录
谷歌寻踪圣诞老人应用(Santa Tracker)迁移到 Android App Bundle 记录
Android 开发者
2022/09/21
1K0
[译] 谷歌寻踪圣诞老人应用(Santa Tracker)迁移到 Android App Bundle 记录
为什么说它对 Android 未来的发展十分重要?
由于其开放性,Android 在其前十年取得了显著的增长。有大量的设备可供选择,蓬勃发展的开发者生态系统提供了许多应用和游戏,为这些设备赋予了长久的生命力。作为开发者,您希望确保用户尽可能获得最佳体验,并确保您的应用尽可能在所有这些设备上运行。您还希望尽可能多的用户安装您的应用; 您也希望他们持续使用它; 并且您不希望他们因您无法控制的原因卸载您的应用。到目前为止,Android 应用的发布和分发方式在所有这些方面都有待改进。我想观察一下开发者面临的一些挑战,并告诉您 Google 正在采取哪些措施来提供帮助。
Android 开发者
2018/12/04
1.7K0
为什么说它对 Android 未来的发展十分重要?
.apk 成为历史!
早在 2018 年 5 月的 Google I/O 大会上,Google 就介绍了 Android App Bundle(AAB)格式,作为其现代化开发的一部分。今年 8 月,AAB 格式将成为全新上架到 Google Play Store 应用的默认格式,已经上架的老应用暂时不会受到影响。
芋道源码
2021/07/13
9210
What's the aab ?
Google Play 将开始要求从 2021 年 8 月开始使用 Android App Bundle 发布新应用。这将取代 APK 作为标准发布格式。
用户9732312
2022/05/13
3890
What's the aab ?
谷歌弃用APK包格式,转而使用AAB格式
近日,谷歌官方宣布:自 2021 年 8 月起,Google Play 将要求开发者以 Android App Bundle (以下简称 AAB)格式发布新应用,该格式将取代 APK 成为标准的Android应用发布格式。
xiangzhihong
2022/11/30
1.9K0
.apk 成为历史!(有福利哦ᥬ?)
早在 2018 年 5 月的 Google I/O 大会上,Google 就介绍了 Android App Bundle(AAB)格式,作为其现代化开发的一部分。今年 8 月,AAB 格式将成为全新上架到 Google Play Store 应用的默认格式,已经上架的老应用暂时不会受到影响。
小小詹同学
2021/07/27
7090
.apk 成为历史!(有福利哦ᥬ?)
基于Google动态化方案的组件化演进
国内Android动态化方案已经蓬勃发展数年之久,在React Natvie、Flutter这些跨平台方案未出现之前,类似Atlas、Replugin、DLA等Android动态化方案在业界独领风骚。在国内动态化方案也分为两个流派:组件化与插件化。比如Atlas自称为组件化方案,另外诸如Replugin、DroidPlugin等称为插件化方案。本文不具体说明组件化与插件化区别相关介绍文章已多入牛毛,这里就不再赘述。
用户1907613
2018/07/25
2.4K0
基于Google动态化方案的组件化演进
相关推荐
为您的应用配置 Play Feature Delivery
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验