Unity性能优化 --- 减少OverDraw

OverDraw(过度绘制)就是GPU多次重复绘制同一像素点的操作。在Unity 中渲染的图像由数百万个像素组成,如果这些像素被多次绘制,那么会造成GPU极大的性能损耗。例如下图多个物体叠加放在一起

注:棕色越深的地方,过度绘制的次数越多。

怎样减少OverDraw?

1.减少不透明的物体绘制。

1.1由于几何体效率低下导致的过度绘制和自身相交的几何体因为在同一绘制调用中无法保证像素渲染顺序导致的过度绘制。

将几何体拆分成小物体,以便Unity的物体渲染排序。

1.2减少有相互遮挡物体的批处理使用。

2.减少透明物体的过度绘制。

2.1减少渲染的透明图层的数量,

2.2减少透明几何体占用的屏幕大小,

缩小透明对象的大小;从Sprite中删除100%透明像素;制作一个紧密网格,减少完全透明区域(如何做?可参考这篇文章 Unity中如何修改Sprite的渲染网格-CSDN博客)。

在使用紧密网格后,即使外边框靠近也不会发生过度绘制。

3.尽量减少粒子系统的透明图层。

4.尽量不使用全屏的后处理效果。

5.在移动端使用加法混合代替alpha混合。

6.在打开全屏UI窗口时关闭3D渲染的相机。

参考链接:

Unity 过度绘制:提高游戏的 GPU 性能 |TheGamedev.Guru 游戏开发大师

How to create custom sprite meshes to reduce overdraw, tri-count and improve performance in Unity 2D (youtube.com)

相关推荐
Mintopia5 分钟前
Web性能测试流程全解析:从概念到落地的完整指南
前端·性能优化·测试
叶智辽39 分钟前
【Three.js 粒子系统进阶】从1000到10万粒子,如何让画面既绚丽又流畅
性能优化·webgl·three.js
willow1 小时前
Webpack5基础与高级配置
webpack·性能优化
桦说编程2 天前
你的函数什么颜色?—— 深入理解异步编程的本质问题(上)
后端·性能优化·编程语言
JackyRoad2 天前
Prometheus-Grafana-vLLM监控实战指南
性能优化·grafana·监控
是梦终空5 天前
React Native 性能优化指南
react native·性能优化
侑虎科技6 天前
在UE5中,预测脚步IK实现-PredictFootIK
性能优化·unreal engine
bluceli8 天前
前端性能优化实战指南:让你的网页飞起来
前端·性能优化
冰_河8 天前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
叶智辽10 天前
【Three.js内存管理】那些你以为释放了,其实还在占着的资源
性能优化·three.js