UGUI合批原理笔记

摘要:
同一图集的Image元素应尽量保证在Hierarchy中连续,避免中间插入其他图集,或插入文本。避免UI元素数目过多和层次结构过于复杂影响Batch更新速度。参考资料Unity官方论坛发布UnityUI性能优化技巧UGUI优化:批次合并源码分析及工具工具:UI层级辅助工具,用于显示UI的层级、批次等数据,便于UI性能优化。使用者可以结合以上规则,分析当前UI元素排列顺序、材质贴图设置,优化UIBatching,减少UIDrawcall。UnityUI优化小结重建是UGUI优化的关键--Unite2017嘉宾杨怀忠分享《UGUI深度优化》

可以通过Frame debugger查看每个drawcall绘制了哪些东西

UGUI源码下载地址:https://bitbucket.org/Unity-Technologies/ui/downloads/

本文测试环境:unity2018.2.9f1,基于Unity Editor (PC平台)

合批的过程

image

网格更新机制

  • Cavans.SendWillRenderCanvas
    • m_LayoutRebuildQueue
    • m_GraphicRebuildQueue
  • Canvas.BuildBatch 更新所有DrawCall
    • WaitingForJob 子线程网格合并
    • PutGeometryJobFence
    • BatchRendere.Flush UI如果开多线程渲染,BatChRender.Flush会增高,主线程在等待子线程的结果时Flush会等待。

哪些因素的改变会引起合批

从源码中可以看到,这些数据的改变会引起合批

源码地址: UI / UnityEngine.UI / UI / Core / Utility / VertexHelper.cs

private List<Vector3> m_Positions = ListPool<Vector3>.Get();//顶点位置的拷贝或指定新顶点位置的数组
private List<Color32> m_Colors = ListPool<Color32>.Get();//颜色
private List<Vector2> m_Uv0S = ListPool<Vector2>.Get();//基本纹理坐标
private List<Vector2> m_Uv1S = ListPool<Vector2>.Get();//第二套纹理坐标
private List<Vector2> m_Uv2S = ListPool<Vector2>.Get();//第三套纹理坐标
private List<Vector2> m_Uv3S = ListPool<Vector2>.Get();
private List<Vector3> m_Normals = ListPool<Vector3>.Get();//法线
private List<Vector4> m_Tangents = ListPool<Vector4>.Get();//切线
private List<int> m_Indices = ListPool<int>.Get();//mesh的索引

Mesh的API:http://wiki.ceeger.com/script/unityengine/classes/mesh/mesh

http://wiki.ceeger.com/script/unityengine/classes/mesh/mesh.getindices

怎么避免合批

尽量减少“动态”长文本(运行时修改文本内容)

Image或Text,如果不需要点击,则不要勾选Raycasts

降低界面的更新频率

避免图集分离,使用相同的图集。

同一图集的Image元素应尽量保证在Hierarchy中连续,避免中间插入其他图集,或插入文本。

避免图片叠加在一起(遮挡,旋转)

如果sprite是中心镂空且切图为九宫格时,可以去除fill center,以减少over draw

透明Image,用来做响应点击事件,同样存在开销

避免或减少Mask的使用,1个Mask至少增加两个DC

避免频繁删除/增加UI对象,UI层次结构变化会引起Canvas的更新

避免频繁动态的更新UI元素的Vertex, Rect, Color, Material, Texture等,可能引起Canvas数据更新和Batch更新计算,有可能引起VBO Update(重新提交顶点数据)。

尽可能使用少的UI Material和贴图(使用图集),使得可以Batching。

同一父节点下所有子节点,保持相同的层次结构(如List控件下的item),便于底层相同depth下UI元素Batch。

避免UI元素数目过多和层次结构过于复杂影响Batch更新速度。

固定的Text考虑与背景图层合在一张图上(可能不便本地化,但可以减少drawcall)。

使用缓存池,对缓存频繁使用的元素。

部分内容参考:http://gad.qq.com/article/detail/25947

HUD处理(动静分离)

