class_quat.rst 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. .. Generated automatically by doc/tools/makerst.py in Godot's source tree.
  2. .. DO NOT EDIT THIS FILE, but the Quat.xml source instead.
  3. .. The source is found in doc/classes or modules/<name>/doc_classes.
  4. .. _class_Quat:
  5. Quat
  6. ====
  7. **Category:** Built-In Types
  8. Brief Description
  9. -----------------
  10. Quaternion.
  11. Member Functions
  12. ----------------
  13. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  14. | :ref:`Quat<class_quat>` | :ref:`Quat<class_Quat_Quat>` **(** :ref:`float<class_float>` x, :ref:`float<class_float>` y, :ref:`float<class_float>` z, :ref:`float<class_float>` w **)** |
  15. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  16. | :ref:`Quat<class_quat>` | :ref:`Quat<class_Quat_Quat>` **(** :ref:`Vector3<class_vector3>` axis, :ref:`float<class_float>` angle **)** |
  17. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  18. | :ref:`Quat<class_quat>` | :ref:`Quat<class_Quat_Quat>` **(** :ref:`Basis<class_basis>` from **)** |
  19. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  20. | :ref:`Quat<class_quat>` | :ref:`cubic_slerp<class_Quat_cubic_slerp>` **(** :ref:`Quat<class_quat>` b, :ref:`Quat<class_quat>` pre_a, :ref:`Quat<class_quat>` post_b, :ref:`float<class_float>` t **)** |
  21. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  22. | :ref:`float<class_float>` | :ref:`dot<class_Quat_dot>` **(** :ref:`Quat<class_quat>` b **)** |
  23. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  24. | :ref:`Quat<class_quat>` | :ref:`inverse<class_Quat_inverse>` **(** **)** |
  25. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  26. | :ref:`bool<class_bool>` | :ref:`is_normalized<class_Quat_is_normalized>` **(** **)** |
  27. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  28. | :ref:`float<class_float>` | :ref:`length<class_Quat_length>` **(** **)** |
  29. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  30. | :ref:`float<class_float>` | :ref:`length_squared<class_Quat_length_squared>` **(** **)** |
  31. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  32. | :ref:`Quat<class_quat>` | :ref:`normalized<class_Quat_normalized>` **(** **)** |
  33. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  34. | :ref:`Quat<class_quat>` | :ref:`slerp<class_Quat_slerp>` **(** :ref:`Quat<class_quat>` b, :ref:`float<class_float>` t **)** |
  35. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  36. | :ref:`Quat<class_quat>` | :ref:`slerpni<class_Quat_slerpni>` **(** :ref:`Quat<class_quat>` b, :ref:`float<class_float>` t **)** |
  37. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  38. | :ref:`Vector3<class_vector3>` | :ref:`xform<class_Quat_xform>` **(** :ref:`Vector3<class_vector3>` v **)** |
  39. +--------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  40. Member Variables
  41. ----------------
  42. .. _class_Quat_w:
  43. - :ref:`float<class_float>` **w** - W component of the quaternion. Default value: ``1``
  44. .. _class_Quat_x:
  45. - :ref:`float<class_float>` **x** - X component of the quaternion. Default value: ``0``
  46. .. _class_Quat_y:
  47. - :ref:`float<class_float>` **y** - Y component of the quaternion. Default value: ``0``
  48. .. _class_Quat_z:
  49. - :ref:`float<class_float>` **z** - Z component of the quaternion. Default value: ``0``
  50. Description
  51. -----------
  52. A 4-dimensional vector representing a rotation.
  53. The vector represents a 4 dimensional complex number where multiplication of the basis elements is not commutative (multiplying i with j gives a different result than multiplying j with i).
  54. Multiplying quaternions reproduces rotation sequences. However quaternions need to be often renormalized, or else they suffer from precision issues.
  55. It can be used to perform SLERP (spherical-linear interpolation) between two rotations.
  56. Member Function Description
  57. ---------------------------
  58. .. _class_Quat_Quat:
  59. - :ref:`Quat<class_quat>` **Quat** **(** :ref:`float<class_float>` x, :ref:`float<class_float>` y, :ref:`float<class_float>` z, :ref:`float<class_float>` w **)**
  60. Returns a quaternion defined by these values.
  61. .. _class_Quat_Quat:
  62. - :ref:`Quat<class_quat>` **Quat** **(** :ref:`Vector3<class_vector3>` axis, :ref:`float<class_float>` angle **)**
  63. Returns a quaternion that will rotate around the given axis by the specified angle. The axis must be a normalized vector.
  64. .. _class_Quat_Quat:
  65. - :ref:`Quat<class_quat>` **Quat** **(** :ref:`Basis<class_basis>` from **)**
  66. Returns the rotation matrix corresponding to the given quaternion.
  67. .. _class_Quat_cubic_slerp:
  68. - :ref:`Quat<class_quat>` **cubic_slerp** **(** :ref:`Quat<class_quat>` b, :ref:`Quat<class_quat>` pre_a, :ref:`Quat<class_quat>` post_b, :ref:`float<class_float>` t **)**
  69. Performs a cubic spherical-linear interpolation with another quaternion.
  70. .. _class_Quat_dot:
  71. - :ref:`float<class_float>` **dot** **(** :ref:`Quat<class_quat>` b **)**
  72. Returns the dot product of two quaternions.
  73. .. _class_Quat_inverse:
  74. - :ref:`Quat<class_quat>` **inverse** **(** **)**
  75. Returns the inverse of the quaternion.
  76. .. _class_Quat_is_normalized:
  77. - :ref:`bool<class_bool>` **is_normalized** **(** **)**
  78. Returns whether the quaternion is normalized or not.
  79. .. _class_Quat_length:
  80. - :ref:`float<class_float>` **length** **(** **)**
  81. Returns the length of the quaternion.
  82. .. _class_Quat_length_squared:
  83. - :ref:`float<class_float>` **length_squared** **(** **)**
  84. Returns the length of the quaternion, squared.
  85. .. _class_Quat_normalized:
  86. - :ref:`Quat<class_quat>` **normalized** **(** **)**
  87. Returns a copy of the quaternion, normalized to unit length.
  88. .. _class_Quat_slerp:
  89. - :ref:`Quat<class_quat>` **slerp** **(** :ref:`Quat<class_quat>` b, :ref:`float<class_float>` t **)**
  90. Performs a spherical-linear interpolation with another quaternion.
  91. .. _class_Quat_slerpni:
  92. - :ref:`Quat<class_quat>` **slerpni** **(** :ref:`Quat<class_quat>` b, :ref:`float<class_float>` t **)**
  93. Performs a spherical-linear interpolation with another quaterion without checking if the rotation path is not bigger than 90°.
  94. .. _class_Quat_xform:
  95. - :ref:`Vector3<class_vector3>` **xform** **(** :ref:`Vector3<class_vector3>` v **)**
  96. Transforms the vector ``v`` by this quaternion.