使用方案及引擎选择建议
收藏
我的收藏文档说明:本文档描述抖音Unity小游戏接入时方案的选择。
抖音Unity小游戏适配方案以WebAssembly为基础,理论上支持大多数的Unity版本。但由于部分性能优化项仅在Unity2021后才有。所以不推荐使用 Unity2021 前的版本。
推荐版本
引擎版本 | 压缩纹理格式 | 编译体积 | 已验证小版本 | 其他 |
2021 | 支持ASTC | 80% | 2021.2.11~2021.3.33 | --- |
2022(推荐) | 支持ASTC | 80% | 2022.3.1~2022.3.14 | --- |
团结引擎-WebGL(推荐) | 支持ASTC | 60~80% | 1.0.4 | 基于2022.3.2, 但包体、内存更多优化,支持FrameDebugger调试 |
团结引擎-DotNet Wasm(尚未支持) | 支持ASTC | 60~80% | 尚未支持 | 基于2022.3.2, 但包体、内存更多优化,支持FrameDebugger调试 |
前置判断项
游戏包体大小改造可能性
在抖音下,游戏的分发是跟随视频的;如果游戏包体过大,取消率过高,会对视频的分发有负向价值,也影响用户体验。所以需要做小包化。 unity游戏,基于WebAssembly,天然要比JS小游戏的方案包体大,所以需要更多的优化工作。
用户可以自行选择小包化方案。如果包体已符合要求(压缩后 小于30M,优秀是6M),则可跳过
- •包体减小,主要在于对资源的分离,可选择的方案包括,且不限于
- ◦Unity 的AssetBundle按需下载
- ◦Unity 的 AutoStreaming 方案
- •如果代码过于庞大,导致wasm 过大,也会造成加载和编译时间过长,那要根据实际情况进行评估是否能够删减。
游戏逻辑改造的可能性
不同的方案,对引擎版本,所用插件有一定限制,考虑项目代码层面改造的可能性
- •支持托管类型的dll插件、C#源码插件,不支持非托管类型(如C++编译的)dll/so。项目依赖的必要插件有Android/iOS平台相关插件或so/framework原生插件,无法转换。
- •性能有限,如果项目中有较多密集运算,物理模拟,脚本,可能要做降级优化。
- •iOS下内存受限,如果项目中有较大的贴图,模型,可能要做降级优化。
功能项评估
游戏重要的能力支持情况如下:
能力 | 是否支持 | 解决方案 |
Unity基础模块 | 支持 | 支持动画、物理、AI、UI等基础模块 |
渲染管线与接口 | 支持 | 支持标准渲染管线、URP,WebGL2.0已支持 |
资源加载 | 支持 | Addressable、AssetBundle网络异步加载 |
Lua脚本 | 支持 | 支持标准Lua与常见binding(如xlua, tolua等), 不支持Luajit。需根据实际游戏在真机验证性能。游戏更新原则上要走平台的审核流程。 |
PuerTS | 支持 | iOS系统需14.5以上, 支持JIT,但目前不支持import,js代码要放到jslib中。游戏更新原则上要走平台的审核流程。 |
Unity音频 | 支持 | Unity Audio基本能力支持,支持fmod插件,不支持wwise。直接使用unity的音频组件即可。 |
第三方插件 | 部分支持 |