Unity性能优化-2d游戏的DrawCall

一、UI

UI算drawcall是按照Hierarchy面板 优先深度遍历后检查相邻是否材质相同,如:

Canvas

├─ BackgroundImage (Image)

├─ ScrollView

│ └─ Viewport

│ └─ Content

│ ├─ Images

│ └─ Texts

├─ PopupButton (Image)

└─ PopupButtonLabel (TMP)

深度优先展开结果是:

BackgroundImage (Image)

Content.Sprites.* (Image)

Content.Texts.* (TMP)

PopupButton (Image)

PopupButtonLabel (TMP)

我们需要做的是,让相同材质的UI尽量相邻,放到一个空物体下,比如

Canvas

|------ImageAs

|------Texts

|------ImageBs

|------TextsB

一个图集中的sprite当然也被视为同一个材质。

二、2d游戏

对所有会画到一个相机上的Renderer(SpriteRenderer / TilemapRenderer / ParticleSystem 等):

  1. 先按Sorting Layer排

    • 在 Project Settings → Tags and Layers 里你定义的那几个 Layer:

      • Default

      • Background

      • Player

      • Front

      • UI

    • 层级列表从上到下:越靠下的,越后画 → 越在"上面"

    • 也可以用 renderer.sortingLayerName / sortingLayerID 改。

  2. 同一个 Sorting Layer 内:按 Order in Layer 排

    • SpriteRenderer.sortingOrder(Inspector 的 "Order in Layer")

    • 数字越大 → 越后画 → 越在"上面"。

  3. 同一个 Layer + 同一个 Order 时:看"距离相机"

    • 默认是按 Z 轴 距离相机排序:离相机更近的,后画。

    • 2D 模式通常相机在 (0, 0, -10),Z 越大越离相机越近(-9 > -10)。

    • Project Settings → Graphics → Transparency Sort Mode 可以改成:

      • Default(用 Z)

      • Custom Axis(比如 2D 里常用 Y 轴,让 Y 越小越在上面之类)

所以一般,一个SortingLayer的都在一个图集里,或将一个图集的放在一个SortingLayer和Order。

相关推荐
ZK_H14 小时前
嵌入式c语言——关键字其6
c语言·开发语言·计算机网络·面试·职场和发展
fei_sun16 小时前
面经、笔试(持续更新中)
fpga开发·面试
aqiu~17 小时前
VSCode编辑器用于Unity项目
vscode·unity
Yuk丶19 小时前
UE4客户端开发技术问题汇总
面试·ue4·图形学·ue4客户端开发
yuki_uix20 小时前
重排、重绘与合成——浏览器渲染性能的底层逻辑
前端·javascript·面试
何陋轩20 小时前
OpenAI Codex深度解析:终端里的AI代码特工,一个指令重构整个项目
人工智能·面试
架构师老Y20 小时前
013、数据库性能优化:索引、查询与连接池
数据库·python·oracle·性能优化·架构
yuki_uix20 小时前
虚拟 DOM 与 Diff 算法——React 性能优化的底层逻辑
前端·react.js·面试
yuki_uix20 小时前
从输入 URL 到页面显示——浏览器工作原理全解析
前端·面试
im_AMBER1 天前
手撕发布订阅与观察者模式:从原理到实践
前端·javascript·面试