Canvas

2025. 11. 12. 02:00·🧊Unity Basic/UGUI

UI 는 게임의 사용자가 게임에 가장 직접적으로 마주하는 첫 번째 상호작용 요소이다.

게임을 떠나 어떤 프로그램이든 UI 가 존재하고 , 사용자는 UI 를 가장 먼저 마주하게 된다.

UI 는 게임에서 아주 중요한 역할을 한다. 

유저와 상호작용 하거나 , 게임의 상태를 유저가 빠르게 체크할 수 있도록 해준다.

UI 작업을 원활하게 하기 위해서는 , UI 가 캔버스에 어떻게 뿌려지는지를 알고 있어야 한다.

랜더링 되는 순서나 , 갱신 주기 등 캔버스의 내부 동작을 이해하고 있어야 한다.

 

Canvas

캔버스는 Unity UI 시스템 ( 특히 UGUI ) 를 그리는 공간 ( Rendering Area ) 이다.

모든 Button , Text , Image , Panel 같은 UI 요소들은 반드시 Canvas 하위에 있어야 화면에 표시된다.

즉 , UI 오브젝트의 루트 ( 최상위 부모 ) 이자 , 렌더링 기준 공간이라고 보면 된다.

  • 유니티 UI 에서 , 모든 UI 들을 담는 컨테이너 역할
  • 모든 UI 요소는 반드시 Canvas 하에 있어야 한다
    └ ( 예시 : 3D 오브젝트에 Image 컴포넌트를 준다고 작동하지 않는다 )
  • Transform 대신 RectTransform 을 들고 있다
Canvas ( UI 루트 )
 ├── Panel ( UI 그룹 )
 │    ├── Button
 │    ├── Image
 │    └── Text
 └── EventSystem ( 입력 처리용 )
  • Canvas : UI 를 실제로 그리는 공간
  • RectTransform : Canvas 내부에서 UI 위치 / 크기 제어 담당
  • EventSystem : 버튼 클릭 , 드래그 등 사용자 입력 처리 담당
    └ UI 이벤트 ( 버튼 클릭 , 드래그 , 터치 등 ) 을 관리하는 시스템
    └ 이 시스템이 없으면 터치나 버튼 클릭 같은 이벤트에 반응하지 않는다

 

 

Render Mode ( 렌더링 방식 )

 

1. 오버레이 ( Screen Space - Overlay )

  • 가장 기본 설정 , 어떤 3D에 객체에 의해서도 가려지지 않는다.
  • UI 가 카메라와 무관하게 화면 최상단에 표시된다.
  • 화면의 해상도에 맞춰 알아서 스케일이 조정된다.
  • ( 일반적인 메뉴 , HUD )

2. 카메라 ( Screen Space - Camera )

  • UI 가 지정된 카메라를 통해 렌더링된다.
  • ( 3D 카메라 시점 UI )

3. 월드 스페이스 ( World Space )

  • 캔버스를 마치 , 게임 오브젝트처럼 사용하고 싶을 때 사용한다.
  • UI 가 3D 오브젝트처럼 Scene 속에 존재
  • VR 과 같이 , UI 가 오브젝트에 붙어 있으면 좋을 때 사용한다.
  • ( NPC 머리 위 체력바 , 3D 보드 등 )

 

'🧊Unity Basic > UGUI' 카테고리의 다른 글

TMP 폰트 생성 및 적용  (0) 2026.02.23
UGUI  (0) 2025.10.21
'🧊Unity Basic/UGUI' 카테고리의 다른 글
  • TMP 폰트 생성 및 적용
  • UGUI
DevHoChan
DevHoChan
맨땅에서 시작하는 코딩 도전
  • DevHoChan
    Debugging Life
    DevHoChan
  • 전체
    오늘
    어제
    • 분류 전체보기 (374)
      • 🕹️Game Life (1)
      • 🖥️Computer Science (5)
      • 📖TIL (141)
        • 🔥Projects (16)
        • 💡DevTips (5)
        • 🤔발생한 문제와 해결 (5)
        • 🔮Unity Graphics (5)
        • 🎤Interview (3)
        • ✅CodingTest (9)
      • 🚀Game Release (4)
      • 🧊Unity Basic (58)
        • 📌용어 사전 (1)
        • 에디터&인터페이스 (3)
        • 디버그 (1)
        • 라이프사이클 (4)
        • 게임오브젝트 (4)
        • 프리팹 (1)
        • 오브젝트풀링 (4)
        • 애트리뷰트 (2)
        • 트랜스폼 (4)
        • 물리&충돌 (1)
        • 프레임&델타타임 (4)
        • 코루틴&이벤트 (7)
        • 수학&보정함수 (3)
        • 디자인패턴 (9)
        • UGUI (3)
        • 벡터 ( Vector ) (3)
        • 씬 ( Scene ) (2)
        • 데이터 관리 (2)
      • ⭐C Sharp (99)
        • 📌용어 사전 (1)
        • 📌문법 사전 (6)
        • 메모리 관리 (3)
        • 00. 문법 (17)
        • 01. 변수 (3)
        • 02. 자료형 (2)
        • 03. 연산자 (6)
        • 04. 조건문 (2)
        • 05. 반복문 (2)
        • 06. 배열 (3)
        • 07. 메서드(함수) (7)
        • 08. 열거형 (3)
        • 09. 구조체 (2)
        • 10. 참조 (2)
        • 11. 객체 지향 (11)
        • 12. 델리게이트 (3)
        • 13. 디자인 패턴 (7)
        • 14. LINQ (1)
        • 📂▼자료구조 (2)
        • 15-1. 제네릭 (3)
        • 15-2. 배열 (4)
        • 15-3. 리스트 (2)
        • 15-4. 스택과 큐 (2)
        • 15-5. 딕셔너리 해시테이블 (2)
        • 15-6. 트리와 그래프 (3)
      • 📊Algorithm (16)
        • BigO (2)
        • 정렬 (4)
        • 셔플 (2)
        • 탐색 (6)
        • 최적화 (1)
      • 📝Game Design (16)
      • 🤖​AI Tools (12)
        • AI 리뷰 분석 (6)
        • Player2 (0)
        • 3D 모델링 (1)
        • 2D 스프라이트 (0)
        • 이미지 (2)
        • 사운드 (1)
        • 동영상 (1)
        • 문서 (1)
      • 🌍Network (6)
      • 🌱Github (11)
        • 기본 개념 (7)
        • 명령어 (1)
        • 도구 활용 (1)
      • ⚙️Visual Studio (5)
        • 🔧설치 및 환경설정 (2)
        • ⌨️HotKey (1)
        • 🚨디버깅 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    algorithm
    CodingTest
    디자인패턴
    unity
    c#
    자료형
    GitHub
    유니티
    문법
    gamedesign
    자료구조
    메모리관리
    부트캠프
    게임기획
    OOP
    객체지향
    til
    csharp
    기획
    게임디자인
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
Canvas
상단으로

티스토리툴바