【Unity】性能优化:UI的合批 图集和优化

在这里插入图片描述

目录

  • 前言
  • 一、合批测试
  • 二、图集

前言

注意:DC指的是Draw Call。
温馨小提示:Frame Debugger 窗口(菜单:Window > Analysis > Frame Debugger)会显示绘制调用信息,并允许您控制正在构建的帧的“回放”。

一、合批测试

首先看第一种情况 相同图片的情况 这里是使用了四个Image,都使用同一张图
在这里插入图片描述

相同图片 z轴相同的合批
在这里插入图片描述

接下来看一下FrameDebugger看一下DC情况
在这里插入图片描述
👆看到DC只有一次,引擎自动对这些使用相同图片的Image进行了合批处理,一次画完

下面在看另一种情况 相同图片不同Z轴

在这里插入图片描述
👆每个Image的Z轴都不相同

和上面的摆放比较类似,就是4个物体的Z轴各不相同,在此查看一下FrameDebugger,发现DC和上面的一样
在这里插入图片描述
👆在这个情况Z轴的不同是不影响合批的,合批依旧发挥作用

那在看下面一种情况,在Image之间插入其他Text物体,也就是说,这几个物体上下的Z轴都不相同,看看会如何
在这里插入图片描述

相同图片Z轴不同 之间插入文本
在这里插入图片描述

在来看一下FrameDebugger
在这里插入图片描述
👆可以看到每个UI都需要一次DC,没有任何的合批

👇下面在做一点小改动,把所有Z轴都设为0,这个时候合批又起作用了,DC变为2
在这里插入图片描述

下面在做一点小改动,仅仅把Text都放在Image的后面
在这里插入图片描述

在这里插入图片描述
👆这个时候会合批,所有图片一次,Text又一次,合批又发挥了作用

结论:这里我发现原本能够被合批的UI即使Z轴不同,也能被合批,不受Z轴影响,但是原本可以合批的UI之间插入了其他Z轴不同的UI,就会打断合批。

👇下面在看另一种情况 ,也就是UI之间的遮挡,这也会影响合批(所有物体Z轴相同情况下)
在这里插入图片描述

上面是三个完全一致的Image,但是前两个Image之间夹了一个Text。
在这里插入图片描述

在这里插入图片描述
第一次DC画最左侧的Image,第二次DC绘制Text,第三次DC绘制剩下的Image,中间遮挡的Text会中断DC,这个也很好理解,被挡住了的话,需要要逐层绘制,这当然也会影响合批。

二、图集

Sprite Editor 图集插件的安装:https://blog.csdn.net/weixin_45961836/article/details/145359732

👇下面在看一下不同图片的情况(所有物体Z轴相同情况下)
在这里插入图片描述

在这里插入图片描述
👆一个Image绘制一次,有几种图片就DC几次

那实际开发中,基本都是用的不同的图片,为了合批,就得使用图集。
现在应该都使用新版图集了,老的spritetag的方式应该弃用了。

下面需要在项目设置中打开图集功能Editor->Project Setting->Editor 下面Sprite Packer选择Always Enabled

在这里插入图片描述

如果不开的话Atlas就会有如下的提示,告诉你如何打开

在这里插入图片描述

下面可以右键Create->Sprite Atlas 来创建一个图集
在这里插入图片描述

在这里插入图片描述

图集的基础使用这里就不再讲解了,图集的优化必须在Play Mode下才能看到

还是上面四张图,区别就是使用了图集,DC就只有一次了👇
在这里插入图片描述

详细查看可以看到使用的图片并不是单张图片了,而是一整张图集资源了

在这里插入图片描述

如果有用到跨多张图集的的资源的话,相对应的DC也会增加
之前的项目都是这样使用图集的,每一个图片文件夹创建一个图集,那么现在可以这样用,一个面板就创建一个对应的Atlas,把面板用到的图片添加到这个图集上,这样可以大大节省GC。

