Class OpenXRInput
OpenXR Input related functionality.
Inherited Members
Namespace: UnityEngine.XR.OpenXR.Input
Assembly: Unity.XR.OpenXR.dll
Syntax
public static class OpenXRInput
Methods
GetActionHandle(InputAction, InputDevice)
Returns the OpenXR action handle for the given input action
Declaration
public static ulong GetActionHandle(InputAction inputAction, InputDevice inputDevice = null)
Parameters
Type | Name | Description |
---|---|---|
InputAction | inputAction | Source InputAction |
InputDevice | inputDevice | Optional InputDevice to filter by |
Returns
Type | Description |
---|---|
ulong | OpenXR handle that is associated with the given InputAction or 0 if not found |
GetActionHandle(InputDevice, string)
Returns the OpenXR action handle for the given input device and usage name.
Declaration
public static ulong GetActionHandle(InputDevice device, string usageName)
Parameters
Type | Name | Description |
---|---|---|
InputDevice | device | Device to find action handle for. |
string | usageName | Usage name to find action handle for. |
Returns
Type | Description |
---|---|
ulong | OpenXR handle that is associated with the given device and usage, or 0 if not found |
GetActionHandle(InputDevice, InputFeatureUsage)
Returns the OpenXR action handle for the given input device and usage.
Declaration
public static ulong GetActionHandle(InputDevice device, InputFeatureUsage usage)
Parameters
Type | Name | Description |
---|---|---|
InputDevice | device | Device to find action handle for. |
InputFeatureUsage | usage | Usage to find action handle for. |
Returns
Type | Description |
---|---|
ulong | OpenXR handle that is associated with the given device and usage, or 0 if not found |
GetActionIsActive(InputAction)
Return the active state of the given action
Declaration
public static bool GetActionIsActive(InputAction inputAction)
Parameters
Type | Name | Description |
---|---|---|
InputAction | inputAction | Input Action |
Returns
Type | Description |
---|---|
bool | True if the given action has any bindings that are active |
GetActionIsActive(InputDevice, string)
Return the active state of the given action
Declaration
public static bool GetActionIsActive(InputDevice device, string usageName)
Parameters
Type | Name | Description |
---|---|---|
InputDevice | device | InputDevice to get active state for |
string | usageName | InputFeatureUsage name to get active state for |
Returns
Type | Description |
---|---|
bool | True if the given action has any bindings that are active |
GetActionIsActive(InputDevice, InputFeatureUsage)
Return the active state of the given action
Declaration
public static bool GetActionIsActive(InputDevice device, InputFeatureUsage usage)
Parameters
Type | Name | Description |
---|---|---|
InputDevice | device | InputDevice to get active state for |
InputFeatureUsage | usage | InputFeatureUsage to get active state for |
Returns
Type | Description |
---|---|
bool | True if the given action has any bindings that are active |
SendHapticImpulse(InputAction, float, float, float, InputDevice)
Send a haptic impulse using the given action
Declaration
public static void SendHapticImpulse(InputAction action, float amplitude, float frequency, float duration, InputDevice inputDevice = null)
Parameters
Type | Name | Description |
---|---|---|
InputAction | action | Action to send haptic impulse through |
float | amplitude | Amplitude of the impulse [0-1] |
float | frequency | Frequency of the impulse in hertz (Hz). (Typical frequency values are between 0 and 300Hz) (0 = default). Note that not all runtimes support frequency. |
float | duration | Duration of the impulse [0-] in seconds |
InputDevice | inputDevice | Optional device to limit haptic impulse to |
SendHapticImpulse(InputAction, float, float, InputDevice)
Send a haptic impulse using the given action
Declaration
public static void SendHapticImpulse(InputAction action, float amplitude, float duration, InputDevice inputDevice = null)
Parameters
Type | Name | Description |
---|---|---|
InputAction | action | Action to send haptic impulse through |
float | amplitude | Amplitude of the impulse [0-1] |
float | duration | Duration of the impulse [0-] in seconds |
InputDevice | inputDevice | Optional device to limit haptic impulse to |
SendHapticImpulse(InputActionReference, float, float, float, InputDevice)
Send a haptic impulse using an action reference
Declaration
public static void SendHapticImpulse(InputActionReference actionRef, float amplitude, float frequency, float duration, InputDevice inputDevice = null)
Parameters
Type | Name | Description |
---|---|---|
InputActionReference | actionRef | Action Reference to send haptic impulse through |
float | amplitude | Amplitude of the impulse [0-1] |
float | frequency | Frequency of the impulse in hertz (Hz). (Typical frequency values are between 0 and 300Hz) (0 = default). Note that not all runtimes support frequency. |
float | duration | Duration of the impulse [0-] in seconds |
InputDevice | inputDevice | Optional device to limit haptic impulse to |
SendHapticImpulse(InputActionReference, float, float, InputDevice)
Send a haptic impulse using an action reference
Declaration
public static void SendHapticImpulse(InputActionReference actionRef, float amplitude, float duration, InputDevice inputDevice = null)
Parameters
Type | Name | Description |
---|---|---|
InputActionReference | actionRef | Action Reference to send haptic impulse through |
float | amplitude | Amplitude of the impulse [0-1] |
float | duration | Duration of the impulse [0-] in seconds |
InputDevice | inputDevice | Optional device to limit haptic impulse to |
SendHapticImpulse(InputDevice, float, float, float)
Send a haptic impulse using the given device
Declaration
public static void SendHapticImpulse(InputDevice device, float amplitude, float frequency, float duration)
Parameters
Type | Name | Description |
---|---|---|
InputDevice | device | Device to send haptic impulse |
float | amplitude | Amplitude of the impulse [0-1] |
float | frequency | Frequency of the impulse in hertz (Hz). (Typical frequency values are between 0 and 300Hz) (0 = default). Note that not all runtimes support frequency. |
float | duration | Duration of the impulse [0-] in seconds |
StopHapticImpulse(InputDevice)
Stop any haptics playing for the given device.
Declaration
public static void StopHapticImpulse(InputDevice device)
Parameters
Type | Name | Description |
---|---|---|
InputDevice | device | Device to stop haptics on. |
StopHaptics(InputAction, InputDevice)
Stop any haptics playing for the given action
Declaration
public static void StopHaptics(InputAction inputAction, InputDevice inputDevice = null)
Parameters
Type | Name | Description |
---|---|---|
InputAction | inputAction | Input action to stop haptics for |
InputDevice | inputDevice | Optional device filter for actions bound to multiple defices |
StopHaptics(InputActionReference, InputDevice)
Stop any haptics playing for the given action reference
Declaration
public static void StopHaptics(InputActionReference actionRef, InputDevice inputDevice = null)
Parameters
Type | Name | Description |
---|---|---|
InputActionReference | actionRef | Action reference to stop the haptics on. |
InputDevice | inputDevice | Optional device filter for actions bound to multiple devices. |
TryGetInputSourceName(InputAction, int, out string, InputSourceNameFlags, InputDevice)
Return the name of the input source bound to the given action
Declaration
public static bool TryGetInputSourceName(InputAction inputAction, int index, out string name, OpenXRInput.InputSourceNameFlags flags = InputSourceNameFlags.All, InputDevice inputDevice = null)
Parameters
Type | Name | Description |
---|---|---|
InputAction | inputAction | Input Action |
int | index | Index of the input source in the case of multiple bindings. |
string | name | Name of the input source if an input source was found or an empty string if none was found |
OpenXRInput.InputSourceNameFlags | flags | Flags that indicate which parts of the input source name are requested. |
InputDevice | inputDevice | Optional input device to limit search to |
Returns
Type | Description |
---|---|
bool | True if an input source was found |
TrySetControllerLateLatchAction(InputAction)
Set InputAction to be used for controller late latching (Vulkan Only Feature). Only support one inputAction for each left and right controller. See Controller Samples MarkLateLatchNode.cs for example code and usages.
Declaration
public static bool TrySetControllerLateLatchAction(InputAction inputAction)
Parameters
Type | Name | Description |
---|---|---|
InputAction | inputAction | Source InputAction - Pose Type |
Returns
Type | Description |
---|---|
bool | True if the given action is a valid pose action can be late latched |
TrySetControllerLateLatchAction(InputDevice, string)
Set InputAction to be used for controller late latching (Vulkan Only Feature). Only support one input action for each left and right controller. See Controller XRInput Samples MarkLateLatchNodeXRInput.cs for example code and usages.
Declaration
public static bool TrySetControllerLateLatchAction(InputDevice device, string usageName)
Parameters
Type | Name | Description |
---|---|---|
InputDevice | device | Source device |
string | usageName | Source usage name - attached to a Pose Type |
Returns
Type | Description |
---|---|
bool | True if the given action is a valid pose action can be late latched |
TrySetControllerLateLatchAction(InputDevice, InputFeatureUsage)
Set InputAction to be used for controller late latching (Vulkan Only Feature). Only support one input action for each left and right controller. See Controller XRInput Samples MarkLateLatchNodeXRInput.cs for example code and usages.
Declaration
public static bool TrySetControllerLateLatchAction(InputDevice device, InputFeatureUsage usage)
Parameters
Type | Name | Description |
---|---|---|
InputDevice | device | Source device |
InputFeatureUsage | usage | Source usage - attached to a Pose Type |
Returns
Type | Description |
---|---|
bool | True if the given action is a valid pose action can be late latched |