通过RenderDoc真机抓取数据来验证和落地解决特效性能的问题
本文为作者原创,转载请注明出处:https://www.cnblogs.com/zhaoqingqing/p/14984882.html
前言#
需求是来自于我在为我司的一个线上RPG游戏做特效的性能优化的过程中,需要验证对特效的一个改动是否能够提高性能,当然这个改动是在不影响美术效果的前提。
特效性能问题#
技能特效#
主角的一个大招(技能)会有10个特效,其中6个是相同的特效,也就是同一时间会存在6份相同的特效,但是从profiler来看这6份相同的特效的set passcall 和dc数量是随着特效数量而递增的(setpasscall=单个 x 数量),根据我的知识储备我判断这肯定有问题,最合理的情况是:多个特效的setpass = 单个特效的setpasscall。
UI特效#
游戏主界面的DC偏高,在排除完UGUI的合批被打断的情况之后,我发现随着游戏图标的增加(图标上有特效),dc也成倍数增加,当然这种情况也出现在了道具的流光特效上。
找出问题#
经过我的测试验证之后,已经确定这两个问题的原因都是一样的:
我们每个特效里面都包含子的Particle System,不同的粒子之间是使用单图,没有打图集,也就是一个特效有多个mat
粒子没有设置OrderInLayer,当出现多份相同的时候,需要unity对它们进行排序,这样就增加了setpasscall,打断了合批。
而在我对粒子进行修改后,就相当于提前给粒子设置了顺序,这样当出现多份相同的粒子时,因为mat,order,texture都是一样的,就可以被合批。
验证结果#
经过我的改动之后,当同屏存在100甚至1000个相同的特效,setpasscall和dc数量都没有上涨,在profiler和真机上抓取的数据都得到了验证。
图一是修改之前dc随数量增加(存在问题),图二是我修改之后dc是稳定的(正确的结果)
项目落地#
在验证这一改动是正确且对性能有提高之后也对美术效果没有影响,我花时间写工具并整理了游戏中的所有的法师技能特效,剑圣技能特效,BOSS技能特效,UI特效(包括图标特效,领取按钮,品质流光),场景特效(包括掉落物模型特效,环境特效,火焰),把要修改的特效统计到一个表格,和主美进行沟通,然后推动特效进行修改。
遇到问题
如果一个特效中同时有粒子和Mesh,且RenderQueue都是透明的(Transparent),修改粒子的Order in Layer后可能会出现mesh跑到粒子的后面,那么给mesh添加Sorting Group组件,并设置Order in Layer比粒子Renderer中的order更大就可以解决。
准备工作#
我的抓取环境:
使用Renderdoc抓取安卓真机数据,不需要ROOT,但需要打开手机的开发者调试模式并通过USB数据连接电脑。
- Renderdoc v1.14
- 自己的国产安卓手机,安卓11系统,未ROOT
- unity2019.3.7f1
- windows 10 ltsc
在Unity Editor中使用RenderDoc#
- 从官网https://renderdoc.org/,下载并安装Renderdoc
- 打开Unity,在Game 视图 - 右键 load Renderdoc
- 点击game视图旁边的小图标,就会把当前内容传输到Renderdoc
文档资料#
官方文档 - 快速开始:https://renderdoc.org/docs/getting_started/quick_start.html
PS. 官方文档比较简单,主要介绍软件的使用,如果你想查阅抓取出来的不同条目或关键词代表的意思,需要去查阅OpenGL或Directx的资料
超级详细的软件入门使用教程:renderdoc的使用
在Rnderdoc中抓包其它的游戏:RenderDoc[01] 使用RenderDoc 分析Android游戏(免Root)
参数解释#
glDrawElement:调用glDrawElements函数进行绘制就是Drawcall的一种形式
glDrawElementsBaseVertex:准备顶点数据
OpenGL的文档:http://docs.gl/gl4/glDrawElements
LearnOpenGL系列教程的简体中文翻译:https://learnopengl-cn.github.io/
保存记录#
因为我是使用自己的手机来调取,所以我抓取完我把记录保存到本地文件,这样当手机断开连接时,也可以查看抓取的数据,但是在我的使用中保存的记录无法查看贴图,其它信息可以查看。
遇到问题#
无法连接手机#
Core 20364 15:59:27 android.cpp(1363) Error Couldn't get PID when launching com.qing.dcTest with activity com.unity3d.player.UnityPlayerActivity and intent args
一开始我在安卓手机端的开发者模式中手动选择了要调试应用,出现上面的错误。
解决办法:只需要打开USB调试模式,像我的是国产定制系统,有ADB授权,把那个关闭就可以了,其它的不要多设置,就可以正常使用。
连接不稳定#
在连接的过程中,每隔几分钟就会断开连接,我后来把数据线连接到电脑后置USB接口上就没断开过了。
其它#
在SnapDragonProfiler中也是看glDrawElements,显示在glDraw call那列数据中。
本文版权归作者和博客园共有,欢迎转载,转载之后请务必在文章明显位置标出原文链接和作者,谢谢。
如果本文对您有帮助,请点击【推荐】您的赞赏将鼓励我继续创作!想跟我一起进步么?那就【关注】我吧。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· NetPad:一个.NET开源、跨平台的C#编辑器
2015-07-08 扩展Unity的方法