Canvas重建就是为了合并DC,将经常变化的文字放在独立的Canvas,手动分离Canvas(会增加DC,不能和其它文字合并),但文字变化时其它Canvas就不需要重建。

示例:名字和血条分开在两个不同的节点下。这样当血条变化时,就不会引起名字的更新。如下图所示:

image

2、设置scale为0,而不是设置active = false/true,或者添加Alpha Group,设置alpha=0/1

不勾选FillCenter

镂空九宫格不勾选FillCenter,在Scene的Overdraw下可以查看到,不勾选FillCenter,overdraw会减少。

image

少用Effect功能

少用Outline,Tiled Sprite

outline额外生成7倍顶点

在一个空场景中,给Text添加outline之后,顶点数大约是未添加之前的7.5倍。

image

去掉outline之后,顶点数下降了很多。

image

Image不使用Tiled

type=simple时的顶点数

image

使用Tiled之后,顶点数也上涨很多。

image

参考资料

Unity官方论坛发布 Unity UI性能优化技巧

UGUI优化:批次合并源码分析及工具

工具:UI层级辅助工具,用于显示UI的层级、批次等数据,便于UI性能优化。使用者可以结合以上规则,分析当前UI元素排列顺序、材质贴图设置,优化UI Batching,减少UI Drawcall。

image

Unity UI优化小结

重建 是UGUI优化的关键 -- Unite2017嘉宾杨怀忠分享《UGUI深度优化》

免责声明:文章转载自《UGUI合批原理笔记》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Neor Profile SQL 中文汉化新型DenseBody框架:一张照片获得3D人体信息下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

UGUI Toggle控件

今天我们来看看Toogle控件, 它由Toogle + 背景 + 打勾图片 + 标签组成的. 它主要用于单选和多选 属性讲解: Is On: 代表是否选中. Toogle Transition: 在状态改变的时候,是否启动动画,颜色,等等过渡的效果. Graphic: 当选中和取消时候, 显示和隐藏的图片. Group: 代表当前Toggle(选择框)...

UGUI 实现Button长按效果(RepeatButton)

Tag:加入了一个延迟,在button按下状态一段时间后再開始 repeate using UnityEngine; using UnityEngine.Events; using UnityEngine.EventSystems; using System.Collections; public class RepeatPressEventTrig...

关于UGUI的Image,Text (转雨凇momo)

Image源码解读 接着我们来看看放在相同图集中的Sprite是如何合并DrawCall的,从原理上来讲,每个Mesh都需要给顶点设置UV信息,也就是说我们只需要将图集上的某个区域一一抠出来贴到Mesh正确的区域即可。如下代码所示,只要观察GenerateSimpleSprite()方法,UGUI通过Sprites.DataUtility.GetOute...

UGUI_屏幕适配

引用:http://www.xuanyusong.com/archives/3278#comments   1.可以选择的有三种: 1.Screen Space – overlay  此模式不需要UI摄像机,UI将永远出现在所有摄像机的最前面。我觉得overlay有问题,如果我想在UI前面放个东西就不行了,因为可能在UI前面放一个特效或者UI啥的。。 2....

关于 Unity UGUI 中修改 Mask 组件下 Image 等子节点组件的材质无效的问题

前几天同事做了一个效果,希望在原本使用了遮罩组件 Mask 的技能图标(让技能图标变成圆形)上在添加一个置灰的功能,但问题来了:因为是动态根据游戏中玩家的条件才动态置灰,以修改 Mask 下子节点 Image 组件的材质来实现的,但是实际上怎么修改也不起作用,呈现出的效果都只停留在第一次运行时的样子。 一开始我也以为是 shader 的问题,修改的 pro...

Unity琐碎(3) UGUI 图文混排解决方案和优化

感觉使用Unity之后总能看到各种各样解决混排的方案,只能说明Unity不够体恤下情啊。这篇文章主要讲一下个人在使用过程中方案选择和优化过程,已做记录。顺便提下,开源很多意味着坑,还是要开实际需求。 1. 方案选择 1 TextMeshPro Unity 最近公布收购了TextMeshPro并且免费开源给大家使用,估计还需要几个小版本才会完全融合到Unit...