2021 友盟+移动应用性能挑战赛 -- Unity开发游戏启动慢问题解决方案

本文涉及的产品
应用实时监控服务-应用监控,每月50GB免费额度
应用实时监控服务-用户体验监控,每月100OCU免费额度
简介: 探索Unity制作游戏启动慢的问题原因分析和使用友盟+定位问题及处理问题的解决方案记录。

一,项目背景

在手游时代,消除游戏成为休闲游戏领域中的一个重要类型。《恶魔消除》是一款可以在手机上三消类益智游戏。游戏除了横竖交换物体得到消除之外,还添加类似魔方的行,列滑动的交互方式,让用户一样的交互体验。

1.1 开发环境:

  • Unity2019.4.19
  • JetBrains Rifer 2019.1.3
  • Xcode 12.5.1

二,所遇到的挑战

2.1 难在于发现问题

随着用户的增加,得到越来越多的用户反馈,游戏打开慢。

有上线经验的程序,应该都知道上线游戏能得到用户反馈的比例是很小的。用户反馈的两个必要条件:

  1. 喜欢你的游戏(需要你的程序)
  2. 程序存在不能忍受的问题

所以一旦有几个用户反馈了同一个问题,我们一定要重视起来(别问我怎么知道的)。

2.2 更难于定位问题

对于用户反馈的启动慢?

程序员:启动慢? 首次启动慢? 冷启动慢? 还是热启动慢啊? 什么机型? 系统什么版本?

这么一大堆问题,肯定没有办法去问用户啊。即便是问了也没有结果。因为大部分用户是不会回复的(能给反馈已经很不易了),剩下的一部分估计要反问了:什么是冷启动?什么是热启动?...

2.3 获取到解决方案

友盟+ U-APM 应用性能监控平台:(之前用过友盟+ 的统计功能,就感觉非常好用。这次又是友盟帮助解决了大问题[手动点赞]。)

由上图可以看到U-APM为我们提供了”2.2”中程序原提出的所有问题的信息统计,感觉真的不要太强大有没有。

虽然有了这么多的统计信息,可是我手里没有那么多测试机啊,总不能先接入SDK发布一个版本,看来用户数据来校验问题是否修正吧。这种想法可真是太可怕了,光是启动慢还好,要是闪退这种直接导致程序崩溃的致命问题,这么干无疑会伤一批用户,不过好在U-APM还为我们提供了云真机功能,并且还推出了免费体验时长,真是贴心~


三,解决问题的步骤

3.1 接入U-AMP

接入流程如下:(每一步官方都有详细文档,这里不再赘述)

官网地址:https://www.umeng.com/

3.2 定位问题

通过接入U-AMP结合官方提供云真机,多机型多次测试后。问题确定为冷启动时间较长。

几经周折,查了很多启动慢相关文章,解决方案基本归结如下:

  1. Resources管理资源:

    Resources目录下面的所有资源会在ResourceManager中记录下来,而ResourceManager就是一个文件,通常是一个YAML格式的文本文件。而这个文件是会在冷启动时加载的。所以Resources目录下面的有越多的资源,那么这个ResourceManager就会越大,加载时间也会越长。

    建议:使用AssetBundle的方式管理,在现在官方也推出了可寻址系统Addressable AssetSystem

  2. Shader编译时长:

    如果只有游戏安装之后第一次启动时间过长,一个很大的可能是Shader编译,之后游戏启动因为有了Cache,所以会快很多。这种情况的话建议查看下Always Include的Shader内容和变体。

    建议:使用shadervariantcollection等方案替代。

  3. 纹理资源过大:

    在游戏中一般是最大的资源,选择合适的压缩格式进行压缩,既可以减少内存占用,又能够加快资源的加载速度。压缩格式的选择要从显示效果和压缩率上进行权衡。

    建议:一般在Android上使用ETC格式,在iOS上使用PVRTC格式,在某些情况下,可能还可以考虑使用Alpha通道分离技术进行压缩处理

3.3 解决问题

由于原工程打包慢,所以我新建了项目,模拟还原了3.2中:Resources管理资源和纹理资源过大问题:

【新建工程,在Resource文件夹中放了资源,在其他文件夹下放了比较大的纹理】

