데이터를 다룰 때 종종 중복된 값이 문제를 일으키곤 합니다. LINQ에서 제공하는 Distinct() 메서드는 이러한 중복을 쉽게 제거해줍니다. Distinct()의 사용법과 다양한 활용 예제를 살펴보겠습니다.Distinct()란?Distinct()는 컬렉션 내의 중복된 요소를 제거하고 고유한 요소만 반환하는 LINQ 메서드입니다.using System;using System.Linq;using System.Collections.Generic;class Program{ static void Main() { var numbers = new List { 1, 2, 2, 3, 3, 3, 4, 4, 4, 4 }; var uniqueNumbers = numbers.Distinc..
StateMachineBehaviour란?StateMachineBehaviour는 특정 State에 진입하자마자, 혹은 빠져나가기 직전 등 각 State의 상황에 따라 어떠한 코드를 자동으로 실행할 수 있도록 도와주는 스크립트입니다. StateMachineBehaviour는 State 입·출력, 업데이트 이벤트 등 다양한 콜백을 제공합니다. OnStateEnter, OnStateUpdate, OnStateExit 등은 물론, Transition시점에 호출되는 이벤트도 다룹니다.더보기🔽Animator란?Unity의 Animator는 State단위로 움직임을 정의합니다. “(Transition) Condition”과 “Animation Clip”을 활용하여 각 State를 서로 연결합니다. StateM..
Meta Avatar SDK 31버전부터는 Avatars 2.0의 도입으로 인해, 3인칭 뷰에서 아바타가 다리를 가지게 되었습니다. 아바타 다리가 생김에 따라 아바타에 적절한 애니메이션이 필요하게 되었는데요. 예를 들어, 점프, 걷기, 뛰기 등.아바타를 더 생동감 있게 만들기 위해, OvrAvatarAnimationBehavior라는 새로운 컴포넌트를 사용하여 아바타에 전신 로코모션을 추가할 수 있게 되었습니다.OvrAvatarAnimationBehavior컴포넌트는 아바타가 환경에 맞게 움직일 수 있도록 하는 애니메이션 컨트롤러를 구현하며, 헤드셋의 움직임을 기반으로 애니메이션을 작동시킬 수 있습니다. 또한, 커스텀 전신 애니메이션을 사용할 수도 있습니다.전신 로코모션으로 아바타 애니메이션 활성화Ava..
C#은 null 참조 에러(null reference exception)를 방지하기 위해 널 허용 참조 타입(nullable reference type)을 도입했습니다. 이에 따라, 컴파일러는 변수가 널(null)일 가능성이 있는 경우 경고를 표시합니다. 하지만 개발자가 변수가 절대로 널이 아님을 확신하는 경우, 컴파일러의 경고를 무시하고 이를 명시적으로 나타내기 위해 널 허용 연산자(null-forgiving operator, !)를 사용할 수 있습니다.널 허용 연산자란?널 허용 연산자(!)는 C#에서 널 검사 경고를 억제하는 연산자입니다. 이를 통해 컴파일러가 "이 변수는 널일 수도 있다"고 경고하는 상황을 개발자가 강제로 무시할 수 있습니다.string? nullableString = null;//..
프로그래밍할 때 종종 사용하는 용어 중 TearDown과 Dirty는 맥락에 따라 다른 의미로 쓰이지만, 각각의 개념은 개발 과정에서 중요합니다. 이번 글에서는 이 두 용어의 의미와 사용 예를 정리해보겠습니다.TearDownTearDown은 설정된 상태를 초기화하거나 제거하는 과정을 의미합니다. 이는 특정 작업이 완료된 후 남아 있는 자원을 정리하거나, 테스트 환경을 원래 상태로 복구하는 데 사용됩니다.예시Unity의 Test Framework에서 TearDown은 테스트가 끝난 후 실행되는 메서드입니다. 테스트 중 생성된 오브젝트나 데이터를 정리해, 다음 테스트가 영향을 받지 않도록 해줍니다.using UnityEngine;using UnityEngine.TestTools;using NUnit.Fram..
플레이어가 여러 명일 경우 “어떤 순서”로 처리할지 고민이 생길 수 있습니다. 대표적으로 플레이어가 네트워크에 접속하는 순서, 혹은 특정 인덱스 기준으로 정렬하고 싶을 때가 있죠.Runner.ActivePlayers는 현재 게임(세션)에 접속해 있는 모든 플레이어 목록을 제공합니다. 여기에 OrderBy(p => p.AsIndex)를 붙이면, 플레이어를 “Index가 낮은 순”부터 정렬합니다.Index가 낮을수록 먼저 접속했거나, Fusion2 내부에서 먼저 할당된 플레이어를 의미합니다. foreach (var playerRef in Runner.ActivePlayers.OrderBy(p => p.AsIndex)){ // 인덱스 순서대로 처리하고 싶은 로직}
Meta SDK를 활용하여 프로젝트를 개발할 때, Meta 플랫폼의 유저 이름을 받아오는 기능에 대해 알아보고자 합니다. 또한 Entitlement, PlatformInfo, Platform이 무엇인지 알아보고, Oculus ID를 통해 최종적으로 유저 이름을 받아오는 방법을 공유하고자 합니다.Entitlement이란?Entitlement는 Meta 플랫폼에서 사용자의 소프트웨어 사용 권한을 확인하는 과정입니다. 사용자가 특정 애플리케이션에 접근할 권한이 있는지를 검증하는 단계로, 보안상 매우 중요한 역할을 합니다. Entitlement 검사는 일반적으로 다음과 같은 상황에서 이루어집니다.사용자가 구매한 애플리케이션에 대한 라이선스 확인애플리케이션의 불법 복제 방지Meta SDK는 이러한 과정(Entit..
Meta Avatar 움직임을 네트워크를 통해 동기화하기 위해 RecordStreamData와 ApplyStreamData 메서드, StreamLOD와 같은 기능을 제공합니다. RecordStreamDatapacket.dataByteCount = _localAvatar.RecordStreamData_AutoBuffer(lod, ref packet.data); //예시RecordStreamData 메서드는 아바타의 현재 상태(움직임과 표정 등)를 캡처하여 이진(binary) 형식으로 압축합니다. 생성된 데이터는 네트워크를 통해 전송되어 특정 시점(=스냅샷)의 아바타 상태를 나타냅니다.ApplyStreamDataavatar.ApplyStreamData(tempStreamDatas); //예시네트워크를 통해 ..
'I Am Cat' 게임은?'I Am Cat'은 플레이어가 고양이가 되어 할머니의 집을 탐험(망가트리는?ㅋㅋ)하는 게임입니다. 집안 곳곳을 돌아다니며 물건을 떨어뜨리고, 가구를 긁고, 심지어 할머니와 숨바꼭질을 할 수도 있습니다.모든 오브젝트는 물리 기반으로 이루어져 있어 몰입감과 현실감을 더해줍니다.유튜브 영상주요특징고양이의 시점에서 할머니 집을 탐험하며, 점프하고, 물건과 상호작용하며, 집안의 사소한 말썽을 부리는 등의 행동을 통해 고양이의 일상을 체험할 수 있습니다. 고양이를 키우는 주인님이 계신다면 꼭 한 번 고양이의 삶을 살아보세요... 할머니의 집에는 다양한 비밀과 퀘스트가 존재하며, 플레이어는 자유롭게 집안을 돌아다니며 다양한 상호작용을 경험할 수 있습니다. 상호작용을 통해 미니 게임이나 퍼..
Green Hell VR은?최대 4명의 친구들과 생존 기술로 야생 열대우림을 탐험하고, 사냥을 하고, 포식자들과 적대적인 부족의 위협으로부터 살아남는 생존게임입니다. Green Hell VR은 가장 정통적인 스토리 중심의 VR 서바이벌 게임으로, 현실적인 생존 기술들을 이용해야 합니다. 넓디 넓은 아마존 정글맵에 존재하는 야생 동물로부터 살아남아야하며 필요한 모든 것을 수집, 제작, 운반하여야합니다. Green Hell VR의 전체 스토리 캠페인에서 실종된 아내를 찾아 떠나는 인류학자 제이크 히긴스의 스릴 넘치는 이야기를 따라가는 내용입니다. 후기 밤과 낮이 존재하는 메커니즘, 그리고 정말 현실적인 생존 방식이 마음에 들었습니다.하지만, 텍스처가 멀미를 유발했고 VR로 오래 플레이 하기에는 불편한 점이 ..
게임 개발을 하다 보면, 배열(혹은 리스트)의 데이터를 복사해야 할 때가 종종 있습니다.그런데 C#에서 배열은 참조 타입이라 얕은 복사(Shallow Copy)와 깊은 복사(Deep Copy)가 존재하여 사용할 때 혼동될 수 있습니다. Unity 프로젝트에서 발생할 수 있는 사례로 알아보겠습니다. 얕은 복사(Shallow Copy)란?“원본과 같은 데이터를 가리키는 참조만 복사한다.”즉, 배열 변수가 가리키는 메모리 주소(참조)만 복사하는 방식입니다. 원본 배열과 복사본 배열은 동일한 실체(데이터)를 공유하므로, 한쪽을 변경하면 다른 쪽에도 영향이 갑니다.void Start(){ int[] originalArray = { 1, 2, 3, 4 }; int[] shallowCopy = origin..
VR로 게임을 하다보면 UI가 선명하지 않아서 보기 불편한 적이 많으셨죠? 특히 2D UI의 경우 Text가 읽기 매우 불편한데요, 오늘 OVR Overlay 컴포넌트를 이용해서 약간 해결해보고자 합니다.OVROverlay는 Compositor Layer를 사용해서 텍스처를 애플리케이션 렌더링 경로를 거치지 않고 직접 디스플레이로 전달하므로, CPU와 GPU 리소스를 절약하면서 선명한 이미지를 제공하도록 도와주는 컴포넌트입니다.Compositor Layer란?Compositor Layer는 VR 애플리케이션의 렌더링 과정을 최적화하여 텍스처, UI, Video와 같은 요소를 효율적으로 디스플레이에 출력하는 방식입니다.Compositor Layer 방식은 Eye Buffer(전통적인 VR 렌더링 파이프라인..
Meta Avatar SDK 버전이 29 넘게 나온거 알고 계시나요?24버전과 29버전의 가장 큰 차이는 캐릭터의 비주얼 부분인데요. 좌측 사진이 Meta Avatar 1세대이고, 우측 사진이 Meta Avatar 2세대입니다.좀 더 사실적인 느낌을 보여주고 있습니다.Oculus 플랫폼 SDK를 비동기적으로 초기화Core.AsyncInitialize()Oculus 플랫폼을 초기화하는 것은 Oculus의 다양한 기능과 서비스에 접근할 수 있도록 하기 위함입니다. Oculus 서비스에는 사용자 인증, 스토어 접근, 소셜 기능, 클라우드 저장소 등이 있습니다. 사용자가 애플리케이션을 사용할 권한이 있는지 확인Entitlements.IsUserEntitledToApplication()정품 사용자만이 애플리케이션..
Meta XR Haptics SDK 패키지 Example을 다운받으시면 Haptic SDK Play Sample 스크립트를 발견하실 수 있습니다.해당 스크립트는 Haptic Clip Player Class을 이용해서 Haptic을 사용하는 예제가 담겨 있는데요. 해당 스크립트에 대해서는 다루지 않겠습니다.이번 포스팅에서는 Haptic Clip Player Class에 대해서만 알아보겠습니다.Haptic Clip Player 클래스란?Haptic Clip Player는 Meta Quest Controller의 진동을 제어하는 유틸리티 클래스입니다.Haptic Clip Player의 핵심 기능에는 다음과 같습니다. 메서드/프로퍼티 기능 설명 특징 Play(Controller)할당된 HapticClip을 ..