Oculus Quest2 - Controller Move

Published: Dec 30, 2020 by BeatChoi

오큘러스 퀘스트2 컨트롤러로 이동하기

오큘러스 퀘스트2 컨트롤러를 이용하여 이동하는 방법을 알아봅니다. 이전시간에 배운 키 입력과 이번시간에 캐릭터 컨트롤러를 이용한 이동을 구현해봅니다.
이전과 동일하게 XR Toolkit을 활용합니다.

유니티3D 에디터에서

스크립트 생성

Oculus Input이라는 이름의 C# 스크립트를 생성합니다.
스크립트에 다음과 같이 작성합니다.

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
32
33
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.XR;
using UnityEngine.XR.Interaction.Toolkit;

public class OculusInput : MonoBehaviour
{
    public XRController controller = null;
    private CharacterController character;
    private GameObject _camera;
    private void Awake()
    {
        character = GetComponent<CharacterController>();
        _camera = GetComponent<XRRig>().cameraGameObject;
    }

    private void Update()
    {
        CommonInput();
    }

    private void CommonInput()
    {
        // Touchpad/Joystick position
        if (controller.inputDevice.TryGetFeatureValue(CommonUsages.primary2DAxis, out Vector2 position)) {
            var inputVector = new Vector3(position.x, Physics.gravity.y, z: position.y);
            var inputDirection = transform.TransformDirection(inputVector);
            var lookDirection = new Vector3(x: 0, _camera.transform.eulerAngles.y, z: 0);
            var newDirection = Quaternion.Euler(lookDirection) * inputDirection;
            character.Move(motion: newDirection * Time.deltaTime * 1f);
        }
    }
}
  • 선언부에 CharacterController character를 추가합니다.
  • Awake문에 character = GetComponent<CharacterController>()character변수를 채워줍니다.
  • 이전 강좌의 Oculus Quest2 - Controller Input에서 배운 코드 중 Joystick position항목에 작성합니다.
  • if문 안의 TryGetFeatureValue메소드의 두번째 인자인 Vector2 position을 확인합니다.
  • position값이 조이스틱의 방향이 되겠습니다.
  • inputVector값이 position의 x 및 y값, 즉 조이스틱의 방향값에 해당합니다.
  • inputDirectioninputVector벡터의 방향을 지정합니다.
  • lookDirection에는 카메라의 방향, 즉 VR로 바라보는 방향값을 지정합니다. 내가 현재 바라보는 방향입니다.
  • newDirection은 현재 바라보는 방향과 컨트롤러로 지정한 이동방향을 이용하여 결과적으로 내가 이동해야하는 방향을 계산합니다.
  • character.Move()메소드를 활용하여 newDirection방향으로 이동하는 로직을 생성합니다.

스크립트를 저장하고 유니티 에디터로 돌아옵니다.

유니티 에디터에서

XRRig오브젝트에 Character Controller컴포넌트를 추가합니다.
Oculus Input스크립트를 XRRig오브젝트에 인스턴스화 시킵니다.
Oculus Input스크립트가 인스턴스화가 되면 Controller변수 공란에 XRRig -> Camera Offset -> LeftHandController 를 연결시킵니다.


<01. Character Controller 컴포넌트 및 Oculus Input 스크립트 추가>

결과물

위 상단 플레이 버튼을 눌러서 테스트를 진행합니다.
왼쪽 컨트롤러의 조이스틱을 움직이는 방향대로 내 자신이 이동하는 것을 확인할 수 있습니다.


<02. 캐릭터의 이동>

Latest Posts

콘텐츠 개발 기법 - URP 환경에서 Bloom 및 Volume 포함한 화면 캡처
콘텐츠 개발 기법 - URP 환경에서 Bloom 및 Volume 포함한 화면 캡처

화면 캡처 :: Screen Capture

일반적으로 URP환경에서 Bloom 등의 Volume 이펙트들이 함께 캡처되지 않는 현상이 일어납니다.
두가지 원인이 있는데 첫번째는 저장할 Texture 및 Texture2D의 크기가 작아 모든 텍스쳐를 저장할 수 없는 경우와
두번째는 Linear color space의 픽셀을 텍스쳐에 저장 할 수 없는 경우가 있습니다.
이번 포스팅에서는 URP 환경에서 해당 이펙트들을 함께 캡쳐하는 방법을 알아봅니다.

콘텐츠 개발 기법 - UI 안나오게 화면 캡처(Screen Capture without UI)
콘텐츠 개발 기법 - UI 안나오게 화면 캡처(Screen Capture without UI)

화면 캡처 :: Screen Capture

UI 없이 화면을 캡쳐하는 방법을 알아봅니다.
해당 방법을 통해 사진 앱에서 사진을 찍거나 게임 내에서 UI를 제거한 스크린샷을 구현할 수 있습니다.

유니티3D 에디터에서

스크립트 작성

LightshipAR SDK 활용하기 - LightshipAR VPS의 활용
LightshipAR SDK 활용하기 - LightshipAR VPS의 활용

LightshipAR SDK

이번 강좌에서는 Visual Positioning System (VPS) 기능을 활용하여 콘텐츠를 개발해 봅니다.
VPS는 GPS정보와 타겟 매핑 정보를 정합하여 해당 타겟을 인식하는 기능입니다.
따라서 객체나 환경의 변화 및 이동이 잦지 않은 타겟이 스캔 대상이 됩니다.
주로 동상, 건물 입구, 가로등 등 위치의 변경이 없는 타겟들이 좋은 타겟입니다.

해당 타겟들을 인식시키고 주변에 가상의 오브젝트들을 배치하고 해당 위치를 저장하는 방법을 알아봅니다.

공간 매핑

Niantic Wayfarer

공간을 인식시키기 위해서 먼저 공간을 매핑해야 합니다.
이 과정은 IOS 어플리케이션으로 진행을 할 수 있는데 아래 링크에서

  1. Testflight
  2. Wayfarer

어플리케이션을 다운로드 및 설치합니다.

링크 : https://testflight.apple.com/join/VXu1F2jf