class_shape.rst 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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 Shape.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_Shape:
  6. Shape
  7. =====
  8. **Inherits:** :ref:`Resource<class_Resource>` **<** :ref:`Reference<class_Reference>` **<** :ref:`Object<class_Object>`
  9. **Inherited By:** :ref:`BoxShape<class_BoxShape>`, :ref:`CapsuleShape<class_CapsuleShape>`, :ref:`ConcavePolygonShape<class_ConcavePolygonShape>`, :ref:`ConvexPolygonShape<class_ConvexPolygonShape>`, :ref:`CylinderShape<class_CylinderShape>`, :ref:`HeightMapShape<class_HeightMapShape>`, :ref:`PlaneShape<class_PlaneShape>`, :ref:`RayShape<class_RayShape>`, :ref:`SphereShape<class_SphereShape>`
  10. Base class for all 3D shape resources.
  11. Description
  12. -----------
  13. Base class for all 3D shape resources. Nodes that inherit from this can be used as shapes for a :ref:`PhysicsBody<class_PhysicsBody>` or :ref:`Area<class_Area>` objects.
  14. Tutorials
  15. ---------
  16. - :doc:`../tutorials/physics/physics_introduction`
  17. Properties
  18. ----------
  19. +---------------------------+--------------------------------------------+----------+
  20. | :ref:`float<class_float>` | :ref:`margin<class_Shape_property_margin>` | ``0.04`` |
  21. +---------------------------+--------------------------------------------+----------+
  22. Methods
  23. -------
  24. +-----------------------------------+----------------------------------------------------------------------+
  25. | :ref:`ArrayMesh<class_ArrayMesh>` | :ref:`get_debug_mesh<class_Shape_method_get_debug_mesh>` **(** **)** |
  26. +-----------------------------------+----------------------------------------------------------------------+
  27. Property Descriptions
  28. ---------------------
  29. .. _class_Shape_property_margin:
  30. - :ref:`float<class_float>` **margin**
  31. +-----------+-------------------+
  32. | *Default* | ``0.04`` |
  33. +-----------+-------------------+
  34. | *Setter* | set_margin(value) |
  35. +-----------+-------------------+
  36. | *Getter* | get_margin() |
  37. +-----------+-------------------+
  38. The collision margin for the shape. Used in Bullet Physics only.
  39. Collision margins allow collision detection to be more efficient by adding an extra shell around shapes. Collision algorithms are more expensive when objects overlap by more than their margin, so a higher value for margins is better for performance, at the cost of accuracy around edges as it makes them less sharp.
  40. Method Descriptions
  41. -------------------
  42. .. _class_Shape_method_get_debug_mesh:
  43. - :ref:`ArrayMesh<class_ArrayMesh>` **get_debug_mesh** **(** **)**
  44. Returns the :ref:`ArrayMesh<class_ArrayMesh>` used to draw the debug collision for this ``Shape``.
  45. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  46. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  47. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`