在这里插入图片描述

下面看看实际项目中的使用

在这里插入图片描述
在这里插入图片描述

实际的DC就仅仅2次

在看看二级面板的情况,大体布局如下

在这里插入图片描述

现在看看DC情况

在这里插入图片描述

在这里插入图片描述

有3次DC,第一次是绘制半透明黑色面板,第二次绘制剩余图片,第三次是剩下的字。需要注意的是第一次DC。

在这里插入图片描述

这是因为我们使用了一个黑色半透明的背景

在这里插入图片描述
如果这样的话会使用一个默认资源,并且不能和图集合批,为了优化这个DC,改为使用一张4*4的白色方块图片,并打入到图集中去。下面看看优化后的DC

在这里插入图片描述在这里插入图片描述

在看看同时打开多个面板的情况,MainPanel打开这个二级菜单的情况,可以主要到的是需要一层一层绘制,也就是避免设计太多层级的UI

在这里插入图片描述

在这个情况下,所有UI的DC就只有4次,每个面板个2次

在这里插入图片描述

下面在看一下平时使用的UI优化

看一下下面这种情况,一个很常见的情况\

在这里插入图片描述

这是一个透明度为0的图片按钮,且使用了一个默认资源。他在DC里面的情况是这样的

在这里插入图片描述
会单独使用一个DC,当然你也可以和上面的说过的一样,选择一个打入图集的白兔,也能合批掉。但是还是会绘制一张看不见的区域,其实并不需要这样,这里可以像这样做

//不渲染但可以相应点击
public class NoOverdrawImage : Graphic
{public override void Rebuild(CanvasUpdate update){}
}   

向上面的Button就可以变成这样

在这里插入图片描述

不会发生绘制了,也不会发生Overdraw的情况

在看看ScrollView这一类的组件,或者说Mask的组件

在这里插入图片描述

这一类组件在DC的情况,

在这里插入图片描述
这个看不到的Mask也会占用一次DC

这个地方的解决方案是使用RectMask2D组件来代替,当然只能是矩形的情况下

另外还有一个优化就是打开全屏UI的时候,可以选择关闭主相机,只保留UI相机。可以使用一个基类来统一管理

另外即使在UI相机看不到的物体,也会被渲染并占用DC,就下下图这样,在外面摆了一大堆东西,这些全部会占用DC,可以先隐藏它们,等需要的时候在显式它们。

在这里插入图片描述

总结一下:
合批优化:

  1. UI中如非必要,Z轴统一设为0。如果有Z改变了,尽量通过Group来规整在一起
  2. 注意组件的遮挡关系,尤其是Text被Image遮挡的情况。
  3. 打图集。
  4. 图集的管理选择以单个面板来管理图集,而不是使用文件夹形式。
  5. Image组件不要选择None,也会使用一个默认图片且无法与图集合批,选用一张图片来统一使用并打入到图集中。
  6. 不要设计很多层级的UI,会全部绘制。

UI组件优化

  1. 不要使用透明为0的图片当作按钮,改用NoOverdrawImage来代替
  2. 使是RectMask2D来代替Mask
  3. 全屏UI关闭主相机,只保留UI相机
  4. UI相机看不到的物体也会被渲染,占用DC,可以先禁用它们

参考文献:https://zhuanlan.zhihu.com/p/364785849

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/15726.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【安当产品应用案例100集】037-强化OpenVPN安全防线的卓越之选——安当ASP身份认证系统

在当前数字化时代,网络安全已成为企业发展的重要组成部分。对于使用OpenVPN的企业而言,确保远程访问的安全性尤为重要。安当ASP身份认证系统凭借其强大的功能和便捷的集成方式,为OpenVPN的二次登录认证提供了理想的解决方案,特别是…

表单与交互:HTML表单标签全面解析

