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。

相关推荐
Lee川1 小时前
从异步迷雾到优雅流程:JavaScript异步编程与内存管理的现代化之旅
javascript·面试
晴殇i3 小时前
揭秘JavaScript中那些“不冒泡”的DOM事件
前端·javascript·面试
绝无仅有3 小时前
Redis过期删除与内存淘汰策略详解
后端·面试·架构
绝无仅有3 小时前
Redis大Key问题排查与解决方案全解析
后端·面试·架构
AAA梅狸猫4 小时前
Looper.loop() 循环机制
面试
AAA梅狸猫4 小时前
Handler基本概念
面试
Wect5 小时前
浏览器缓存机制
前端·面试·浏览器
掘金安东尼6 小时前
Fun with TypeScript Generics:玩转 TS 泛型
前端·javascript·面试
掘金安东尼6 小时前
Next.js 企业级落地
前端·javascript·面试
掘金安东尼6 小时前
React 性能优化完全指南 2026
前端·javascript·面试