打包测试结果如下:

经过减少Resource文件夹资源,和对比较大的贴图压缩后。

打包测试结果:

经过对比可以看到启动时间确实是减少了,证明方案可行,可以应用到实际项目。


四,项目总结

相比于Android或者IOS原生App,Unity3D引擎开发的游戏在冷启动时间上确实比较长。但是过长的启动时间会导致用户不好的用户体验,甚至损失一批用户。若没有用户反馈,可能问题一直得不到解决,很可能成为收益少的一大因素。

所以,平时开发时注重资源管理,后续就不会有这种类似问题。另外测试数据量,以及低端机型用户体验都是有必要作为关键测试点的。

最后建议[友盟+ U-APM SDK]。不管是统计工程和还是性能分析以及崩溃反馈都可以帮助开发者及时快速定位解决问题,以免带来更大的损失。

相关实践学习
通过云拨测对指定服务器进行Ping/DNS监测
本实验将通过云拨测对指定服务器进行Ping/DNS监测,评估网站服务质量和用户体验。
相关文章
|
4月前
|
图形学 C#
超实用!深度解析Unity引擎,手把手教你从零开始构建精美的2D平面冒险游戏,涵盖资源导入、角色控制与动画、碰撞检测等核心技巧,打造沉浸式游戏体验完全指南
【8月更文挑战第31天】本文是 Unity 2D 游戏开发的全面指南,手把手教你从零开始构建精美的平面冒险游戏。首先,通过 Unity Hub 创建 2D 项目并导入游戏资源。接着,编写 `PlayerController` 脚本来实现角色移动,并添加动画以增强视觉效果。最后,通过 Collider 2D 组件实现碰撞检测等游戏机制。每一步均展示 Unity 在 2D 游戏开发中的强大功能。
220 6
|
3月前
|
测试技术 C# 图形学
掌握Unity调试与测试的终极指南:从内置调试工具到自动化测试框架,全方位保障游戏品质不踩坑,打造流畅游戏体验的必备技能大揭秘!
【9月更文挑战第1天】在开发游戏时,Unity 引擎让创意变为现实。但软件开发中难免遇到 Bug,若不解决,将严重影响用户体验。调试与测试成为确保游戏质量的最后一道防线。本文介绍如何利用 Unity 的调试工具高效排查问题,并通过 Profiler 分析性能瓶颈。此外,Unity Test Framework 支持自动化测试,提高开发效率。结合单元测试与集成测试,确保游戏逻辑正确无误。对于在线游戏,还需进行压力测试以验证服务器稳定性。总之,调试与测试贯穿游戏开发全流程,确保最终作品既好玩又稳定。
150 4
|
4月前
|
图形学 缓存 算法
掌握这五大绝招,让您的Unity游戏瞬间加载完毕,从此告别漫长等待,大幅提升玩家首次体验的满意度与留存率!
【8月更文挑战第31天】游戏的加载时间是影响玩家初次体验的关键因素,特别是在移动设备上。本文介绍了几种常见的Unity游戏加载优化方法,包括资源的预加载与异步加载、使用AssetBundles管理动态资源、纹理和模型优化、合理利用缓存系统以及脚本优化。通过具体示例代码展示了如何实现异步加载场景,并提出了针对不同资源的优化策略。综合运用这些技术可以显著缩短加载时间,提升玩家满意度。
276 5
|
3月前
|
前端开发 图形学 开发者
【独家揭秘】那些让你的游戏瞬间鲜活起来的Unity UI动画技巧:从零开始打造动态按钮,提升玩家交互体验的绝招大公开!
【9月更文挑战第1天】在游戏开发领域,Unity 是最受欢迎的游戏引擎之一,其强大的跨平台发布能力和丰富的功能集让开发者能够迅速打造出高质量的游戏。优秀的 UI 设计对于游戏至关重要,尤其是在手游市场,出色的 UI 能给玩家留下深刻的第一印象。Unity 的 UGUI 系统提供了一整套解决方案,包括 Canvas、Image 和 Button 等组件,支持添加各种动画效果。
156 3
|
3月前
|
设计模式 存储 人工智能
深度解析Unity游戏开发:从零构建可扩展与可维护的游戏架构,让你的游戏项目在模块化设计、脚本对象运用及状态模式处理中焕发新生,实现高效迭代与团队协作的完美平衡之路
【9月更文挑战第1天】游戏开发中的架构设计是项目成功的关键。良好的架构能提升开发效率并确保项目的长期可维护性和可扩展性。在使用Unity引擎时,合理的架构尤为重要。本文探讨了如何在Unity中实现可扩展且易维护的游戏架构,包括模块化设计、使用脚本对象管理数据、应用设计模式(如状态模式)及采用MVC/MVVM架构模式。通过这些方法,可以显著提高开发效率和游戏质量。例如,模块化设计将游戏拆分为独立模块。
209 3
|
3月前
|
图形学 C++ C#
Unity插件开发全攻略:从零起步教你用C++扩展游戏功能,解锁Unity新玩法的详细步骤与实战技巧大公开
【8月更文挑战第31天】Unity 是一款功能强大的游戏开发引擎,支持多平台发布并拥有丰富的插件生态系统。本文介绍 Unity 插件开发基础,帮助读者从零开始编写自定义插件以扩展其功能。插件通常用 C++ 编写,通过 Mono C# 运行时调用,需在不同平台上编译。文中详细讲解了开发环境搭建、简单插件编写及在 Unity 中调用的方法,包括创建 C# 封装脚本和处理跨平台问题,助力开发者提升游戏开发效率。
283 0
|
3月前
|
vr&ar 图形学 API
Unity与VR控制器交互全解:从基础配置到力反馈应用,多角度提升虚拟现实游戏的真实感与沉浸体验大揭秘
【8月更文挑战第31天】虚拟现实(VR)技术迅猛发展,Unity作为主流游戏开发引擎,支持多种VR硬件并提供丰富的API,尤其在VR控制器交互设计上具备高度灵活性。本文详细介绍了如何在Unity中配置VR支持、设置控制器、实现按钮交互及力反馈,结合碰撞检测和物理引擎提升真实感,助力开发者创造沉浸式体验。
189 0
|
3月前
|
图形学 开发者
【独家揭秘】Unity游戏开发秘籍:从基础到进阶,掌握材质与纹理的艺术,打造超现实游戏视效的全过程剖析——案例教你如何让每一面墙都会“说话”
【8月更文挑战第31天】Unity 是全球领先的跨平台游戏开发引擎,以其高效性能和丰富的工具集著称,尤其在提升游戏视觉效果方面表现突出。本文通过具体案例分析,介绍如何利用 Unity 中的材质与纹理技术打造逼真且具艺术感的游戏世界。材质定义物体表面属性,如颜色、光滑度等;纹理则用于模拟真实细节。结合使用两者可显著增强场景真实感。以 FPS 游戏为例,通过调整材质参数和编写脚本动态改变属性,可实现自然视觉效果。此外,Unity 还提供了多种高级技术和优化方法供开发者探索。
58 0
|
3月前
|
图形学 iOS开发 Android开发
从Unity开发到移动平台制胜攻略:全面解析iOS与Android应用发布流程,助你轻松掌握跨平台发布技巧,打造爆款手游不是梦——性能优化、广告集成与内购设置全包含
【8月更文挑战第31天】本书详细介绍了如何在Unity中设置项目以适应移动设备,涵盖性能优化、集成广告及内购功能等关键步骤。通过具体示例和代码片段,指导读者完成iOS和Android应用的打包与发布,确保应用顺利上线并获得成功。无论是性能调整还是平台特定的操作,本书均提供了全面的解决方案。
157 0
|
4月前
|
图形学 开发者 存储
超越基础教程:深度拆解Unity地形编辑器的每一个隐藏角落,让你的游戏世界既浩瀚无垠又细节满满——从新手到高手的全面技巧升级秘籍
【8月更文挑战第31天】Unity地形编辑器是游戏开发中的重要工具,可快速创建复杂多变的游戏环境。本文通过比较不同地形编辑技术,详细介绍如何利用其功能构建广阔且精细的游戏世界,并提供具体示例代码,展示从基础地形绘制到植被与纹理添加的全过程。通过学习这些技巧,开发者能显著提升游戏画面质量和玩家体验。
182 3