NGUI UI DrawCall 优化
Posted smallboat
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了NGUI UI DrawCall 优化相关的知识,希望对你有一定的参考价值。
首先要明确Unity中的drawcall定义:
每次引擎准备数据并通知GPU的过程称为一次Draw Call。
Unity(或者说基本所有图形引擎)生成一帧画面的处理过程大致可以这样简化描述:引擎首先经过简单的可见性测试,确定摄像机可以看到的物体,然后把这些物体的顶点(包括本地位置、法线、UV等),(顶点如何组成三角形),变换(就是物体的位置、旋转、缩放、以及摄像机位置等),相关光源,纹理,渲染方式(由材质/Shader决定)等数据准备好,然后通知图形API——或者就简单地看作是通知GPU——开始绘制,GPU基于这些数据,经过一系列运算,在屏幕上画出成千上万的三角形,最终构成一幅图像。
NGUI中的UIWidget的显示顺序:
每一个UIWidget的显示顺序由depth值决定,跟z轴没关系,而这个depth值是由两部分组成的,一个是UIWidget所在的UIPanel的depth和UIwidget自身的depth值进行加权计算。
并且,UIPanel的权重非常大,可以认为,UIPanel的depth大的所有UIWidget比UIPanel的depth小的所有UIWidget比最后计算的depth一定大;NGUI合并drawcall是以UIWidget为最小单位并依据UIPanel来合并的,就是说在每一个UIPanel内部以UIWidget根据depth顺序合并统一图集元素drawcall;这样若是中间插有其他图集的UIWidget,NGUI将另起一个Drawcall来渲染。
以上是关于NGUI UI DrawCall 优化的主要内容,如果未能解决你的问题,请参考以下文章