HTC VIVE Plugin 적용(Vive Controller Binding)

Published: Jun 18, 2020 by BeatChoi

[CameraRig] 프리펩 알아보기

[CameraRig] 프리펩의 좌측 드롭다운 버튼을 눌러 해당 프리펩을 살펴봅니다. Controller (Left), Controller (Right), Camera 세가지 오브젝트로 이루어져 있는데 각각 좌측 컨트롤러 우측컨트롤러 그리고 HMD를 나타냅니다. 유저가 HMD로 보는 방향이 Camera오브젝트가 바라보는 방향입니다.

img

컨트롤러 설정하기

바이브 컨트롤러에는 Grip, Menu, Trigger, Trackpad, System 버튼이 있습니다. 각 버튼의 유형에 따라 알맞는 콘텐츠를 실행시킬 수 있습니다.

Window 탭에서 SteamVR Input을 클릭합니다.

img

생성된 창의 중앙에 있는 Actions항목은 버튼을 실행시켰을 때 행할 행동들을 정의했다고 보면 됩니다. 그렇다고 해서 미리 생성된 액션들이 이미 구현이 되어있는 것은 아니고 추후에 유저들이 해당 액션을 구현해야 합니다.

img

우측 하단에 Open binding UI를 클릭하여 컨트롤러 Binding 창을 띄웁니다.

img

상단의 Current Binding 의 Edit 버튼을 선택하여 들어갑니다.

img

본 창에서 컨트롤러의 각 버튼에 유저가 설정한 액션을 연결시킬 수 있습니다. 그러면 그 버튼을 누르면 설정한 액션이 행해지게 되는것이죠. 기본 값으로 트리거 버튼에 Grab Pinch 액션이 설정되어 있는 것을 확인할 수 있습니다. 이를 이용하여 버튼이 눌리는 것을 확인해 보겠습니다.

컨트롤러 입력 확인하기

ButtonTrigger 스크립트를 하나 생성합니다. 다음과 같은 코드를 작성합니다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using Valve.VR;

public class ButtonTrigger : MonoBehaviour
{
    public SteamVR_Input_Sources handType;
    public SteamVR_Action_Boolean grabPinch;
    // Start is called before the first frame update
    void Start()
    {
        
    }

    // Update is called once per frame
    void Update()
    {
        if (grabPinch.GetState(handType))
        {
            Debug.Log("Trigger");
        }
    }
}

4)Valve.VR 네임스페이스를 등록하여야 Steam VR API를 활용할 수 있습니다.
8)SteamVR_Input_Sources 는 입력이 되는 디바이스인데 이 경우엔 컨트롤러(좌, 우) 입니다.
9)SteamVR_Action_Boolean 은 Boolean 값을 가지는 액션을 선택합니다. 이경우엔 GrabPinch가 됩니다.
19)grabPinch.GetState(handType) : 참 거짓 값을 리턴하는 메소드인 GetState를 활용합니다. 인자값으로 입력 소스를 넣으면 됩니다. 이경우엔 위에서선택한 컨트롤러입니다. 이 경우 grabPinch에 해당하는 액션에 지정된 입력이 실행될 경우 참을 호출합니다.

해당 스크립트를 [CameraRig] 프리펩 하위에 있는 Controller (left) 또는 Controller (right)에 인스턴스화 시킵니다.

img
img

인스턴스화 시킨 스크립트에서 Hand Type 은 Any 또는 left, right hand 를 선택합니다.

img

Grab Pinch 항목은 GrabPinch 액션을 선택합니다. 잘 보면 액션들은 SteamVR Input 창에 미리 생성되어있었던 액션들 중 하나입니다.

img

img

세팅을 마치고 상단 플레이버튼을 누르고 컨트롤러의 트리거를 당겨보면 콘솔창에 Trigger 가 호출되는 것을 알 수 있습니다. 우리가 Binding 창에서 Trigger 항목에 Grab Pinch를 연결시켜줬기 때문에 트리거를 당겼을 때 Grab Pinch 액션을 호출하게 되고 Grab Pinch 액션은 우리가 작성한 스크립트중 GetState 메소드와 연결이 되어있기 때문에 해당 코드의 참을 호출합니다. 따라서 Debug.Log(“Trigger”)가 실행되는 것입니다.

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