입력 이벤트 - MRTK2

아래 목록에서는 사용자 지정 MonoBehaviour 구성 요소에서 구현할 사용 가능한 모든 입력 이벤트 인터페이스를 간략하게 설명합니다. 이러한 인터페이스는 MRTK 입력 시스템에서 호출되어 사용자 입력 상호 작용에 따라 사용자 지정 앱 논리를 처리합니다. 포인터 입력 이벤트는 아래의 표준 입력 이벤트 유형과 약간 다르게 처리됩니다.

중요

기본적으로 스크립트는 포커스에 있는 GameObject의 포인터 또는 부모에 의해 포커스가 있는 GameObject인 경우에만 입력 이벤트를 받습니다.

Handler 이벤트 Description
IMixedRealitySourceStateHandler 원본 검색됨/손실됨 입력 소스가 감지/손실될 때(예: 관절이 있는 손이 감지되거나 추적이 손실되는 경우) 발생합니다.
IMixedRealitySourcePoseHandler 원본 포즈 변경됨 원본 포즈 변경에서 발생합니다. 원본 포즈는 입력 소스의 일반 포즈를 나타냅니다. 6개의 DOF 컨트롤러에서 그립 또는 포인터 포즈와 같은 특정 포즈는 를 통해 IMixedRealityInputHandler<MixedRealityPose>얻을 수 있습니다.
IMixedRealityInputHandler 아래로/위로 입력 단추와 같은 이진 입력의 변경 내용에서 발생합니다.
IMixedRealityInputHandler<T> 입력 변경됨 지정된 형식의 입력에 대한 변경 내용에서 발생합니다. T 는 다음 값을 사용할 수 있습니다.
- float (예: 아날로그 트리거 반환)
- Vector2 (예: 게임 패드 엄지스틱 방향을 반환)
- Vector3 (예: 추적된 디바이스의 위치 반환)
- Quaternion (예: 추적된 디바이스의 방향을 반환)
- MixedRealityPose (예: 완전히 추적된 디바이스 반환)
IMixedRealitySpeechHandler 음성 키워드 인식됨 음성 명령 프로필에 구성된 키워드 중 하나를 인식할 때 발생합니다.
IMixedRealityDictationHandler 받아쓰기
Hypothesis
결과
완료
오류
받아쓰기 세션의 결과를 보고하기 위해 받아쓰기 시스템에 의해 발생합니다.
IMixedRealityGestureHandler 제스처 이벤트:
시작됨
업데이트됨
완료됨
취소됨
제스처 감지에서 발생합니다.
IMixedRealityGestureHandler<T> 제스처 업데이트/완료됨 지정된 형식의 추가 데이터가 포함된 제스처를 검색할 때 발생합니다. T에 대한 가능한 값에 대한 자세한 내용은 제스처 이벤트를 참조하세요.
IMixedRealityHandJointHandler 손 관절 업데이트됨 손 관절이 업데이트될 때 관절형 손 컨트롤러에 의해 발생합니다.
IMixedRealityHandMeshHandler 손 메시 업데이트됨 손 메시가 업데이트될 때 관절식 손 컨트롤러에 의해 발생합니다.
IMixedRealityInputActionHandler 작업 시작/종료 동작에 매핑된 입력에 대한 작업 시작 및 종료를 나타내기 위해 를 올립니다.

작동 중인 입력 이벤트

스크립트 수준에서 입력 이벤트는 위의 표에 표시된 이벤트 처리기 인터페이스 중 하나를 구현하여 사용할 수 있습니다. 사용자 상호 작용을 통해 입력 이벤트가 발생하면 다음이 발생합니다.

  1. MRTK 입력 시스템은 입력 이벤트가 발생했음을 인식합니다.
  2. MRTK 입력 시스템은 등록된 모든 전역 입력 처리기에 입력 이벤트의 관련 인터페이스 함수를 실행합니다.
  3. 입력 시스템에 등록된 모든 활성 포인터:
    1. 입력 시스템은 현재 포인터에 포커스가 있는 GameObject를 결정합니다.
    2. 입력 시스템은 Unity의 이벤트 시스템을 활용하여 포커스가 있는 GameObject에서 일치하는 모든 구성 요소에 대한 관련 인터페이스 함수를 실행합니다.
    3. 입력 이벤트가 사용된 것으로 표시된 경우 프로세스가 종료되고 더 이상 GameObjects가 콜백을 수신하지 않습니다.
      • 예: 인터페이스 IMixedRealitySpeechHandler 를 구현하는 구성 요소는 음성 명령이 인식될 때 검색됩니다.
      • 참고: Unity 이벤트 시스템은 현재 GameObject에서 원하는 인터페이스와 일치하는 구성 요소가 없으면 부모 GameObject를 검색하기 위해 버블업됩니다.
  4. 전역 입력 처리기가 등록되지 않고 일치하는 구성 요소/인터페이스를 사용하여 GameObject를 찾을 수 없는 경우 입력 시스템은 등록된 각 대체 입력 처리기를 호출합니다.

참고

포인터 입력 이벤트는 위에 나열된 입력 이벤트 인터페이스와 약간 다른 방식으로 처리됩니다. 특히 포인터 입력 이벤트는 입력 이벤트를 발생시킨 포인터와 모든 전역 입력 처리기에 의해 포커스가 있는 GameObject에 의해서만 처리됩니다. 일반 입력 이벤트는 모든 활성 포인터에 대해 포커스가 있는 GameObjects에 의해 처리됩니다.

입력 이벤트 인터페이스 예제