目录 前言 一.HTML表单的基本结构 基本结构 示例 二.常用表单控件 文本输入框 选择控件 文件上传 按钮 综合案例 三.标签的作用 四.注意事项 前言 HTML&#xff08;超文本标记语言&#xff09;是构建网页的基础&#xff0c;其中表单&#xff08;<form>&…

python卷积神经网络人脸识别示例实现详解

目录 一、准备 1&#xff09;使用pytorch 2&#xff09;安装pytorch 3&#xff09;准备训练和测试资源 二、卷积神经网络的基本结构 三、代码实现 1&#xff09;导入库 2&#xff09;数据预处理 3&#xff09;加载数据 4&#xff09;构建一个卷积神经网络 5&#xff0…

防御保护-----前言

HCIE安全防御 前言 计算机病毒 ​ 蠕虫病毒----->具备蠕虫特性的病毒&#xff1a;1&#xff0c;繁殖性特别强&#xff08;自我繁殖&#xff09;&#xff1b;2&#xff0c;具备破坏性 蠕虫病毒是一种常见的计算机病毒&#xff0c;其名称来源于它的传播方式类似于自然界中…

java和vue开发的图书馆借阅管理系统小程序

主要功能&#xff1a; 学生借书还书&#xff0c;管理员管理图书管理学生借书还书。系统显示在馆数量和图书总数量&#xff0c;借书时借书数量不可超过在馆数量&#xff0c;还书时需要输入归还数量&#xff08;可借2本书&#xff0c;归还的时候一本一本归还&#xff0c;可查看归…

【R】Dijkstra算法求最短路径

使用R语言实现Dijkstra算法求最短路径 求点2、3、4、5、6、7到点1的最短距离和路径 1.设置data&#xff0c;存放有向图信息 data中每个点所在的行序号为起始点序号&#xff0c;列为终点序号。 比如&#xff1a;值4的坐标为(1,2)即点1到点2距离为4&#xff1b;值8的坐标为(6,7)…

Oracle的学习心得和知识总结(三十三)|Oracle数据库数据库的SQL ID的底层计算原理分析

目录结构 注&#xff1a;提前言明 本文借鉴了以下博主、书籍或网站的内容&#xff0c;其列表如下&#xff1a; 1、参考书籍&#xff1a;《Oracle Database SQL Language Reference》 2、参考书籍&#xff1a;《PostgreSQL中文手册》 3、EDB Postgres Advanced Server User Gui…

将DeepSeek接入Excel实现交互式对话

引言 将DeepSeek接入Excel&#xff0c;为你带来前所未有的交互体验&#xff01;“哪里不懂&#xff0c;选中哪里”&#xff0c;然后直接在侧边栏对话框向DeepSeek发问&#xff0c;非常地方便&#xff01; 案例演示 设置接入方式 既可以通过本地部署的DeepSeek接入Excel&#…

在npm上传属于自己的包

最近在整理代码&#xff0c;上传到npm方便使用&#xff0c;所以学习了如何在npm发布一个包&#xff0c;整理写成一篇文章和大家一起交流。 1、注册npm账号 npm | Home 2、确保是登录状态 &#xff08;在包目录下&#xff0c;终端执行 npm login) 按enter键自动打开页面&…

JS宏进阶:XMLHttpRequest对象

一、概述 XMLHttpRequest简称XHR&#xff0c;它是一个可以在JavaScript中使用的对象&#xff0c;用于在后台与服务器交换数据&#xff0c;实现页面的局部更新&#xff0c;而无需重新加载整个页面&#xff0c;也是Ajax&#xff08;Asynchronous JavaScript and XML&#xff09;…

【快应用】多语言适配案例

【关键词】 多语言,$t 【问题背景】 快应用平台的能力会覆盖多个国家地区,平台支持多语言的能力后,可以让一个快应同时支持多个语言版本的切换,开发者无需开发多个不同语言的源码项目,避免给项目维护带来困难。使用系统默认的语言,开发者配置多语言的方式非常简单,只…

PyQt学习记录

