일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 류와꾸수
- 퇴끼
- 일기장
- PunRPC
- 무리하지말자
- 생각
- 악마쨩
- Unity2D
- TMP
- Reimport
- 애옹개발자
- 나히다
- AeOngClickeer
- 만화
- c#
- 카카오워크
- 고민
- Fanart
- unity3d
- Unity
- 애옹
- 애니메이션
- 씹덕인가봐요
- Assembly-CSharp.dll
- art
- 움짤
- TextMeshPro
- 몬드
- 낙서
- Psyche
- Today
- Total
히가츠류의 보금자리
Unity Sprite Mask //Where is My cat? 본문
Unity 2018.4.7 버전
Sprite Mask를 사용한 예제!
Sprite Mask를 사용하면 일부 영역의 이미지를 나타내거나 없앨 수 있다.
이를 사용하면 숨바꼭질을 만들 수 있을 것 같아서 간단하게 실험해보았다.
우선 실험에 필요할 스프라이트 부터 구상해보았다.
<필요 Sprite>
1. 고양이를 숨겨줄 Front Object
2. 숨어있는 고양이나 물건이 될 Middle Object
3. 고양이가 안에 있다는 느낌을 더 크게 줄 수 있는 Back Object
4. 아무 상호작용이 없을 배경용 Background
필요 스프라이트를 작업하기 위해
그림 폴더를 크게 4가지로 나눠 작업한 다음 개별적으로 저장했다.
(ClipStudio로 작업)
게임이었다면 고양이를 찾아서 클릭할 때마다 사라지면서 점수가 올라야하므로
사물 하나하나 별도 저장해야 하는 게 맞겠지만, 지금은 그냥 실험용이니 통째로 저장했다.
Unity2D 프로젝트를 만들어준 후, 이미지들을 넣고 각각 이름을 정해줬다.
그 후 Sprite Rederer에 있는 Order in Layer를 통해 이미지가 보이는 순서를 정해줬다.
(Order in Layer의 숫자가 높을 수록 먼저 보이게 됨.)
그 후 Hierarchy창에 오른쪽 클릭을 해서 2D Object > Sprite Mask를 생성해줬다.
Sprite Mask를 생성하면 다른 오브젝트들에 있는 Sprite Renderer에 Mask Interaction이 생기는데,
이를 설정하면 Sprite Mask와 어떤 관계가 되는지 설정할 수 있다.
None : 아무 상호작용 없음
Visible Inside Mask : 이 객체는 Sprite Mask와 닿아있는 곳만 보임.
Visible Outside Mask : 이 객체는 Sprite Mask와 닿아있는 곳만 투명해짐.
정확히는 닿아있는 부분이 보이고 안보이고 하는게 아니라
카메라가 Sprite Mask를 통해서 물체를 보는 느낌이다. 3D버전을 보면 더 쉽게 알 수 있다.
↓3D 영상을 보면 더 쉽게 이해할 수 있다.
★고로 Sprtie Mask는 카메라와 Sprite Object 사이 있어야한다. 순서 주의.
Sprite Renderer에 Mask Interaction를 설정한 후
Sprite Mask와 관계를 정하고 Sprite Mask 객체를 설정해줬다.
Sprite Mask에 Sprite를 대충 동그라미(Knob)으로 설정한 후, Scale로 눈에 보일만한 크기로 조정했다.
Sprite Mask가 마우스를 따라다니기 위해 Follow Mouse라는 Script를 작성해줬다.
//MouseSpriteMask가 마우스를 따라다니게 하는 주요 코드
void Update()
{
Vector3 target = Input.mousePosition;
target += new Vector3(0,0,1);
transform.position = Camera.main.ScreenToWorldPoint(target);
}
원래는 프로그램의 과부하를 막기위해 Update말고 Coroutine을 쓰는게 좋겠지만
실험용이라서 스킵했다.
<결과>
매우 귀여웠다.
추후에 시간이 된다면 간단한 고양이 찾기 게임을 만들어볼 예정이다.
'Programming > Unity 2D' 카테고리의 다른 글
ScrollView(ScrollRect)와 Button의 드래그/스크롤(OnDrag)에 대한 문제 해결법 (6) | 2021.04.25 |
---|---|
코루틴(Coroutine)을 이용하여 1초 마다 오브젝트 소환 (0) | 2020.06.11 |