빠른 시작: 인버스 유니티 패키지
이 가이드에서는 패키지 설치, 햅틱 릭 설정, 힘 및 위치 제어를 위한 간단한 스크립트 생성 등 기본적인 설정에 대한 개요와 Haply Inverse Unity 패키지의 기본 사용법을 보여 주는 간단한 예제를 제공합니다.
자세한 내용과 고급 기술을 알아보려면 튜토리얼을 살펴보세요.
버전 지원
- Unity 2021.3.x LTS: 지원됨
- Unity 2022.3.x LTS: 지원됨
- Unity 2023.x.x(테크 스트림): 실험 단계
- Haply Inverse SDK: 2.0.0 이상
전제 조건
- 설치 Haply Inverse SDK 버전 2.0.0 이상을 설치하세요.
- Haply 역방향 서비스가 작동하는지 확인합니다.
- 씬을 시작하기 전에 Inverse3 및 VerseGrip 장치가 연결되고 보정되었는지 확인합니다.
이 패키지는 Inverse3 에 대한 지원을 강화하기 위해 지속적으로 개발 중입니다. 지원, 피드백 또는 요청 사항이 있으면 문의해 주세요.
설치
인버스 유니티 패키지는 유니티의 범위 지정 레지스트리를 통해 사용할 수 있습니다. 패키지를 통합하려면
-
편집 > 프로젝트 설정 > 패키지 관리자를 엽니다. 새 범위 지정 레지스트리를 추가합니다:
- 이름:
Haply Robotics
- URL:
https://unitypackages.haply.co
- 범위:
co.haply
- 이름:
-
액세스 창 > 패키지 관리자을 클릭하고 추가 + 버튼을 클릭하고 이름으로 패키지 추가. 입력
co.haply.inverse
을 클릭하고 추가.
설치가 완료되면 패키지 관리자에 Inverse 패키지가 표시됩니다.
햅틱 릭 설정
햅틱 릭을 생성하려면 게임 오브젝트 > Haply 반전 > 햅틱 릭(한 손)으로 이동합니다. 이 작업은 Inverse3 컨트롤러와 VerseGrip으로 완전한 환경을 조립합니다.
이제 씬에 다음이 포함됩니다:
- 햅틱 디바이스 매퍼: Haply 역방향 서비스로 디바이스 할당을 관리합니다.
- 햅틱 원점: 씬 내에서 햅틱 설정의 스케일과 위치를 조정합니다.
- 햅틱 컨트롤러: 커서 힘 또는 위치를 관리합니다. Inverse3 및 VerseGrip 디바이스 데이터를 기반으로 커서의 힘이나 위치를 관리합니다.
- 커서: 커서: 장면 표현을 위한 Inverse3Cursor 및 VerseGrip 커서 컴포넌트를 포함합니다.
패키지 구성 요소에 대한 자세한 내용은 글로벌 아키텍처 문서 페이지를 참조하세요.
재생 모드에서 구는 커서 및 VerseGrip 방향과 Inverse3 커서 및 VerseGrip 방향에 맞춰 구가 움직이고 회전합니다.
강제 제어 모드
만들기 ForceControl.cs
C# 스크립트에 첨부하여 햅틱 오리진 게임 오브젝트.
이 스크립트를 사용하면 Inverse3 장치에서 인스펙터 슬라이더를 사용합니다.
using Haply.Inverse.Unity;
using UnityEngine;
public class ForceControl : MonoBehaviour
{
[Range(-2, 2)]
public float forceX;
[Range(-2, 2)]
public float forceY;
[Range(-2, 2)]
public float forceZ;
private Inverse3 _inverse3;
private void Awake()
{
_inverse3 = GetComponentInChildren<Inverse3>();
}
protected void OnEnable()
{
_inverse3.DeviceStateChanged += OnDeviceStateChanged;
}
protected void OnDisable()
{
_inverse3.DeviceStateChanged -= OnDeviceStateChanged;
_inverse3.Release();
}
private void OnDeviceStateChanged(Inverse3 inverse3)
{
inverse3.CursorSetForce(forceX, forceY, forceZ);
}
}
스크립트 설명
-
forceX, Y, Z
: 슬라이더를 사용하여 힘 벡터 구성 요소를 조정하여 힘이 안전 한도 내에서 유지되도록 보장합니다.CursorSetForce
메서드를 사용할 수 있습니다. 또는 표준Vector3
필드를 사용할 수 있습니다. -
Awake()
: 검색 Inverse3 컴포넌트를 현재 게임 오브젝트 또는 그 자식에서 가져옵니다. -
OnEnable()
: 등록OnDeviceStateChanged
콜백을 별도의 스레드에서 햅틱 업데이트의Awake
메서드 호출과 스크립트가 활성화될 때마다 호출합니다. -
OnDisable()
: 스크립트가 비활성화되거나 애플리케이션이 중지되면 콜백 등록을 취소하고 강제 적용을 재설정합니다. -
OnDeviceStateChanged
: 를 가져옵니다.force
벡터를 인스펙터 창에서 가져와서 Inverse3 를 사용하여CursorSetForce
메서드를 사용합니다.중요: 콜백은 햅틱 스레드에 의해 4kHz~8kHz 범위의 높은 주파수로 트리거됩니다. 이 콜백 내의 모든 코드가 고도로 최적화되어 있는지 확인하는 것이 중요합니다.
사용법
재생 모드로 들어가기 전에 커서를 길게 누르고 있는지 확인하세요. 장치가 녹색 표시등으로 표시되는 강제 제어 상태로 전환되어야 합니다. 그런 다음 슬라이더를 사용하여 힘 출력을 조정하여 디바이스 작업 공간을 탐색할 수 있습니다.
힘을 조절하면 Inverse3 이 움직입니다. 작업 공간이 깨끗한지 확인하고 항상 커서를 잡고 있어야 합니다. 안전 지침은 안전 사용 문서를 참조하세요.
위치 제어 모드
마찬가지로 PositionControl.cs
C# 스크립트를 사용하여 디바이스의 위치를 제어하고 이를 햅틱 오리진 게임 오브젝트.
using Haply.Inverse.Unity;
using UnityEngine;
public class PositionControl : MonoBehaviour
{
[Range(-0.1f, 0.1f)]
public float positionX;
[Range(-0.1f, 0.1f)]
public float positionY;
[Range(-0.1f, 0.1f)]
public float positionZ;
private Inverse3 _inverse3;
private void Awake()
{
_inverse3 = GetComponentInChildren<Inverse3>();
}
protected void OnEnable()
{
_inverse3.DeviceStateChanged += OnDeviceStateChanged;
}
protected void OnDisable()
{
_inverse3.DeviceStateChanged -= OnDeviceStateChanged;
_inverse3.Release();
}
private void OnDeviceStateChanged(Inverse3 inverse3)
{
var position = inverse3.WorkspaceCenterLocalPosition + new Vector3(positionX, positionY, positionZ);
inverse3.CursorSetLocalPosition(position);
}
}
ForceControl 스크립트 또는 장치를 제어하는 다른 스크립트가 비활성화되어 있는지 확인합니다.
이전 예와 비슷합니다:
- 활용
positionX, Y, and Z
를 조정하려면 위치 플레이 모드에서 슬라이더를 사용합니다.선택한
Range(-0.1, 0.1)
는 대략 달성 가능한 최대 위치에 해당합니다. - 그리고
Awake
메서드는 Inverse3 컴포넌트입니다. - 그리고
OnEnable
메서드를 등록하면OnDeviceStateChanged
콜백을 별도의 스레드에서 햅틱 업데이트의Awake
메서드 호출과 스크립트가 활성화될 때마다 호출합니다. - 그리고
OnDisable
메서드는 콜백 등록을 취소하고 스크립트가 비활성화되거나 애플리케이션이 중지되면 강제성을 재설정합니다.
그러나 차이점이 있습니다:
- 그리고
OnDeviceStateChanged
콜백을 호출합니다, 는 인스펙터 창에서 위치 벡터를 가져와서WorkspaceCenterLocalPosition
, 를 사용하여 Inverse3 으로 전송합니다.CursorSetLocalPosition
메서드를 사용합니다.
재생 모드로 들어가기 전에 커서를 가운데 위치에 가까이 가져갑니다. 장치가 위치 제어 상태로 전환됩니다(파란색 표시등으로 표시됨). 그런 다음 슬라이더로 위치 출력을 조정하여 디바이스 작업 공간을 탐색할 수 있습니다.
위치를 조정할 때 Inverse3 이 움직입니다. 작업 공간에 귀중품이 없는지 확인하고 항상 커서를 잡고 있어야 합니다. 자세한 내용은 안전한 사용 도움말을 참조하세요.