123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383 |
- :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/doc/classes/XRPositionalTracker.xml.
- .. _class_XRPositionalTracker:
- XRPositionalTracker
- ===================
- **Inherits:** :ref:`RefCounted<class_RefCounted>` **<** :ref:`Object<class_Object>`
- A tracked object.
- .. rst-class:: classref-introduction-group
- Description
- -----------
- An instance of this object represents a device that is tracked, such as a controller or anchor point. HMDs aren't represented here as they are handled internally.
- As controllers are turned on and the :ref:`XRInterface<class_XRInterface>` detects them, instances of this object are automatically added to this list of active tracking objects accessible through the :ref:`XRServer<class_XRServer>`.
- The :ref:`XRController3D<class_XRController3D>` and :ref:`XRAnchor3D<class_XRAnchor3D>` both consume objects of this type and should be used in your project. The positional trackers are just under-the-hood objects that make this all work. These are mostly exposed so that GDExtension-based interfaces can interact with them.
- .. rst-class:: classref-introduction-group
- Tutorials
- ---------
- - :doc:`XR documentation index <../tutorials/xr/index>`
- .. rst-class:: classref-reftable-group
- Properties
- ----------
- .. table::
- :widths: auto
- +----------------------------------------------------------+--------------------------------------------------------------------+----------------+
- | :ref:`String<class_String>` | :ref:`description<class_XRPositionalTracker_property_description>` | ``""`` |
- +----------------------------------------------------------+--------------------------------------------------------------------+----------------+
- | :ref:`TrackerHand<enum_XRPositionalTracker_TrackerHand>` | :ref:`hand<class_XRPositionalTracker_property_hand>` | ``0`` |
- +----------------------------------------------------------+--------------------------------------------------------------------+----------------+
- | :ref:`StringName<class_StringName>` | :ref:`name<class_XRPositionalTracker_property_name>` | ``&"Unknown"`` |
- +----------------------------------------------------------+--------------------------------------------------------------------+----------------+
- | :ref:`String<class_String>` | :ref:`profile<class_XRPositionalTracker_property_profile>` | ``""`` |
- +----------------------------------------------------------+--------------------------------------------------------------------+----------------+
- | :ref:`TrackerType<enum_XRServer_TrackerType>` | :ref:`type<class_XRPositionalTracker_property_type>` | ``128`` |
- +----------------------------------------------------------+--------------------------------------------------------------------+----------------+
- .. rst-class:: classref-reftable-group
- Methods
- -------
- .. table::
- :widths: auto
- +-------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Variant<class_Variant>` | :ref:`get_input<class_XRPositionalTracker_method_get_input>` **(** :ref:`StringName<class_StringName>` name **)** |const| |
- +-------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`XRPose<class_XRPose>` | :ref:`get_pose<class_XRPositionalTracker_method_get_pose>` **(** :ref:`StringName<class_StringName>` name **)** |const| |
- +-------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`has_pose<class_XRPositionalTracker_method_has_pose>` **(** :ref:`StringName<class_StringName>` name **)** |const| |
- +-------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`invalidate_pose<class_XRPositionalTracker_method_invalidate_pose>` **(** :ref:`StringName<class_StringName>` name **)** |
- +-------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_input<class_XRPositionalTracker_method_set_input>` **(** :ref:`StringName<class_StringName>` name, :ref:`Variant<class_Variant>` value **)** |
- +-------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_pose<class_XRPositionalTracker_method_set_pose>` **(** :ref:`StringName<class_StringName>` name, :ref:`Transform3D<class_Transform3D>` transform, :ref:`Vector3<class_Vector3>` linear_velocity, :ref:`Vector3<class_Vector3>` angular_velocity, :ref:`TrackingConfidence<enum_XRPose_TrackingConfidence>` tracking_confidence **)** |
- +-------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Signals
- -------
- .. _class_XRPositionalTracker_signal_button_pressed:
- .. rst-class:: classref-signal
- **button_pressed** **(** :ref:`String<class_String>` name **)**
- Emitted when a button on this tracker is pressed. Note that many XR runtimes allow other inputs to be mapped to buttons.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_signal_button_released:
- .. rst-class:: classref-signal
- **button_released** **(** :ref:`String<class_String>` name **)**
- Emitted when a button on this tracker is released.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_signal_input_float_changed:
- .. rst-class:: classref-signal
- **input_float_changed** **(** :ref:`String<class_String>` name, :ref:`float<class_float>` value **)**
- Emitted when a trigger or similar input on this tracker changes value.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_signal_input_vector2_changed:
- .. rst-class:: classref-signal
- **input_vector2_changed** **(** :ref:`String<class_String>` name, :ref:`Vector2<class_Vector2>` vector **)**
- Emitted when a thumbstick or thumbpad on this tracker moves.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_signal_pose_changed:
- .. rst-class:: classref-signal
- **pose_changed** **(** :ref:`XRPose<class_XRPose>` pose **)**
- Emitted when the state of a pose tracked by this tracker changes.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_signal_pose_lost_tracking:
- .. rst-class:: classref-signal
- **pose_lost_tracking** **(** :ref:`XRPose<class_XRPose>` pose **)**
- Emitted when a pose tracked by this tracker stops getting updated tracking data.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_signal_profile_changed:
- .. rst-class:: classref-signal
- **profile_changed** **(** :ref:`String<class_String>` role **)**
- Emitted when the profile of our tracker changes.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Enumerations
- ------------
- .. _enum_XRPositionalTracker_TrackerHand:
- .. rst-class:: classref-enumeration
- enum **TrackerHand**:
- .. _class_XRPositionalTracker_constant_TRACKER_HAND_UNKNOWN:
- .. rst-class:: classref-enumeration-constant
- :ref:`TrackerHand<enum_XRPositionalTracker_TrackerHand>` **TRACKER_HAND_UNKNOWN** = ``0``
- The hand this tracker is held in is unknown or not applicable.
- .. _class_XRPositionalTracker_constant_TRACKER_HAND_LEFT:
- .. rst-class:: classref-enumeration-constant
- :ref:`TrackerHand<enum_XRPositionalTracker_TrackerHand>` **TRACKER_HAND_LEFT** = ``1``
- This tracker is the left hand controller.
- .. _class_XRPositionalTracker_constant_TRACKER_HAND_RIGHT:
- .. rst-class:: classref-enumeration-constant
- :ref:`TrackerHand<enum_XRPositionalTracker_TrackerHand>` **TRACKER_HAND_RIGHT** = ``2``
- This tracker is the right hand controller.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Property Descriptions
- ---------------------
- .. _class_XRPositionalTracker_property_description:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **description** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_tracker_desc** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_tracker_desc** **(** **)**
- The description of this tracker.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_property_hand:
- .. rst-class:: classref-property
- :ref:`TrackerHand<enum_XRPositionalTracker_TrackerHand>` **hand** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_tracker_hand** **(** :ref:`TrackerHand<enum_XRPositionalTracker_TrackerHand>` value **)**
- - :ref:`TrackerHand<enum_XRPositionalTracker_TrackerHand>` **get_tracker_hand** **(** **)**
- Defines which hand this tracker relates to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_property_name:
- .. rst-class:: classref-property
- :ref:`StringName<class_StringName>` **name** = ``&"Unknown"``
- .. rst-class:: classref-property-setget
- - void **set_tracker_name** **(** :ref:`StringName<class_StringName>` value **)**
- - :ref:`StringName<class_StringName>` **get_tracker_name** **(** **)**
- The unique name of this tracker. The trackers that are available differ between various XR runtimes and can often be configured by the user. Godot maintains a number of reserved names that it expects the :ref:`XRInterface<class_XRInterface>` to implement if applicable:
- - ``left_hand`` identifies the controller held in the players left hand
- - ``right_hand`` identifies the controller held in the players right hand
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_property_profile:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **profile** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_tracker_profile** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_tracker_profile** **(** **)**
- The profile associated with this tracker, interface dependent but will indicate the type of controller being tracked.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_property_type:
- .. rst-class:: classref-property
- :ref:`TrackerType<enum_XRServer_TrackerType>` **type** = ``128``
- .. rst-class:: classref-property-setget
- - void **set_tracker_type** **(** :ref:`TrackerType<enum_XRServer_TrackerType>` value **)**
- - :ref:`TrackerType<enum_XRServer_TrackerType>` **get_tracker_type** **(** **)**
- The type of tracker.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Method Descriptions
- -------------------
- .. _class_XRPositionalTracker_method_get_input:
- .. rst-class:: classref-method
- :ref:`Variant<class_Variant>` **get_input** **(** :ref:`StringName<class_StringName>` name **)** |const|
- Returns an input for this tracker. It can return a boolean, float or :ref:`Vector2<class_Vector2>` value depending on whether the input is a button, trigger or thumbstick/thumbpad.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_method_get_pose:
- .. rst-class:: classref-method
- :ref:`XRPose<class_XRPose>` **get_pose** **(** :ref:`StringName<class_StringName>` name **)** |const|
- Returns the current :ref:`XRPose<class_XRPose>` state object for the bound ``name`` pose.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_method_has_pose:
- .. rst-class:: classref-method
- :ref:`bool<class_bool>` **has_pose** **(** :ref:`StringName<class_StringName>` name **)** |const|
- Returns ``true`` if the tracker is available and is currently tracking the bound ``name`` pose.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_method_invalidate_pose:
- .. rst-class:: classref-method
- void **invalidate_pose** **(** :ref:`StringName<class_StringName>` name **)**
- Marks this pose as invalid, we don't clear the last reported state but it allows users to decide if trackers need to be hidden if we lose tracking or just remain at their last known position.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_method_set_input:
- .. rst-class:: classref-method
- void **set_input** **(** :ref:`StringName<class_StringName>` name, :ref:`Variant<class_Variant>` value **)**
- Changes the value for the given input. This method is called by a :ref:`XRInterface<class_XRInterface>` implementation and should not be used directly.
- .. rst-class:: classref-item-separator
- ----
- .. _class_XRPositionalTracker_method_set_pose:
- .. rst-class:: classref-method
- void **set_pose** **(** :ref:`StringName<class_StringName>` name, :ref:`Transform3D<class_Transform3D>` transform, :ref:`Vector3<class_Vector3>` linear_velocity, :ref:`Vector3<class_Vector3>` angular_velocity, :ref:`TrackingConfidence<enum_XRPose_TrackingConfidence>` tracking_confidence **)**
- Sets the transform, linear velocity, angular velocity and tracking confidence for the given pose. This method is called by a :ref:`XRInterface<class_XRInterface>` implementation and should not be used directly.
- .. |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.)`
|