class_vehiclewheel3d.rst 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400
  1. :github_url: hide
  2. .. DO NOT EDIT THIS FILE!!!
  3. .. Generated automatically from Godot engine sources.
  4. .. Generator: https://github.com/godotengine/godot/tree/master/doc/tools/make_rst.py.
  5. .. XML source: https://github.com/godotengine/godot/tree/master/doc/classes/VehicleWheel3D.xml.
  6. .. _class_VehicleWheel3D:
  7. VehicleWheel3D
  8. ==============
  9. **Inherits:** :ref:`Node3D<class_Node3D>` **<** :ref:`Node<class_Node>` **<** :ref:`Object<class_Object>`
  10. A 3D physics body for a :ref:`VehicleBody3D<class_VehicleBody3D>` that simulates the behavior of a wheel.
  11. .. rst-class:: classref-introduction-group
  12. Description
  13. -----------
  14. A node used as a child of a :ref:`VehicleBody3D<class_VehicleBody3D>` parent to simulate the behavior of one of its wheels. This node also acts as a collider to detect if the wheel is touching a surface.
  15. \ **Note:** This class has known issues and isn't designed to provide realistic 3D vehicle physics. If you want advanced vehicle physics, you may need to write your own physics integration using another :ref:`PhysicsBody3D<class_PhysicsBody3D>` class.
  16. .. rst-class:: classref-introduction-group
  17. Tutorials
  18. ---------
  19. - `3D Truck Town Demo <https://godotengine.org/asset-library/asset/524>`__
  20. .. rst-class:: classref-reftable-group
  21. Properties
  22. ----------
  23. .. table::
  24. :widths: auto
  25. +---------------------------+---------------------------------------------------------------------------------+------------+
  26. | :ref:`float<class_float>` | :ref:`brake<class_VehicleWheel3D_property_brake>` | ``0.0`` |
  27. +---------------------------+---------------------------------------------------------------------------------+------------+
  28. | :ref:`float<class_float>` | :ref:`damping_compression<class_VehicleWheel3D_property_damping_compression>` | ``0.83`` |
  29. +---------------------------+---------------------------------------------------------------------------------+------------+
  30. | :ref:`float<class_float>` | :ref:`damping_relaxation<class_VehicleWheel3D_property_damping_relaxation>` | ``0.88`` |
  31. +---------------------------+---------------------------------------------------------------------------------+------------+
  32. | :ref:`float<class_float>` | :ref:`engine_force<class_VehicleWheel3D_property_engine_force>` | ``0.0`` |
  33. +---------------------------+---------------------------------------------------------------------------------+------------+
  34. | :ref:`float<class_float>` | :ref:`steering<class_VehicleWheel3D_property_steering>` | ``0.0`` |
  35. +---------------------------+---------------------------------------------------------------------------------+------------+
  36. | :ref:`float<class_float>` | :ref:`suspension_max_force<class_VehicleWheel3D_property_suspension_max_force>` | ``6000.0`` |
  37. +---------------------------+---------------------------------------------------------------------------------+------------+
  38. | :ref:`float<class_float>` | :ref:`suspension_stiffness<class_VehicleWheel3D_property_suspension_stiffness>` | ``5.88`` |
  39. +---------------------------+---------------------------------------------------------------------------------+------------+
  40. | :ref:`float<class_float>` | :ref:`suspension_travel<class_VehicleWheel3D_property_suspension_travel>` | ``0.2`` |
  41. +---------------------------+---------------------------------------------------------------------------------+------------+
  42. | :ref:`bool<class_bool>` | :ref:`use_as_steering<class_VehicleWheel3D_property_use_as_steering>` | ``false`` |
  43. +---------------------------+---------------------------------------------------------------------------------+------------+
  44. | :ref:`bool<class_bool>` | :ref:`use_as_traction<class_VehicleWheel3D_property_use_as_traction>` | ``false`` |
  45. +---------------------------+---------------------------------------------------------------------------------+------------+
  46. | :ref:`float<class_float>` | :ref:`wheel_friction_slip<class_VehicleWheel3D_property_wheel_friction_slip>` | ``10.5`` |
  47. +---------------------------+---------------------------------------------------------------------------------+------------+
  48. | :ref:`float<class_float>` | :ref:`wheel_radius<class_VehicleWheel3D_property_wheel_radius>` | ``0.5`` |
  49. +---------------------------+---------------------------------------------------------------------------------+------------+
  50. | :ref:`float<class_float>` | :ref:`wheel_rest_length<class_VehicleWheel3D_property_wheel_rest_length>` | ``0.15`` |
  51. +---------------------------+---------------------------------------------------------------------------------+------------+
  52. | :ref:`float<class_float>` | :ref:`wheel_roll_influence<class_VehicleWheel3D_property_wheel_roll_influence>` | ``0.1`` |
  53. +---------------------------+---------------------------------------------------------------------------------+------------+
  54. .. rst-class:: classref-reftable-group
  55. Methods
  56. -------
  57. .. table::
  58. :widths: auto
  59. +-----------------------------+-------------------------------------------------------------------------------------------+
  60. | :ref:`Node3D<class_Node3D>` | :ref:`get_contact_body<class_VehicleWheel3D_method_get_contact_body>` **(** **)** |const| |
  61. +-----------------------------+-------------------------------------------------------------------------------------------+
  62. | :ref:`float<class_float>` | :ref:`get_rpm<class_VehicleWheel3D_method_get_rpm>` **(** **)** |const| |
  63. +-----------------------------+-------------------------------------------------------------------------------------------+
  64. | :ref:`float<class_float>` | :ref:`get_skidinfo<class_VehicleWheel3D_method_get_skidinfo>` **(** **)** |const| |
  65. +-----------------------------+-------------------------------------------------------------------------------------------+
  66. | :ref:`bool<class_bool>` | :ref:`is_in_contact<class_VehicleWheel3D_method_is_in_contact>` **(** **)** |const| |
  67. +-----------------------------+-------------------------------------------------------------------------------------------+
  68. .. rst-class:: classref-section-separator
  69. ----
  70. .. rst-class:: classref-descriptions-group
  71. Property Descriptions
  72. ---------------------
  73. .. _class_VehicleWheel3D_property_brake:
  74. .. rst-class:: classref-property
  75. :ref:`float<class_float>` **brake** = ``0.0``
  76. .. rst-class:: classref-property-setget
  77. - void **set_brake** **(** :ref:`float<class_float>` value **)**
  78. - :ref:`float<class_float>` **get_brake** **(** **)**
  79. Slows down the wheel by applying a braking force. The wheel is only slowed down if it is in contact with a surface. The force you need to apply to adequately slow down your vehicle depends on the :ref:`RigidBody3D.mass<class_RigidBody3D_property_mass>` of the vehicle. For a vehicle with a mass set to 1000, try a value in the 25 - 30 range for hard braking.
  80. .. rst-class:: classref-item-separator
  81. ----
  82. .. _class_VehicleWheel3D_property_damping_compression:
  83. .. rst-class:: classref-property
  84. :ref:`float<class_float>` **damping_compression** = ``0.83``
  85. .. rst-class:: classref-property-setget
  86. - void **set_damping_compression** **(** :ref:`float<class_float>` value **)**
  87. - :ref:`float<class_float>` **get_damping_compression** **(** **)**
  88. The damping applied to the spring when the spring is being compressed. This value should be between 0.0 (no damping) and 1.0. A value of 0.0 means the car will keep bouncing as the spring keeps its energy. A good value for this is around 0.3 for a normal car, 0.5 for a race car.
  89. .. rst-class:: classref-item-separator
  90. ----
  91. .. _class_VehicleWheel3D_property_damping_relaxation:
  92. .. rst-class:: classref-property
  93. :ref:`float<class_float>` **damping_relaxation** = ``0.88``
  94. .. rst-class:: classref-property-setget
  95. - void **set_damping_relaxation** **(** :ref:`float<class_float>` value **)**
  96. - :ref:`float<class_float>` **get_damping_relaxation** **(** **)**
  97. The damping applied to the spring when relaxing. This value should be between 0.0 (no damping) and 1.0. This value should always be slightly higher than the :ref:`damping_compression<class_VehicleWheel3D_property_damping_compression>` property. For a :ref:`damping_compression<class_VehicleWheel3D_property_damping_compression>` value of 0.3, try a relaxation value of 0.5.
  98. .. rst-class:: classref-item-separator
  99. ----
  100. .. _class_VehicleWheel3D_property_engine_force:
  101. .. rst-class:: classref-property
  102. :ref:`float<class_float>` **engine_force** = ``0.0``
  103. .. rst-class:: classref-property-setget
  104. - void **set_engine_force** **(** :ref:`float<class_float>` value **)**
  105. - :ref:`float<class_float>` **get_engine_force** **(** **)**
  106. Accelerates the wheel by applying an engine force. The wheel is only sped up if it is in contact with a surface. The :ref:`RigidBody3D.mass<class_RigidBody3D_property_mass>` of the vehicle has an effect on the acceleration of the vehicle. For a vehicle with a mass set to 1000, try a value in the 25 - 50 range for acceleration.
  107. \ **Note:** The simulation does not take the effect of gears into account, you will need to add logic for this if you wish to simulate gears.
  108. A negative value will result in the wheel reversing.
  109. .. rst-class:: classref-item-separator
  110. ----
  111. .. _class_VehicleWheel3D_property_steering:
  112. .. rst-class:: classref-property
  113. :ref:`float<class_float>` **steering** = ``0.0``
  114. .. rst-class:: classref-property-setget
  115. - void **set_steering** **(** :ref:`float<class_float>` value **)**
  116. - :ref:`float<class_float>` **get_steering** **(** **)**
  117. The steering angle for the wheel, in radians. Setting this to a non-zero value will result in the vehicle turning when it's moving.
  118. .. rst-class:: classref-item-separator
  119. ----
  120. .. _class_VehicleWheel3D_property_suspension_max_force:
  121. .. rst-class:: classref-property
  122. :ref:`float<class_float>` **suspension_max_force** = ``6000.0``
  123. .. rst-class:: classref-property-setget
  124. - void **set_suspension_max_force** **(** :ref:`float<class_float>` value **)**
  125. - :ref:`float<class_float>` **get_suspension_max_force** **(** **)**
  126. The maximum force the spring can resist. This value should be higher than a quarter of the :ref:`RigidBody3D.mass<class_RigidBody3D_property_mass>` of the :ref:`VehicleBody3D<class_VehicleBody3D>` or the spring will not carry the weight of the vehicle. Good results are often obtained by a value that is about 3× to 4× this number.
  127. .. rst-class:: classref-item-separator
  128. ----
  129. .. _class_VehicleWheel3D_property_suspension_stiffness:
  130. .. rst-class:: classref-property
  131. :ref:`float<class_float>` **suspension_stiffness** = ``5.88``
  132. .. rst-class:: classref-property-setget
  133. - void **set_suspension_stiffness** **(** :ref:`float<class_float>` value **)**
  134. - :ref:`float<class_float>` **get_suspension_stiffness** **(** **)**
  135. This value defines the stiffness of the suspension. Use a value lower than 50 for an off-road car, a value between 50 and 100 for a race car and try something around 200 for something like a Formula 1 car.
  136. .. rst-class:: classref-item-separator
  137. ----
  138. .. _class_VehicleWheel3D_property_suspension_travel:
  139. .. rst-class:: classref-property
  140. :ref:`float<class_float>` **suspension_travel** = ``0.2``
  141. .. rst-class:: classref-property-setget
  142. - void **set_suspension_travel** **(** :ref:`float<class_float>` value **)**
  143. - :ref:`float<class_float>` **get_suspension_travel** **(** **)**
  144. This is the distance the suspension can travel. As Godot units are equivalent to meters, keep this setting relatively low. Try a value between 0.1 and 0.3 depending on the type of car.
  145. .. rst-class:: classref-item-separator
  146. ----
  147. .. _class_VehicleWheel3D_property_use_as_steering:
  148. .. rst-class:: classref-property
  149. :ref:`bool<class_bool>` **use_as_steering** = ``false``
  150. .. rst-class:: classref-property-setget
  151. - void **set_use_as_steering** **(** :ref:`bool<class_bool>` value **)**
  152. - :ref:`bool<class_bool>` **is_used_as_steering** **(** **)**
  153. If ``true``, this wheel will be turned when the car steers. This value is used in conjunction with :ref:`VehicleBody3D.steering<class_VehicleBody3D_property_steering>` and ignored if you are using the per-wheel :ref:`steering<class_VehicleWheel3D_property_steering>` value instead.
  154. .. rst-class:: classref-item-separator
  155. ----
  156. .. _class_VehicleWheel3D_property_use_as_traction:
  157. .. rst-class:: classref-property
  158. :ref:`bool<class_bool>` **use_as_traction** = ``false``
  159. .. rst-class:: classref-property-setget
  160. - void **set_use_as_traction** **(** :ref:`bool<class_bool>` value **)**
  161. - :ref:`bool<class_bool>` **is_used_as_traction** **(** **)**
  162. If ``true``, this wheel transfers engine force to the ground to propel the vehicle forward. This value is used in conjunction with :ref:`VehicleBody3D.engine_force<class_VehicleBody3D_property_engine_force>` and ignored if you are using the per-wheel :ref:`engine_force<class_VehicleWheel3D_property_engine_force>` value instead.
  163. .. rst-class:: classref-item-separator
  164. ----
  165. .. _class_VehicleWheel3D_property_wheel_friction_slip:
  166. .. rst-class:: classref-property
  167. :ref:`float<class_float>` **wheel_friction_slip** = ``10.5``
  168. .. rst-class:: classref-property-setget
  169. - void **set_friction_slip** **(** :ref:`float<class_float>` value **)**
  170. - :ref:`float<class_float>` **get_friction_slip** **(** **)**
  171. This determines how much grip this wheel has. It is combined with the friction setting of the surface the wheel is in contact with. 0.0 means no grip, 1.0 is normal grip. For a drift car setup, try setting the grip of the rear wheels slightly lower than the front wheels, or use a lower value to simulate tire wear.
  172. It's best to set this to 1.0 when starting out.
  173. .. rst-class:: classref-item-separator
  174. ----
  175. .. _class_VehicleWheel3D_property_wheel_radius:
  176. .. rst-class:: classref-property
  177. :ref:`float<class_float>` **wheel_radius** = ``0.5``
  178. .. rst-class:: classref-property-setget
  179. - void **set_radius** **(** :ref:`float<class_float>` value **)**
  180. - :ref:`float<class_float>` **get_radius** **(** **)**
  181. The radius of the wheel in meters.
  182. .. rst-class:: classref-item-separator
  183. ----
  184. .. _class_VehicleWheel3D_property_wheel_rest_length:
  185. .. rst-class:: classref-property
  186. :ref:`float<class_float>` **wheel_rest_length** = ``0.15``
  187. .. rst-class:: classref-property-setget
  188. - void **set_suspension_rest_length** **(** :ref:`float<class_float>` value **)**
  189. - :ref:`float<class_float>` **get_suspension_rest_length** **(** **)**
  190. This is the distance in meters the wheel is lowered from its origin point. Don't set this to 0.0 and move the wheel into position, instead move the origin point of your wheel (the gizmo in Godot) to the position the wheel will take when bottoming out, then use the rest length to move the wheel down to the position it should be in when the car is in rest.
  191. .. rst-class:: classref-item-separator
  192. ----
  193. .. _class_VehicleWheel3D_property_wheel_roll_influence:
  194. .. rst-class:: classref-property
  195. :ref:`float<class_float>` **wheel_roll_influence** = ``0.1``
  196. .. rst-class:: classref-property-setget
  197. - void **set_roll_influence** **(** :ref:`float<class_float>` value **)**
  198. - :ref:`float<class_float>` **get_roll_influence** **(** **)**
  199. This value affects the roll of your vehicle. If set to 1.0 for all wheels, your vehicle will be prone to rolling over, while a value of 0.0 will resist body roll.
  200. .. rst-class:: classref-section-separator
  201. ----
  202. .. rst-class:: classref-descriptions-group
  203. Method Descriptions
  204. -------------------
  205. .. _class_VehicleWheel3D_method_get_contact_body:
  206. .. rst-class:: classref-method
  207. :ref:`Node3D<class_Node3D>` **get_contact_body** **(** **)** |const|
  208. Returns the contacting body node if valid in the tree, as :ref:`Node3D<class_Node3D>`. At the moment, :ref:`GridMap<class_GridMap>` is not supported so the node will be always of type :ref:`PhysicsBody3D<class_PhysicsBody3D>`.
  209. Returns ``null`` if the wheel is not in contact with a surface, or the contact body is not a :ref:`PhysicsBody3D<class_PhysicsBody3D>`.
  210. .. rst-class:: classref-item-separator
  211. ----
  212. .. _class_VehicleWheel3D_method_get_rpm:
  213. .. rst-class:: classref-method
  214. :ref:`float<class_float>` **get_rpm** **(** **)** |const|
  215. Returns the rotational speed of the wheel in revolutions per minute.
  216. .. rst-class:: classref-item-separator
  217. ----
  218. .. _class_VehicleWheel3D_method_get_skidinfo:
  219. .. rst-class:: classref-method
  220. :ref:`float<class_float>` **get_skidinfo** **(** **)** |const|
  221. Returns a value between 0.0 and 1.0 that indicates whether this wheel is skidding. 0.0 is skidding (the wheel has lost grip, e.g. icy terrain), 1.0 means not skidding (the wheel has full grip, e.g. dry asphalt road).
  222. .. rst-class:: classref-item-separator
  223. ----
  224. .. _class_VehicleWheel3D_method_is_in_contact:
  225. .. rst-class:: classref-method
  226. :ref:`bool<class_bool>` **is_in_contact** **(** **)** |const|
  227. Returns ``true`` if this wheel is in contact with a surface.
  228. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  229. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  230. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
  231. .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
  232. .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
  233. .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`
  234. .. |bitfield| replace:: :abbr:`BitField (This value is an integer composed as a bitmask of the following flags.)`