아래 코드에서는 인터페이스를 사용하는 방법을 보여 줍니다 IMixedRealitySpeechHandler . 사용자가 이 ShowHideSpeechHandler 클래스를 사용하여 GameObject에 집중하는 동안 "작음" 또는 "더 큰" 단어를 말하는 경우 GameObject는 자체 크기를 절반 또는 두 배만큼 확장합니다.

public class ShowHideSpeechHandler : MonoBehaviour, IMixedRealitySpeechHandler
{
    ...

    void IMixedRealitySpeechHandler.OnSpeechKeywordRecognized(SpeechEventData eventData)
    {
        if (eventData.Command.Keyword == "smaller")
        {
            transform.localScale *= 0.5f;
        }
        else if (eventData.Command.Keyword == "bigger")
        {
            transform.localScale *= 2.0f;
        }
    }
}

참고

IMixedRealitySpeechHandler 입력 이벤트를 사용하려면 원하는 키워드가 MRTK Speech Commands Profile에 미리 등록되어 있어야 합니다.

전역 입력 이벤트 등록

GameObject가 포커스에 있을 수 있는 것을 무시하고 전역 입력 이벤트를 수신 대기하는 구성 요소를 만들려면 구성 요소가 입력 시스템에 등록해야 합니다. 등록되면 이 MonoBehaviour의 모든 인스턴스는 현재 포커스가 있는 GameObject 및 기타 전역 등록 수신기와 함께 입력 이벤트를 받게 됩니다.

입력 이벤트가 사용된 것으로 표시된 경우 전역 등록 처리기는 여전히 모두 콜백을 받습니다. 그러나 포커스가 있는 GameObjects는 이벤트를 수신하지 않습니다.

전역 입력 등록 예제

public class GlobalHandListenerExample : MonoBehaviour,
    IMixedRealitySourceStateHandler, // Handle source detected and lost
    IMixedRealityHandJointHandler // handle joint position updates for hands
{
    private void OnEnable()
    {
        // Instruct Input System that we would like to receive all input events of type
        // IMixedRealitySourceStateHandler and IMixedRealityHandJointHandler
        CoreServices.InputSystem?.RegisterHandler<IMixedRealitySourceStateHandler>(this);
        CoreServices.InputSystem?.RegisterHandler<IMixedRealityHandJointHandler>(this);
    }

    private void OnDisable()
    {
        // This component is being destroyed
        // Instruct the Input System to disregard us for input event handling
        CoreServices.InputSystem?.UnregisterHandler<IMixedRealitySourceStateHandler>(this);
        CoreServices.InputSystem?.UnregisterHandler<IMixedRealityHandJointHandler>(this);
    }

    // IMixedRealitySourceStateHandler interface
    public void OnSourceDetected(SourceStateEventData eventData)
    {
        var hand = eventData.Controller as IMixedRealityHand;

        // Only react to articulated hand input sources
        if (hand != null)
        {
            Debug.Log("Source detected: " + hand.ControllerHandedness);
        }
    }

    public void OnSourceLost(SourceStateEventData eventData)
    {
        var hand = eventData.Controller as IMixedRealityHand;

        // Only react to articulated hand input sources
        if (hand != null)
        {
            Debug.Log("Source lost: " + hand.ControllerHandedness);
        }
    }

    public void OnHandJointsUpdated(
                InputEventData<IDictionary<TrackedHandJoint, MixedRealityPose>> eventData)
    {
        MixedRealityPose palmPose;
        if (eventData.InputData.TryGetValue(TrackedHandJoint.Palm, out palmPose))
        {
            Debug.Log("Hand Joint Palm Updated: " + palmPose.Position);
        }
    }
}

대체 입력 이벤트 등록

대체 입력 처리기는 등록된 전역 입력 처리기와 유사하지만 입력 이벤트 처리의 최후의 수단으로 처리됩니다. 전역 입력 처리기를 찾을 수 없고 GameObject가 포커스에 없는 경우에만 대체 입력 처리기가 활용됩니다.

대체 입력 처리기 예제

public class GlobalHandListenerExample : MonoBehaviour,
    IMixedRealitySourceStateHandler // Handle source detected and lost
{
    private void OnEnable()
    {
        CoreServices.InputSystem?.PushFallbackInputHandler(this);
    }

    private void OnDisable()
    {
        CoreServices.InputSystem?.PopFallbackInputHandler();
    }

    // IMixedRealitySourceStateHandler interface
    public void OnSourceDetected(SourceStateEventData eventData)
    {
        ...
    }

    public void OnSourceLost(SourceStateEventData eventData)
    {
        ...
    }
}

입력 이벤트를 중지하는 방법

모든 입력 이벤트 인터페이스는 인터페이스의 BaseInputEventData 각 함수에 대한 매개 변수로 데이터 개체를 제공합니다. 이 이벤트 데이터 개체는 Unity의 자체 AbstractEventData에서 확장됩니다.

입력 이벤트가 설명된 대로 실행을 통해 전파되는 것을 막기 위해 구성 요소는 를 호출 AbstractEventData.Use() 하여 이벤트를 사용된 것으로 표시할 수 있습니다. 이렇게 하면 전역 입력 처리기를 제외하고 다른 GameObject가 현재 입력 이벤트를 수신하지 못하게 됩니다.

참고

메서드를 Use() 호출하는 구성 요소는 다른 GameObjects의 수신을 중지합니다. 그러나 현재 GameObject의 다른 구성 요소는 여전히 입력 이벤트를 수신하고 관련 인터페이스 함수를 실행합니다.

추가 정보