13. UGUI合批

1.合批的关键渲染状态因素

2.UI特有的层级与顺序因素

3.影响合批的常见陷阱与优化策略


1.合批的关键渲染状态因素

csharp 复制代码
以下是决定UI元素能否合批的主要渲染状态因素, 它们必须全部相同才能合批

1).材质

最重要的因素, 必须使用完全相同的材质实例

这就是为什么Atlas(图集)如此关键, 当多个Image组件使用同一张图集纹理时, 它们引用的是同一个材质, 这是合批的基础

注意: 即使两个材质使用了相同的Shader和相同的Texture, 但如果它们是两个不同的材质实例, 仍然无法合批

2).纹理

作为材质的一部分, 纹理必须相同

UI的默认Sprite Atlas系统就是为了把多个小图片打包到一张大图集里, 让它们共享纹理, 从而满足合批条件

3).Shader和渲染队列

必须使用同一个Shader, 并且渲染队列(Render Queue)值相同

2.UI特有的层级与顺序因素

csharp 复制代码
1).UI特有的层级与顺序因素

由于UI是层级化的, 除了基础渲染状态, 在Hierarchy中的顺序也至关重要; 合批遵循一个"从上到下, 深度优先"遍历规则

同层级连续顺序: 在同一父节点下, 连续的、满足渲染状态相同的子节点可以被合批

2).中断(Break Batch): 如果中间出现了一个不满足合批条件的UI元素(例如使用了不同的材质), 它会中断合批流程, 其之

后的元素即使和前面的元素材质相同, 也需要从新的Draw Call开始

3.影响合批的常见陷阱与优化策略

csharp 复制代码
影响合批的常见陷阱与优化策略

1).不同的图集/纹理: 这是最常见的原因, 确保功能相关的UI精灵打包在同一个图集中

比如: 穿插的不同类型UI元素
csharp 复制代码
2).Mask / RectMask2D:

a.Mask组件(基于模板缓冲区)会强制中断合批, 严重影响性能

b.RectMask2D是更优选择, 它使用简单的轴对齐裁剪, 通常不会打断合批, 性能好得多
csharp 复制代码
3).Canvas层级

每个Canvas组件会生成一个独立的网格, 子Canvas或嵌套Canvas会打断合批边界

频繁改变的UI元素应该放在单独的Canvas中, 这样只需重建这个小的网格, 而不是整个大UI的网格; 这是"静态"和"动态"的

分离
相关推荐
mxwin3 小时前
Unity Shader exp 函数的算法与渲染应用
算法·unity·游戏引擎·shader
WarPigs9 小时前
AB包自定义打包工具
unity
叶帆18 天前
【YFIOs】用C#开发硬件之设备上云
开发语言·unity·c#
久数君18 天前
AI三维建模工具“造形家”:地理场景三维化的高效解决方案
unity·glb·ai算法·ai三维建模工具·地图框选·造形家·城市建筑模型
会思考的猴子18 天前
Unity VFX 属性 Postion 和 TargetPostion
unity
心前阳光18 天前
Unity资源导入之自动化资源导入
unity·自动化·游戏引擎
心前阳光18 天前
Unity之2021.3.45f2c1发布安卓程序遇到的问题
android·unity·游戏引擎
纪纯18 天前
PicoVR Unity Integration SDK 3.4 常用交互API
unity·游戏引擎·vr·pico
龙智DevSecOps解决方案18 天前
3A 游戏优化技术栈:如何打通引擎级分析工具与 DevOps 持续集成管线?
unity·性能优化·游戏开发·技术美术·perforce·unrealengine
葛兰岱尔18 天前
从 SolidWorks 到 Three.js,从 Inventor 到 Unity——制造业CAD模型“几何-语义一体化“转换,不再是天方夜谭!
开发语言·javascript·unity