class_skeletonik.rst 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281
  1. :github_url: hide
  2. .. Generated automatically by doc/tools/make_rst.py in Godot's source tree.
  3. .. DO NOT EDIT THIS FILE, but the SkeletonIK.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_SkeletonIK:
  6. SkeletonIK
  7. ==========
  8. **Inherits:** :ref:`Node<class_Node>` **<** :ref:`Object<class_Object>`
  9. SkeletonIK is used to place the end bone of a :ref:`Skeleton<class_Skeleton>` bone chain at a certain point in 3D by rotating all bones in the chain accordingly.
  10. Description
  11. -----------
  12. SkeletonIK is used to place the end bone of a :ref:`Skeleton<class_Skeleton>` bone chain at a certain point in 3D by rotating all bones in the chain accordingly. A typical scenario for IK in games is to place a characters feet on the ground or a characters hands on a currently hold object. SkeletonIK uses FabrikInverseKinematic internally to solve the bone chain and applies the results to the :ref:`Skeleton<class_Skeleton>` ``bones_global_pose_override`` property for all affected bones in the chain. If fully applied this overwrites any bone transform from :ref:`Animation<class_Animation>`\ s or bone custom poses set by users. The applied amount can be controlled with the ``interpolation`` property.
  13. ::
  14. # Apply IK effect automatically on every new frame (not the current)
  15. skeleton_ik_node.start()
  16. # Apply IK effect only on the current frame
  17. skeleton_ik_node.start(true)
  18. # Stop IK effect and reset bones_global_pose_override on Skeleton
  19. skeleton_ik_node.stop()
  20. # Apply full IK effect
  21. skeleton_ik_node.set_interpolation(1.0)
  22. # Apply half IK effect
  23. skeleton_ik_node.set_interpolation(0.5)
  24. # Apply zero IK effect (a value at or below 0.01 also removes bones_global_pose_override on Skeleton)
  25. skeleton_ik_node.set_interpolation(0.0)
  26. Tutorials
  27. ---------
  28. - `3D Inverse Kinematics Demo <https://godotengine.org/asset-library/asset/523>`__
  29. Properties
  30. ----------
  31. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  32. | :ref:`float<class_float>` | :ref:`interpolation<class_SkeletonIK_property_interpolation>` | ``1.0`` |
  33. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  34. | :ref:`Vector3<class_Vector3>` | :ref:`magnet<class_SkeletonIK_property_magnet>` | ``Vector3( 0, 0, 0 )`` |
  35. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  36. | :ref:`int<class_int>` | :ref:`max_iterations<class_SkeletonIK_property_max_iterations>` | ``10`` |
  37. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  38. | :ref:`float<class_float>` | :ref:`min_distance<class_SkeletonIK_property_min_distance>` | ``0.01`` |
  39. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  40. | :ref:`bool<class_bool>` | :ref:`override_tip_basis<class_SkeletonIK_property_override_tip_basis>` | ``true`` |
  41. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  42. | :ref:`String<class_String>` | :ref:`root_bone<class_SkeletonIK_property_root_bone>` | ``""`` |
  43. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  44. | :ref:`Transform<class_Transform>` | :ref:`target<class_SkeletonIK_property_target>` | ``Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )`` |
  45. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  46. | :ref:`NodePath<class_NodePath>` | :ref:`target_node<class_SkeletonIK_property_target_node>` | ``NodePath("")`` |
  47. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  48. | :ref:`String<class_String>` | :ref:`tip_bone<class_SkeletonIK_property_tip_bone>` | ``""`` |
  49. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  50. | :ref:`bool<class_bool>` | :ref:`use_magnet<class_SkeletonIK_property_use_magnet>` | ``false`` |
  51. +-----------------------------------+-------------------------------------------------------------------------+-----------------------------------------------------+
  52. Methods
  53. -------
  54. +---------------------------------+------------------------------------------------------------------------------------------------+
  55. | :ref:`Skeleton<class_Skeleton>` | :ref:`get_parent_skeleton<class_SkeletonIK_method_get_parent_skeleton>` **(** **)** |const| |
  56. +---------------------------------+------------------------------------------------------------------------------------------------+
  57. | :ref:`bool<class_bool>` | :ref:`is_running<class_SkeletonIK_method_is_running>` **(** **)** |
  58. +---------------------------------+------------------------------------------------------------------------------------------------+
  59. | void | :ref:`start<class_SkeletonIK_method_start>` **(** :ref:`bool<class_bool>` one_time=false **)** |
  60. +---------------------------------+------------------------------------------------------------------------------------------------+
  61. | void | :ref:`stop<class_SkeletonIK_method_stop>` **(** **)** |
  62. +---------------------------------+------------------------------------------------------------------------------------------------+
  63. Property Descriptions
  64. ---------------------
  65. .. _class_SkeletonIK_property_interpolation:
  66. - :ref:`float<class_float>` **interpolation**
  67. +-----------+--------------------------+
  68. | *Default* | ``1.0`` |
  69. +-----------+--------------------------+
  70. | *Setter* | set_interpolation(value) |
  71. +-----------+--------------------------+
  72. | *Getter* | get_interpolation() |
  73. +-----------+--------------------------+
  74. Interpolation value for how much the IK results are applied to the current skeleton bone chain. A value of ``1.0`` will overwrite all skeleton bone transforms completely while a value of ``0.0`` will visually disable the SkeletonIK. A value at or below ``0.01`` also calls :ref:`Skeleton.clear_bones_global_pose_override<class_Skeleton_method_clear_bones_global_pose_override>`.
  75. ----
  76. .. _class_SkeletonIK_property_magnet:
  77. - :ref:`Vector3<class_Vector3>` **magnet**
  78. +-----------+----------------------------+
  79. | *Default* | ``Vector3( 0, 0, 0 )`` |
  80. +-----------+----------------------------+
  81. | *Setter* | set_magnet_position(value) |
  82. +-----------+----------------------------+
  83. | *Getter* | get_magnet_position() |
  84. +-----------+----------------------------+
  85. Secondary target position (first is :ref:`target<class_SkeletonIK_property_target>` property or :ref:`target_node<class_SkeletonIK_property_target_node>`) for the IK chain. Use magnet position (pole target) to control the bending of the IK chain. Only works if the bone chain has more than 2 bones. The middle chain bone position will be linearly interpolated with the magnet position.
  86. ----
  87. .. _class_SkeletonIK_property_max_iterations:
  88. - :ref:`int<class_int>` **max_iterations**
  89. +-----------+---------------------------+
  90. | *Default* | ``10`` |
  91. +-----------+---------------------------+
  92. | *Setter* | set_max_iterations(value) |
  93. +-----------+---------------------------+
  94. | *Getter* | get_max_iterations() |
  95. +-----------+---------------------------+
  96. Number of iteration loops used by the IK solver to produce more accurate (and elegant) bone chain results.
  97. ----
  98. .. _class_SkeletonIK_property_min_distance:
  99. - :ref:`float<class_float>` **min_distance**
  100. +-----------+-------------------------+
  101. | *Default* | ``0.01`` |
  102. +-----------+-------------------------+
  103. | *Setter* | set_min_distance(value) |
  104. +-----------+-------------------------+
  105. | *Getter* | get_min_distance() |
  106. +-----------+-------------------------+
  107. The minimum distance between bone and goal target. If the distance is below this value, the IK solver stops further iterations.
  108. ----
  109. .. _class_SkeletonIK_property_override_tip_basis:
  110. - :ref:`bool<class_bool>` **override_tip_basis**
  111. +-----------+-------------------------------+
  112. | *Default* | ``true`` |
  113. +-----------+-------------------------------+
  114. | *Setter* | set_override_tip_basis(value) |
  115. +-----------+-------------------------------+
  116. | *Getter* | is_override_tip_basis() |
  117. +-----------+-------------------------------+
  118. If ``true`` overwrites the rotation of the tip bone with the rotation of the :ref:`target<class_SkeletonIK_property_target>` (or :ref:`target_node<class_SkeletonIK_property_target_node>` if defined).
  119. ----
  120. .. _class_SkeletonIK_property_root_bone:
  121. - :ref:`String<class_String>` **root_bone**
  122. +-----------+----------------------+
  123. | *Default* | ``""`` |
  124. +-----------+----------------------+
  125. | *Setter* | set_root_bone(value) |
  126. +-----------+----------------------+
  127. | *Getter* | get_root_bone() |
  128. +-----------+----------------------+
  129. The name of the current root bone, the first bone in the IK chain.
  130. ----
  131. .. _class_SkeletonIK_property_target:
  132. - :ref:`Transform<class_Transform>` **target**
  133. +-----------+-----------------------------------------------------+
  134. | *Default* | ``Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )`` |
  135. +-----------+-----------------------------------------------------+
  136. | *Setter* | set_target_transform(value) |
  137. +-----------+-----------------------------------------------------+
  138. | *Getter* | get_target_transform() |
  139. +-----------+-----------------------------------------------------+
  140. First target of the IK chain where the tip bone is placed and, if :ref:`override_tip_basis<class_SkeletonIK_property_override_tip_basis>` is ``true``, how the tip bone is rotated. If a :ref:`target_node<class_SkeletonIK_property_target_node>` path is available the nodes transform is used instead and this property is ignored.
  141. ----
  142. .. _class_SkeletonIK_property_target_node:
  143. - :ref:`NodePath<class_NodePath>` **target_node**
  144. +-----------+------------------------+
  145. | *Default* | ``NodePath("")`` |
  146. +-----------+------------------------+
  147. | *Setter* | set_target_node(value) |
  148. +-----------+------------------------+
  149. | *Getter* | get_target_node() |
  150. +-----------+------------------------+
  151. Target node :ref:`NodePath<class_NodePath>` for the IK chain. If available, the node's current :ref:`Transform<class_Transform>` is used instead of the :ref:`target<class_SkeletonIK_property_target>` property.
  152. ----
  153. .. _class_SkeletonIK_property_tip_bone:
  154. - :ref:`String<class_String>` **tip_bone**
  155. +-----------+---------------------+
  156. | *Default* | ``""`` |
  157. +-----------+---------------------+
  158. | *Setter* | set_tip_bone(value) |
  159. +-----------+---------------------+
  160. | *Getter* | get_tip_bone() |
  161. +-----------+---------------------+
  162. The name of the current tip bone, the last bone in the IK chain placed at the :ref:`target<class_SkeletonIK_property_target>` transform (or :ref:`target_node<class_SkeletonIK_property_target_node>` if defined).
  163. ----
  164. .. _class_SkeletonIK_property_use_magnet:
  165. - :ref:`bool<class_bool>` **use_magnet**
  166. +-----------+-----------------------+
  167. | *Default* | ``false`` |
  168. +-----------+-----------------------+
  169. | *Setter* | set_use_magnet(value) |
  170. +-----------+-----------------------+
  171. | *Getter* | is_using_magnet() |
  172. +-----------+-----------------------+
  173. If ``true``, instructs the IK solver to consider the secondary magnet target (pole target) when calculating the bone chain. Use the magnet position (pole target) to control the bending of the IK chain.
  174. Method Descriptions
  175. -------------------
  176. .. _class_SkeletonIK_method_get_parent_skeleton:
  177. - :ref:`Skeleton<class_Skeleton>` **get_parent_skeleton** **(** **)** |const|
  178. Returns the parent :ref:`Skeleton<class_Skeleton>` Node that was present when SkeletonIK entered the :ref:`SceneTree<class_SceneTree>`. Returns null if the parent node was not a :ref:`Skeleton<class_Skeleton>` Node when SkeletonIK entered the :ref:`SceneTree<class_SceneTree>`.
  179. ----
  180. .. _class_SkeletonIK_method_is_running:
  181. - :ref:`bool<class_bool>` **is_running** **(** **)**
  182. Returns ``true`` if SkeletonIK is applying IK effects on continues frames to the :ref:`Skeleton<class_Skeleton>` bones. Returns ``false`` if SkeletonIK is stopped or :ref:`start<class_SkeletonIK_method_start>` was used with the ``one_time`` parameter set to ``true``.
  183. ----
  184. .. _class_SkeletonIK_method_start:
  185. - void **start** **(** :ref:`bool<class_bool>` one_time=false **)**
  186. Starts applying IK effects on each frame to the :ref:`Skeleton<class_Skeleton>` bones but will only take effect starting on the next frame. If ``one_time`` is ``true``, this will take effect immediately but also reset on the next frame.
  187. ----
  188. .. _class_SkeletonIK_method_stop:
  189. - void **stop** **(** **)**
  190. Stops applying IK effects on each frame to the :ref:`Skeleton<class_Skeleton>` bones and also calls :ref:`Skeleton.clear_bones_global_pose_override<class_Skeleton_method_clear_bones_global_pose_override>` to remove existing overrides on all bones.
  191. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  192. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  193. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`