Android上架GooglePlay AAB大于150M解决方案

2023-10-12 15:50

本文主要是介绍Android上架GooglePlay AAB大于150M解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在打包aab上架时Google要求base目录大小必须小于150M,在做unity游戏混合原生开发时游戏内的资源包一般是远远大于150M的,因此可以利用Google提供的PAD(Play Asset Delivery )插件将unity包的assets资源文件拆分。
在这里插入图片描述
Play Asset Delivery 官方文档

新建存放拆分后的资源包library。

在这里插入图片描述
注意: 名字不能有特殊字符包括中横线“-”不然运行时会报错,可以有下划线“_”。
![在这里插入图片描述](https://img-blog.csdnimg.cn/49a7092ac7014a5e8bc7144d5c463df9.png

新建好后检查是否已添加到settings.gradle

在这里插入图片描述

打开刚新建u3d_resources的build.gradle添加如下内容

plugins {id 'com.android.library'id 'org.jetbrains.kotlin.android'id 'com.android.asset-pack'
}assetPack {//名称与刚刚新建的library名称必须一致packName = "u3d_resources"dynamicDelivery {//PAD资源分发 安装时分发deliveryType = "install-time"  }
}

分发模式

install-time
资源包在用户安装应用时分发。这些资源包以拆分 APK(APK 集的一部分)的形式提供。它们也称为“预先”资源包;您可以在应用启动时立即使用这些资源包。这些资源包会增加 Google Play 商店上列出的应用大小。用户无法修改或删除这些资源包。

fast-follow
资源包会在用户安装应用后立即自动下载;用户无需打开应用即可开始 fast-follow 下载。此类下载不会阻止用户访问应用。这些资源包会增加 Google Play 商店上列出的应用大小。

on-demand
资源包会在应用运行时下载。

再app的build.gradle导入core插件

 //PAD资源分发implementation 'com.google.android.play:core:1.10.3' 

资源包拆分

将我们拿到unity提供的aar包把文件后缀名改成zip然后解压就得到了所有的资源文件
在这里插入图片描述
将so、jar、AndroidManifest.xml、res复制到我们主目录(app目录)或者也可以其他模块。
在这里插入图片描述
再将assets资源文件复制到我们新建的资源模块u3d_resources assets目录,没有就新建。
在这里插入图片描述
特别注意assets bind目录下的资源文件是unity的核心资源最好不要拆分这个目录,否者在启动app时会出现unity资源加载不成功
在这里插入图片描述
将核心资源包保存在刚刚so、jar、AndroidManifest.xml、res同模块下assets目录或者其他模块
在这里插入图片描述

验证是否成功

到这里就完成资源拆分了,下面可以验证下是否已拆分成功。
打出的aab包base目录就会小很多,会多出一个刚刚我们新建的资源目录u3d_resources
在这里插入图片描述
如果拆分后的base还大于150M时就可以考虑移除一些架构下的so文件,或者其他的资源文件,只要能保证base小于150M就行。

使用 bundletool 插件验证aab包是否能正常安装unity资源文件加载正常

  1. 拿到aab文件使用命令打出apks文件。
java -jar bundletool-all-1.8.2.jar build-apks --bundle=[aab文件路径] --output=output.apks --local-testing
  1. 将apks文件安装到设备。
java -jar bundletool-all-1.8.2.jar install-apks --apks=output.apks

到这里基本上拆包流程已经完成。

debug配置

配置好拆包后为了方便平时debug调试可以动态配置在debug时使用aar,再打出正式包时在使用拆分后的library。
再app目录的gradle配置不同的渠道

 mateProduct {buildConfigField "boolean", "URL_DEBUG", "false"manifestPlaceholders = [CHANNEL_NAME: channelName]}//打包aab时资源分包aabProduct {buildConfigField "boolean", "URL_DEBUG", "false"manifestPlaceholders = [CHANNEL_NAME: channelName]}

再根据渠道导入不同的library

 gradle.startParameter.getTaskNames().each {println("====== $it ======")//判断如果是打包aab渠道就导入分包资源模块if (it.contains("AabProduct")||it.contains("aabProduct")) {api project(path: ':u3d-library')} else {//打包其他模块加载aar模块api project(path: ':u3d-debug-library')}}

这篇关于Android上架GooglePlay AAB大于150M解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/196887

相关文章

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2

html 滚动条滚动过快会留下边框线的解决方案

《html滚动条滚动过快会留下边框线的解决方案》:本文主要介绍了html滚动条滚动过快会留下边框线的解决方案,解决方法很简单,详细内容请阅读本文,希望能对你有所帮助... 滚动条滚动过快时,会留下边框线但其实大部分时候是这样的,没有多出边框线的滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行