Chapter 12-7. 기타 : 타이틀 메뉴(+ 버튼 이벤트, Scene 간의 이동)
Categories: Unity Lesson 3
Tags: Unity Game Engine
인프런에 있는 케이디님의 [유니티 3D] 실전! 생존게임 만들기 - Advanced 강의를 듣고 정리한 필기입니다. 😀
🌜 강의 들으러 가기 Click
🚀 타이틀 메뉴 씬 만들기
기존에 내내 작업했던 “Sample” 씬의 이름을 GameStage
로 변경하였고, 타이틀 메뉴 씬으로 쓸 새로운 씬 GameTitle
을 생성해주었다. (우클 - Create - Scene)
🚀 타이틀 메뉴 UI 만들기
- 캔버스 (WorldSpace 모드)
- 패널 UI (검정색, 화면 다 덮을만큼 크게)
- Title 텍스트
- Start, Load, Exit 텍스트
- 버튼 컴포넌트 추가
- 패널 UI (검정색, 화면 다 덮을만큼 크게)
✈ 카메라 맞추기
현재 씬 화면에 있는 상태 그대로를 메인 카메라가 찍게 하려면 메인 카메라 오브젝트를 누르고 Ctrl+Shift+F
단축키를 누르면 된다. 현재 씬에서 보고 있는 화면 그대로를 카메라가 찍게 된다.
✈ 버튼 애니메이션
3 개의 버튼에 모두 똑같이 적용해준다.
버튼의 Transition을 Color Tint 에서 Animation으로 바꾼다. 그러면 밑에 “Audo Generate Animation” 버튼이 생긴다.
이렇게 버튼에 자동으로 Animator 컴포넌트도 붙게 된다. 위에서 “Audo Generate Animation” 버튼을 통해 생성한 버튼 애니메이션 컨트롤러를 할당해준다.
“Audo Generate Animation” 버튼을 누르고 애니메이션 컨트롤러를 생성하면 자동으로 이렇게 “Pressed”, “Highlighted” 등등 버튼과 관련된 애니메이션 클립들과 위와 같은 내용의 컨트롤러를 자동으로 만들어준다.
버튼에 커서를 올렸을 때인 “Highlighted” 애니메이션 클립을 녹화하여 만들자. 버튼에 커서를 올리면 자동으로 “Highlighted” 애니메이션 클립 재생이 되게끔 버튼 애니메이션 컨트롤러에 트랜지션이 짜여져 있다. 버튼에 커서를 올리면 10 프레임 때쯤 크기가 커진다. 애니메이션 재생으로 서서히 10프레임으로 갈 수록 커질 것이다.
버튼을 눌렀을 때인 “Pressed” 애니메이션 클립을 녹화하여 만들자. 버튼을 누르면 자동으로 “Pressed” 애니메이션 클립 재생이 되게끔 버튼 애니메이션 컨트롤러에 트랜지션이 짜여져 있다. 버튼을 누르면 15 프레임 때쯤 크기가 더 커지고 투명해진다.(알파값 0) 애니메이션 재생으로 서서히 15프레임으로 갈 수록 투명해지고 커질 것이다.
애니메이션 클립들은 반복 재생을 해제해준다.
📜Title
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.SceneManagement;
public class Title : MonoBehaviour
{
public string sceneName = "GameStage";
public void ClickStart()
{
Debug.Log("로딩");
SceneManager.LoadScene(sceneName);
}
public void ClickLoad()
{
Debug.Log("로드");
}
public void ClickExit()
{
Debug.Log("게임 종료");
Application.Quit();
}
}
“GameTitle” 타이틀 메뉴 씬의
Canvas
에 붙인다.
Start 버튼을 눌렀을 때 불러올 씬은 “GameStage” 씬. SceneManager.LoadScene
함수를 통해 씬의 이름을 넘겨주면 그 씬을 불러올 수 있다. CLickLoad 함수는 다음 포스트에서 구현.
🚀 씬 빌드 세팅
File - Build Settings 에 빌드할 두 씬을 추가해준다. 꼭 추가해주어야 한다!!!
🌜 개인 공부 기록용 블로그입니다. 오류나 틀린 부분이 있을 경우
언제든지 댓글 혹은 메일로 지적해주시면 감사하겠습니다! 😄
Leave a comment