123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792 |
- :github_url: hide
- .. DO NOT EDIT THIS FILE!!!
- .. Generated automatically from Godot engine sources.
- .. Generator: https://github.com/godotengine/godot/tree/master/doc/tools/make_rst.py.
- .. XML source: https://github.com/godotengine/godot/tree/master/modules/openxr/doc_classes/OpenXRInterface.xml.
- .. _class_OpenXRInterface:
- OpenXRInterface
- ===============
- **Inherits:** :ref:`XRInterface<class_XRInterface>` **<** :ref:`RefCounted<class_RefCounted>` **<** :ref:`Object<class_Object>`
- Our OpenXR interface.
- .. rst-class:: classref-introduction-group
- Description
- -----------
- The OpenXR interface allows Godot to interact with OpenXR runtimes and make it possible to create XR experiences and games.
- Due to the needs of OpenXR this interface works slightly different than other plugin based XR interfaces. It needs to be initialized when Godot starts. You need to enable OpenXR, settings for this can be found in your games project settings under the XR heading. You do need to mark a viewport for use with XR in order for Godot to know which render result should be output to the headset.
- .. rst-class:: classref-introduction-group
- Tutorials
- ---------
- - :doc:`Setting up XR <../tutorials/xr/setting_up_xr>`
- .. rst-class:: classref-reftable-group
- Properties
- ----------
- .. table::
- :widths: auto
- +---------------------------+----------------------------------------------------------------------------------------------------+-----------+
- | :ref:`float<class_float>` | :ref:`display_refresh_rate<class_OpenXRInterface_property_display_refresh_rate>` | ``0.0`` |
- +---------------------------+----------------------------------------------------------------------------------------------------+-----------+
- | :ref:`bool<class_bool>` | :ref:`foveation_dynamic<class_OpenXRInterface_property_foveation_dynamic>` | ``false`` |
- +---------------------------+----------------------------------------------------------------------------------------------------+-----------+
- | :ref:`int<class_int>` | :ref:`foveation_level<class_OpenXRInterface_property_foveation_level>` | ``0`` |
- +---------------------------+----------------------------------------------------------------------------------------------------+-----------+
- | :ref:`float<class_float>` | :ref:`render_target_size_multiplier<class_OpenXRInterface_property_render_target_size_multiplier>` | ``1.0`` |
- +---------------------------+----------------------------------------------------------------------------------------------------+-----------+
- .. rst-class:: classref-reftable-group
- Methods
- -------
- .. table::
- :widths: auto
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Array<class_Array>` | :ref:`get_action_sets<class_OpenXRInterface_method_get_action_sets>` **(** **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Array<class_Array>` | :ref:`get_available_display_refresh_rates<class_OpenXRInterface_method_get_available_display_refresh_rates>` **(** **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Vector3<class_Vector3>` | :ref:`get_hand_joint_angular_velocity<class_OpenXRInterface_method_get_hand_joint_angular_velocity>` **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | |bitfield|\<:ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>`\> | :ref:`get_hand_joint_flags<class_OpenXRInterface_method_get_hand_joint_flags>` **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Vector3<class_Vector3>` | :ref:`get_hand_joint_linear_velocity<class_OpenXRInterface_method_get_hand_joint_linear_velocity>` **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Vector3<class_Vector3>` | :ref:`get_hand_joint_position<class_OpenXRInterface_method_get_hand_joint_position>` **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`float<class_float>` | :ref:`get_hand_joint_radius<class_OpenXRInterface_method_get_hand_joint_radius>` **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Quaternion<class_Quaternion>` | :ref:`get_hand_joint_rotation<class_OpenXRInterface_method_get_hand_joint_rotation>` **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`HandMotionRange<enum_OpenXRInterface_HandMotionRange>` | :ref:`get_motion_range<class_OpenXRInterface_method_get_motion_range>` **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`is_action_set_active<class_OpenXRInterface_method_is_action_set_active>` **(** :ref:`String<class_String>` name **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`is_eye_gaze_interaction_supported<class_OpenXRInterface_method_is_eye_gaze_interaction_supported>` **(** **)** |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`is_foveation_supported<class_OpenXRInterface_method_is_foveation_supported>` **(** **)** |const| |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`is_hand_tracking_supported<class_OpenXRInterface_method_is_hand_tracking_supported>` **(** **)** |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_action_set_active<class_OpenXRInterface_method_set_action_set_active>` **(** :ref:`String<class_String>` name, :ref:`bool<class_bool>` active **)** |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_motion_range<class_OpenXRInterface_method_set_motion_range>` **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandMotionRange<enum_OpenXRInterface_HandMotionRange>` motion_range **)** |
- +--------------------------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Signals
- -------
- .. _class_OpenXRInterface_signal_pose_recentered:
- .. rst-class:: classref-signal
- **pose_recentered** **(** **)**
- Informs the user queued a recenter of the player position.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_signal_session_begun:
- .. rst-class:: classref-signal
- **session_begun** **(** **)**
- Informs our OpenXR session has been started.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_signal_session_focussed:
- .. rst-class:: classref-signal
- **session_focussed** **(** **)**
- Informs our OpenXR session now has focus.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_signal_session_stopping:
- .. rst-class:: classref-signal
- **session_stopping** **(** **)**
- Informs our OpenXR session is stopping.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_signal_session_visible:
- .. rst-class:: classref-signal
- **session_visible** **(** **)**
- Informs our OpenXR session is now visible (output is being sent to the HMD).
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Enumerations
- ------------
- .. _enum_OpenXRInterface_Hand:
- .. rst-class:: classref-enumeration
- enum **Hand**:
- .. _class_OpenXRInterface_constant_HAND_LEFT:
- .. rst-class:: classref-enumeration-constant
- :ref:`Hand<enum_OpenXRInterface_Hand>` **HAND_LEFT** = ``0``
- Left hand.
- .. _class_OpenXRInterface_constant_HAND_RIGHT:
- .. rst-class:: classref-enumeration-constant
- :ref:`Hand<enum_OpenXRInterface_Hand>` **HAND_RIGHT** = ``1``
- Right hand.
- .. _class_OpenXRInterface_constant_HAND_MAX:
- .. rst-class:: classref-enumeration-constant
- :ref:`Hand<enum_OpenXRInterface_Hand>` **HAND_MAX** = ``2``
- Maximum value for the hand enum.
- .. rst-class:: classref-item-separator
- ----
- .. _enum_OpenXRInterface_HandMotionRange:
- .. rst-class:: classref-enumeration
- enum **HandMotionRange**:
- .. _class_OpenXRInterface_constant_HAND_MOTION_RANGE_UNOBSTRUCTED:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandMotionRange<enum_OpenXRInterface_HandMotionRange>` **HAND_MOTION_RANGE_UNOBSTRUCTED** = ``0``
- .. _class_OpenXRInterface_constant_HAND_MOTION_RANGE_CONFORM_TO_CONTROLLER:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandMotionRange<enum_OpenXRInterface_HandMotionRange>` **HAND_MOTION_RANGE_CONFORM_TO_CONTROLLER** = ``1``
- .. _class_OpenXRInterface_constant_HAND_MOTION_RANGE_MAX:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandMotionRange<enum_OpenXRInterface_HandMotionRange>` **HAND_MOTION_RANGE_MAX** = ``2``
- .. rst-class:: classref-item-separator
- ----
- .. _enum_OpenXRInterface_HandJoints:
- .. rst-class:: classref-enumeration
- enum **HandJoints**:
- .. _class_OpenXRInterface_constant_HAND_JOINT_PALM:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_PALM** = ``0``
- Palm joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_WRIST:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_WRIST** = ``1``
- Wrist joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_THUMB_METACARPAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_THUMB_METACARPAL** = ``2``
- Thumb metacarpal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_THUMB_PROXIMAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_THUMB_PROXIMAL** = ``3``
- Thumb proximal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_THUMB_DISTAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_THUMB_DISTAL** = ``4``
- Thumb distal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_THUMB_TIP:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_THUMB_TIP** = ``5``
- Thumb tip joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_INDEX_METACARPAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_INDEX_METACARPAL** = ``6``
- Index metacarpal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_INDEX_PROXIMAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_INDEX_PROXIMAL** = ``7``
- Index proximal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_INDEX_INTERMEDIATE:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_INDEX_INTERMEDIATE** = ``8``
- Index intermediate joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_INDEX_DISTAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_INDEX_DISTAL** = ``9``
- Index distal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_INDEX_TIP:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_INDEX_TIP** = ``10``
- Index tip joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_MIDDLE_METACARPAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_MIDDLE_METACARPAL** = ``11``
- Middle metacarpal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_MIDDLE_PROXIMAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_MIDDLE_PROXIMAL** = ``12``
- Middle proximal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_MIDDLE_INTERMEDIATE:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_MIDDLE_INTERMEDIATE** = ``13``
- Middle intermediate joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_MIDDLE_DISTAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_MIDDLE_DISTAL** = ``14``
- Middle distal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_MIDDLE_TIP:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_MIDDLE_TIP** = ``15``
- Middle tip joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_RING_METACARPAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_RING_METACARPAL** = ``16``
- Ring metacarpal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_RING_PROXIMAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_RING_PROXIMAL** = ``17``
- Ring proximal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_RING_INTERMEDIATE:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_RING_INTERMEDIATE** = ``18``
- Ring intermediate joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_RING_DISTAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_RING_DISTAL** = ``19``
- Ring distal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_RING_TIP:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_RING_TIP** = ``20``
- Ring tip joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_LITTLE_METACARPAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_LITTLE_METACARPAL** = ``21``
- Little metacarpal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_LITTLE_PROXIMAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_LITTLE_PROXIMAL** = ``22``
- Little proximal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_LITTLE_INTERMEDIATE:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_LITTLE_INTERMEDIATE** = ``23``
- Little intermediate joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_LITTLE_DISTAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_LITTLE_DISTAL** = ``24``
- Little distal joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_LITTLE_TIP:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_LITTLE_TIP** = ``25``
- Little tip joint.
- .. _class_OpenXRInterface_constant_HAND_JOINT_MAX:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` **HAND_JOINT_MAX** = ``26``
- Maximum value for the hand joint enum.
- .. rst-class:: classref-item-separator
- ----
- .. _enum_OpenXRInterface_HandJointFlags:
- .. rst-class:: classref-enumeration
- flags **HandJointFlags**:
- .. _class_OpenXRInterface_constant_HAND_JOINT_NONE:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>` **HAND_JOINT_NONE** = ``0``
- No flags are set.
- .. _class_OpenXRInterface_constant_HAND_JOINT_ORIENTATION_VALID:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>` **HAND_JOINT_ORIENTATION_VALID** = ``1``
- If set, the orientation data is valid, otherwise, the orientation data is unreliable and should not be used.
- .. _class_OpenXRInterface_constant_HAND_JOINT_ORIENTATION_TRACKED:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>` **HAND_JOINT_ORIENTATION_TRACKED** = ``2``
- If set, the orientation data comes from tracking data, otherwise, the orientation data contains predicted data.
- .. _class_OpenXRInterface_constant_HAND_JOINT_POSITION_VALID:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>` **HAND_JOINT_POSITION_VALID** = ``4``
- If set, the positional data is valid, otherwise, the positional data is unreliable and should not be used.
- .. _class_OpenXRInterface_constant_HAND_JOINT_POSITION_TRACKED:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>` **HAND_JOINT_POSITION_TRACKED** = ``8``
- If set, the positional data comes from tracking data, otherwise, the positional data contains predicted data.
- .. _class_OpenXRInterface_constant_HAND_JOINT_LINEAR_VELOCITY_VALID:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>` **HAND_JOINT_LINEAR_VELOCITY_VALID** = ``16``
- If set, our linear velocity data is valid, otherwise, the linear velocity data is unreliable and should not be used.
- .. _class_OpenXRInterface_constant_HAND_JOINT_ANGULAR_VELOCITY_VALID:
- .. rst-class:: classref-enumeration-constant
- :ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>` **HAND_JOINT_ANGULAR_VELOCITY_VALID** = ``32``
- If set, our angular velocity data is valid, otherwise, the angular velocity data is unreliable and should not be used.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Property Descriptions
- ---------------------
- .. _class_OpenXRInterface_property_display_refresh_rate:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **display_refresh_rate** = ``0.0``
- .. rst-class:: classref-property-setget
- - void **set_display_refresh_rate** **(** :ref:`float<class_float>` value **)**
- - :ref:`float<class_float>` **get_display_refresh_rate** **(** **)**
- The display refresh rate for the current HMD. Only functional if this feature is supported by the OpenXR runtime and after the interface has been initialized.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_property_foveation_dynamic:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **foveation_dynamic** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_foveation_dynamic** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **get_foveation_dynamic** **(** **)**
- Enable dynamic foveation adjustment, the interface must be initialized before this is accessible. If enabled foveation will automatically adjusted between low and :ref:`foveation_level<class_OpenXRInterface_property_foveation_level>`.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_property_foveation_level:
- .. rst-class:: classref-property
- :ref:`int<class_int>` **foveation_level** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_foveation_level** **(** :ref:`int<class_int>` value **)**
- - :ref:`int<class_int>` **get_foveation_level** **(** **)**
- Set foveation level from 0 (off) to 3 (high), the interface must be initialized before this is accessible.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_property_render_target_size_multiplier:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **render_target_size_multiplier** = ``1.0``
- .. rst-class:: classref-property-setget
- - void **set_render_target_size_multiplier** **(** :ref:`float<class_float>` value **)**
- - :ref:`float<class_float>` **get_render_target_size_multiplier** **(** **)**
- The render size multiplier for the current HMD. Must be set before the interface has been initialized.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Method Descriptions
- -------------------
- .. _class_OpenXRInterface_method_get_action_sets:
- .. rst-class:: classref-method
- :ref:`Array<class_Array>` **get_action_sets** **(** **)** |const|
- Returns a list of action sets registered with Godot (loaded from the action map at runtime).
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_get_available_display_refresh_rates:
- .. rst-class:: classref-method
- :ref:`Array<class_Array>` **get_available_display_refresh_rates** **(** **)** |const|
- Returns display refresh rates supported by the current HMD. Only returned if this feature is supported by the OpenXR runtime and after the interface has been initialized.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_get_hand_joint_angular_velocity:
- .. rst-class:: classref-method
- :ref:`Vector3<class_Vector3>` **get_hand_joint_angular_velocity** **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const|
- If handtracking is enabled, returns the angular velocity of a joint (``joint``) of a hand (``hand``) as provided by OpenXR. This is relative to :ref:`XROrigin3D<class_XROrigin3D>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_get_hand_joint_flags:
- .. rst-class:: classref-method
- |bitfield|\<:ref:`HandJointFlags<enum_OpenXRInterface_HandJointFlags>`\> **get_hand_joint_flags** **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const|
- If handtracking is enabled, returns flags that inform us of the validity of the tracking data.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_get_hand_joint_linear_velocity:
- .. rst-class:: classref-method
- :ref:`Vector3<class_Vector3>` **get_hand_joint_linear_velocity** **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const|
- If handtracking is enabled, returns the linear velocity of a joint (``joint``) of a hand (``hand``) as provided by OpenXR. This is relative to :ref:`XROrigin3D<class_XROrigin3D>` without worldscale applied!
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_get_hand_joint_position:
- .. rst-class:: classref-method
- :ref:`Vector3<class_Vector3>` **get_hand_joint_position** **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const|
- If handtracking is enabled, returns the position of a joint (``joint``) of a hand (``hand``) as provided by OpenXR. This is relative to :ref:`XROrigin3D<class_XROrigin3D>` without worldscale applied!
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_get_hand_joint_radius:
- .. rst-class:: classref-method
- :ref:`float<class_float>` **get_hand_joint_radius** **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const|
- If handtracking is enabled, returns the radius of a joint (``joint``) of a hand (``hand``) as provided by OpenXR. This is without worldscale applied!
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_get_hand_joint_rotation:
- .. rst-class:: classref-method
- :ref:`Quaternion<class_Quaternion>` **get_hand_joint_rotation** **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandJoints<enum_OpenXRInterface_HandJoints>` joint **)** |const|
- If handtracking is enabled, returns the rotation of a joint (``joint``) of a hand (``hand``) as provided by OpenXR.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_get_motion_range:
- .. rst-class:: classref-method
- :ref:`HandMotionRange<enum_OpenXRInterface_HandMotionRange>` **get_motion_range** **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand **)** |const|
- If handtracking is enabled and motion range is supported, gets the currently configured motion range for ``hand``.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_is_action_set_active:
- .. rst-class:: classref-method
- :ref:`bool<class_bool>` **is_action_set_active** **(** :ref:`String<class_String>` name **)** |const|
- Returns ``true`` if the given action set is active.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_is_eye_gaze_interaction_supported:
- .. rst-class:: classref-method
- :ref:`bool<class_bool>` **is_eye_gaze_interaction_supported** **(** **)**
- Returns the capabilities of the eye gaze interaction extension.
- \ **Note:** This only returns a valid value after OpenXR has been initialized.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_is_foveation_supported:
- .. rst-class:: classref-method
- :ref:`bool<class_bool>` **is_foveation_supported** **(** **)** |const|
- Returns ``true`` if OpenXR's foveation extension is supported, the interface must be initialized before this returns a valid value.
- \ **Note:** This feature is only available on the compatibility renderer and currently only available on some stand alone headsets. For Vulkan set :ref:`Viewport.vrs_mode<class_Viewport_property_vrs_mode>` to ``VRS_XR`` on desktop.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_is_hand_tracking_supported:
- .. rst-class:: classref-method
- :ref:`bool<class_bool>` **is_hand_tracking_supported** **(** **)**
- Returns ``true`` if OpenXR's hand tracking is supported and enabled.
- \ **Note:** This only returns a valid value after OpenXR has been initialized.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_set_action_set_active:
- .. rst-class:: classref-method
- void **set_action_set_active** **(** :ref:`String<class_String>` name, :ref:`bool<class_bool>` active **)**
- Sets the given action set as active or inactive.
- .. rst-class:: classref-item-separator
- ----
- .. _class_OpenXRInterface_method_set_motion_range:
- .. rst-class:: classref-method
- void **set_motion_range** **(** :ref:`Hand<enum_OpenXRInterface_Hand>` hand, :ref:`HandMotionRange<enum_OpenXRInterface_HandMotionRange>` motion_range **)**
- If handtracking is enabled and motion range is supported, sets the currently configured motion range for ``hand`` to ``motion_range``.
- .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
- .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
- .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
- .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
- .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
- .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`
- .. |bitfield| replace:: :abbr:`BitField (This value is an integer composed as a bitmask of the following flags.)`
|