학원에서 다른 학생을 볼때Raycast가 안 된다며 몇 시간을 붙잡고 보면LayerMask 설정을 잘못한 경우가 꽤나 많습니다. 직접 LayerMask 변수를 만들어 사용하면 괜찮긴한데,변수 하나 만드는 것과 Inspector에서 직접 설정 해야한다는 점이 개운하지 못합니다. LayerMask mask = 1 그렇다면 방법은 NameToLayer( )라는 메서드를 사용하고비트 연산을 하는 것인데,학원에서 배울정도면 비트 연산에 대해 낯설수 있습니다. 그것을 쉽게 해줄 방법은 아니지만,Raycast가 어떤 int형 매개변수를LayerMask 설정으로 사용하는 원리? 방법을 알게되면인상깊어서 앞으로의 실수는 없지 않을까 생각해봤습니다.using UnityEngine;public class RaycastTes..
Photon을 사용하여 매치메이킹을 구현하면서Room List를 보여줄 방법으로 Scroll View를 사용하기로 하였습니다.Scroll View, 별거 없을거라 생각하고 기회되면 한 번 쓰지... 하는 생각으로 미뤄두다가처음 사용하게 되었는데 꽤 쓸만한거 같습니다.깊게 고민하고 사용하지 않아서 그럴지도 모르지만간단하게나마 사용법에 대해 정리하려고 합니다. Canvas 생성은 생략하고,Scroll View를 만들게 되면 이런 식으로 생성됩니다. 최상위 객체인 Scroll View에는 Scroll Rect 컴포넌트가 있습니다. 이름만 보아도 기능에 대해 충분히 유추 가능한 것 같습니다. 먼저 두 bool 값에 대해 보면 체크한 축으로 스크롤이 가능합니다.체크를 해제하면 해당 축으로는 스크롤을 할 수 없습니..
우선 Sequence는 단일 객체가 아닌,다수의 객체에 대한 여러 트윈을 하나로 묶고등록한 순서대로 트윈을 재생하기 위해 사용합니다. Sequence sequence;Sequence는 변수 선언 시 null 상태입니다. sequence = DOTween.Sequence(); static으로 선언된 생성자가 있습니다.이 생성자를 통해 Sequence를 만듭니다. 시퀀스는 생성 즉시 자동으로 재생됩니다. sequence = DOTween.Sequence().Play();Play()를 사용해 시퀀스를 재생할 수 있지만 자동 재생입니다. sequence = DOTween.Sequence().Pause();이를 원치 않으면 트윈을 추가하면서 동시에 재생을 중단해야 합..
0. 코드전문using System.Collections.Generic;using UnityEngine;using UnityEngine.UI;using DG.Tweening;[RequireComponent(typeof(Canvas))]public class InfoUIController : MonoBehaviour{ readonly Queue infoUIs = new Queue(); public Image prefab; Image currentInfo = null; [SerializeField, Header("시작 위치")] RectTransform startPosition; [SerializeField, Header("목표 위치")] RectTransform tar..
0. 코드 전문123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166..
NetworkRoomManager에서 Start Host나 Start Client를 실행하면Offline Scene에서 Online Scene으로 이동합니다.이후에 벌어지는 일을 정리해봅니다. Online Scene으로 이동하면 NetworkRoomPlayer 객체가 생성됩니다.객체의 Start 구문에서 DontDestroyOnLoad(gameObject)가 실행됩니다. 그리고 싱글톤이 된 NetworkRoomManager의 RoomSlots에 자신을 추가합니다. RoomSlots은 NetworkRoomPlayer형 HashSet입니다.( HashSet : 중복 값을 허용하지 않는 고유한 값의 컬렉션)NetworkRoomManager의 RoomSlots을 조회하면 원하는 플레이어를 호출할 수 있겠습니다..
이제 잔상을 남길 수 있습니다. SkinnedMeshRenderer의 BakeMesh 메서드만 이해한다면 누구나 잔상을 만들 수 있습니다. 현재 SkinnedMeshRenderer가 참조하는 Mesh의 모습을 그대로 복제하여,매개변수의 Mesh mesh에 할당하는 식인가 봅니다. 이 작동 원리를 이해했다면 구현 방식을 쉽게 생각 해볼 수 있습니다.바로 잔상의 Mesh를 가진 객체를 계속 생성하는 것입니다. 1. 잔상을 남기고 싶은 순간마다 객체를 생성합니다. 객체에는 Mesh Filter와 Mesh Renderer가 필요하겠습니다.2. Mesh Filter에는 아까의 BakeMesh 메서드로 복제한 메쉬를, Mesh Renderer에는 복제한 메쉬가 사용할 Material을 할당합니다.3. 시간이 지나면..
오목 검출 알고리즘을 생각하던 중에문득 RaycastAll로 검출된 RaycastHit 배열의 요소가Ray의 시작점으로부터 가까운 순으로 반환되는지 궁금해져서 실험해 봤다. 생각대로 될 리가 없지 ㅋㅋㅋ 혹시나 했던 역시나, 뒤죽박죽으로 배열에 담겨 반환되었다. 그럼 거리 순으로 정렬하면 어떨까? System.Array.Sort(hits, (hit1, hit2) => hit1.distance.CompareTo(hit2.distance)); List를 사용할 때 Sort를 그저 오름차순 정렬에만 사용해서 몰랐는데,System.Array.Sort는 람다함수와 병행하면정렬할 수 없는 사용자 정의 객체를비교 메서드를 사용하여 기준에 따라 정렬할 수 있다. 7개의 큐브가 거리 순으로 정렬되었다. 이것이 Arr..