【unity】关于技能释放shader.CreateGPUProgram造成卡顿,优化和定位方法。

关于优化方法,UWA这边有介绍

Unity移动端游戏性能优化简谱之 CPU耗时调优|单帧|动画|调用|unity|实例化_网易订阅

对此,我们可以将Shader通过ShaderVariantCollection收集要用到的变体并进行AssetBundle打包。在将该ShaderVariantCollection资源加载进内存后,通过在游戏前期场景调用ShaderVariantCollection.WarmUp来触发Shader.CreateGPUProgram,并将此SVC进行缓存,从而避免在游戏运行时触发此API的调用、避免局部的CPU高耗时。

然而即便是已经做过以上操作的项目也常会检测到运行时偶尔的该API耗时峰值,说明存在一些"漏网之鱼"。开发者可以结合Profiler的Timeline模式,选中触发调用Shader.CreateGPUProgram的帧来查看具体是哪些Shader触发了该API,可以参考。

timeline里可以看到具体开销,但量比较多的时候一帧里找还是挺费劲的。

对于漏网之鱼的定位,后来还介绍了一种方法,我实际了一下记录一下:

就是启用 LogShaderCompilation 功能:

  1. 打开 Unity 编辑器,并打开您的项目。
  2. 在菜单栏中选择 "Edit"(编辑)选项。
  3. 在下拉菜单中选择 "Project Settings"(项目设置)。
  4. 在 "Project Settings"(项目设置)窗口中,选择 "Graphics"(图形)选项卡。
  5. 在 "Graphics"(图形)选项卡中,找到 "Shader Loading"部分。将 "LogShaderCompilation"(当着色器编译时记录日志)选项勾选上。

打包在手机上运行后, 用logcat抓到日志

关键字 Compiled shader, Debug级别的,如果你过滤了可能看不到。

看一下日志能看到当时哪个shader 的什么Keywords触发了编译:

相关推荐
龙智DevSecOps解决方案2 小时前
Perforce《2025游戏技术现状报告》Part 3:不同行业挑战以及Unreal、Godot、自研游戏引擎的应用趋势
游戏引擎·godot·游戏开发·perforce
在路上看风景2 小时前
13. UGUI合批
unity
jtymyxmz15 小时前
《Unity Shader》12.2调整屏幕的亮度、饱和度和对比度
unity·游戏引擎
AllBlue1 天前
unity嵌入安卓界面,如何显示状态
android·unity·游戏引擎
tealcwu1 天前
【Unity技巧】实现在Play时自动保存当前场景
java·unity·游戏引擎
tealcwu1 天前
【Unity基础】实现Scroll View跟随动态内容滚动
java·unity·游戏引擎
野奔在山外的猫1 天前
【文档】VSCode 配置 Unity 环境流程
unity
技术小甜甜1 天前
[Godot排错] 上传 Google Play Console 封闭测试时签名证书不匹配错误的解决方案
游戏引擎·godot·游戏开发
变身缎带1 天前
Unity中的NetworkManager基于protobuf, Socket-TCP
tcp/ip·unity·游戏引擎
AllBlue2 天前
unity调用安卓方法
android·unity·游戏引擎