0. 安装配置 0.1 安装相关库 首先打开你的PyCharm程序&#xff0c;然后新建一个目录用于学习&#xff0c;其次在terminal中输入 pip install pyqt5如果你不具有科学上网能力&#xff0c;请改为国内源 pip install pyqt5 -i https://pypi.douban.com/simple然后安装pyqt相关…

【多模态大模型】系列3:语义分割(LSeg、GroupViT)

目录 1 LSeg2 Group ViT 1 LSeg LANGUAGE-DRIVEN SEMANTIC SEGMENTATION LSeg是第一篇将CLIP应用于语义分割的论文。它的分割的效果拔群&#xff0c;容错能力也很高&#xff1a; 模型总览图跟CLIP很像&#xff1a; 对于图像链路&#xff1a;输入一张图片&#xff0c;进入分割…

【深度学习】多目标融合算法(四):多门混合专家网络MMOE(Multi-gate Mixture-of-Experts)

目录 一、引言 二、MMoE&#xff08;Multi-gate Mixture-of-Experts&#xff0c;多门混合专家网络&#xff09; 2.1 技术原理 2.2 技术优缺点 2.3 业务代码实践 2.3.1 业务场景与建模 2.3.2 模型代码实现 2.3.3 模型训练与推理测试 2.3.4 打印模型结构 三、总结 一、…

自动驾驶数据集三剑客:nuScenes、nuImages 与 nuPlan 的技术矩阵与生态协同

目录 1、引言 2、主要内容 2.1、定位对比&#xff1a;感知与规划的全维覆盖 2.2、数据与技术特性对比 2.3、技术协同&#xff1a;构建全栈研发生态 2.4、应用场景与评估体系 2.5、总结与展望 3、参考文献 1、引言 随着自动驾驶技术向全栈化迈进&#xff0c;Motional 团…

使用 AlexNet 实现图片分类 | PyTorch 深度学习实战

前一篇文章&#xff0c;CNN 卷积神经网络处理图片任务 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 本篇文章内容来自于 强化学习必修课&#xff1a;引领人工智能新时代【梗直哥瞿炜】 使用 AlexNet 实现图片分类…

C# Winform 使用委托实现C++中回调函数的功能

C# Winform 使用委托实现C中回调函数的功能 在项目中遇到了使用C#调用C封装的接口&#xff0c;其中C接口有一个回调函数的参数。参考对比后&#xff0c;在C#中是使用委托(delegate)来实现类似的功能。 下面使用一个示例来介绍具体的使用方式&#xff1a; 第一步&#xff1a;…

攻防世界33 catcat-new【文件包含/flask_session伪造】

题目&#xff1a; 点击一只猫猫&#xff1a; 看这个url像是文件包含漏洞&#xff0c;试试 dirsearch扫出来/admin&#xff0c;访问也没成功&#xff08;--delay 0.1 -t 5&#xff09; 会的那几招全用不了了哈哈&#xff0c;那就继续看答案 先总结几个知识点 1./etc/passwd&am…

ArgoCD实战指南:GitOps驱动下的Kubernetes自动化部署与Helm/Kustomize集成

摘要 ArgoCD 是一种 GitOps 持续交付工具,专为 Kubernetes 设计。它能够自动同步 Git 仓库中的声明性配置,并将其应用到 Kubernetes 集群中。本文将介绍 ArgoCD 的架构、安装步骤,以及如何结合 Helm 和 Kustomize 进行 Kubernetes 自动化部署。 引言 为什么选择 ArgoCD?…

尝试一下,交互式的三维计算python库,py3d

py3d是一个我开发的三维计算python库&#xff0c;目前不定期在PYPI上发版&#xff0c;可以通过pip直接安装 pip install py3d 开发这个库主要可视化是想把自己在工作中常用的三维方法汇总积累下来&#xff0c;不必每次重新造轮子。其实现成的python库也有很多&#xff0c;例如…