class_area.rst 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. .. _class_Area:
  2. Area
  3. ====
  4. **Inherits:** :ref:`CollisionObject<class_collisionobject>` **<** :ref:`Spatial<class_spatial>` **<** :ref:`Node<class_node>` **<** :ref:`Object<class_object>`
  5. **Category:** Core
  6. Brief Description
  7. -----------------
  8. Member Functions
  9. ----------------
  10. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  11. | void | :ref:`set_space_override_mode<class_Area_set_space_override_mode>` **(** :ref:`int<class_int>` enable **)** |
  12. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  13. | :ref:`int<class_int>` | :ref:`get_space_override_mode<class_Area_get_space_override_mode>` **(** **)** const |
  14. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  15. | void | :ref:`set_gravity_is_point<class_Area_set_gravity_is_point>` **(** :ref:`bool<class_bool>` enable **)** |
  16. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  17. | :ref:`bool<class_bool>` | :ref:`is_gravity_a_point<class_Area_is_gravity_a_point>` **(** **)** const |
  18. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  19. | void | :ref:`set_gravity_distance_scale<class_Area_set_gravity_distance_scale>` **(** :ref:`float<class_float>` distance_scale **)** |
  20. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  21. | :ref:`float<class_float>` | :ref:`get_gravity_distance_scale<class_Area_get_gravity_distance_scale>` **(** **)** const |
  22. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  23. | void | :ref:`set_gravity_vector<class_Area_set_gravity_vector>` **(** :ref:`Vector3<class_vector3>` vector **)** |
  24. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  25. | :ref:`Vector3<class_vector3>` | :ref:`get_gravity_vector<class_Area_get_gravity_vector>` **(** **)** const |
  26. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  27. | void | :ref:`set_gravity<class_Area_set_gravity>` **(** :ref:`float<class_float>` gravity **)** |
  28. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  29. | :ref:`float<class_float>` | :ref:`get_gravity<class_Area_get_gravity>` **(** **)** const |
  30. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  31. | void | :ref:`set_angular_damp<class_Area_set_angular_damp>` **(** :ref:`float<class_float>` angular_damp **)** |
  32. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  33. | :ref:`float<class_float>` | :ref:`get_angular_damp<class_Area_get_angular_damp>` **(** **)** const |
  34. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  35. | void | :ref:`set_linear_damp<class_Area_set_linear_damp>` **(** :ref:`float<class_float>` linear_damp **)** |
  36. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  37. | :ref:`float<class_float>` | :ref:`get_linear_damp<class_Area_get_linear_damp>` **(** **)** const |
  38. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  39. | void | :ref:`set_priority<class_Area_set_priority>` **(** :ref:`float<class_float>` priority **)** |
  40. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  41. | :ref:`float<class_float>` | :ref:`get_priority<class_Area_get_priority>` **(** **)** const |
  42. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  43. | void | :ref:`set_monitorable<class_Area_set_monitorable>` **(** :ref:`bool<class_bool>` enable **)** |
  44. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  45. | :ref:`bool<class_bool>` | :ref:`is_monitorable<class_Area_is_monitorable>` **(** **)** const |
  46. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  47. | void | :ref:`set_enable_monitoring<class_Area_set_enable_monitoring>` **(** :ref:`bool<class_bool>` enable **)** |
  48. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  49. | :ref:`bool<class_bool>` | :ref:`is_monitoring_enabled<class_Area_is_monitoring_enabled>` **(** **)** const |
  50. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  51. | :ref:`Array<class_array>` | :ref:`get_overlapping_bodies<class_Area_get_overlapping_bodies>` **(** **)** const |
  52. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  53. | :ref:`Array<class_array>` | :ref:`get_overlapping_areas<class_Area_get_overlapping_areas>` **(** **)** const |
  54. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  55. | :ref:`PhysicsBody<class_physicsbody>` | :ref:`overlaps_body<class_Area_overlaps_body>` **(** :ref:`Object<class_object>` body **)** const |
  56. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  57. | :ref:`Area<class_area>` | :ref:`overlaps_area<class_Area_overlaps_area>` **(** :ref:`Object<class_object>` area **)** const |
  58. +----------------------------------------+---------------------------------------------------------------------------------------------------------------------------------+
  59. Signals
  60. -------
  61. - **body_enter** **(** :ref:`Object<class_object>` body **)**
  62. - **body_enter_shape** **(** :ref:`int<class_int>` body_id, :ref:`Object<class_object>` body, :ref:`int<class_int>` body_shape, :ref:`int<class_int>` area_shape **)**
  63. - **area_enter** **(** :ref:`Object<class_object>` area **)**
  64. - **area_enter_shape** **(** :ref:`int<class_int>` area_id, :ref:`Object<class_object>` area, :ref:`int<class_int>` area_shape, :ref:`int<class_int>` area_shape **)**
  65. - **body_exit** **(** :ref:`Object<class_object>` body **)**
  66. - **body_exit_shape** **(** :ref:`int<class_int>` body_id, :ref:`Object<class_object>` body, :ref:`int<class_int>` body_shape, :ref:`int<class_int>` area_shape **)**
  67. - **area_exit** **(** :ref:`Object<class_object>` area **)**
  68. - **area_exit_shape** **(** :ref:`int<class_int>` area_id, :ref:`Object<class_object>` area, :ref:`int<class_int>` area_shape, :ref:`int<class_int>` area_shape **)**
  69. Member Function Description
  70. ---------------------------
  71. .. _class_Area_set_space_override_mode:
  72. - void **set_space_override_mode** **(** :ref:`int<class_int>` enable **)**
  73. Set the space override mode. This mode controls how an area affects gravity and damp.
  74. AREA_SPACE_OVERRIDE_DISABLED: This area does not affect gravity/damp. These are generally areas that exist only to detect collisions, and objects entering or exiting them.
  75. AREA_SPACE_OVERRIDE_COMBINE: This area adds its gravity/damp values to whatever has been calculated so far. This way, many overlapping areas can combine their physics to make interesting effects.
  76. AREA_SPACE_OVERRIDE_COMBINE_REPLACE: This area adds its gravity/damp values to whatever has been calculated so far. Then stops taking into account the rest of the areas, even the default one.
  77. AREA_SPACE_OVERRIDE_REPLACE: This area replaces any gravity/damp, even the default one, and stops taking into account the rest of the areas.
  78. AREA_SPACE_OVERRIDE_REPLACE_COMBINE: This area replaces any gravity/damp calculated so far, but keeps calculating the rest of the areas, down to the default one.
  79. .. _class_Area_get_space_override_mode:
  80. - :ref:`int<class_int>` **get_space_override_mode** **(** **)** const
  81. .. _class_Area_set_gravity_is_point:
  82. - void **set_gravity_is_point** **(** :ref:`bool<class_bool>` enable **)**
  83. .. _class_Area_is_gravity_a_point:
  84. - :ref:`bool<class_bool>` **is_gravity_a_point** **(** **)** const
  85. .. _class_Area_set_gravity_distance_scale:
  86. - void **set_gravity_distance_scale** **(** :ref:`float<class_float>` distance_scale **)**
  87. .. _class_Area_get_gravity_distance_scale:
  88. - :ref:`float<class_float>` **get_gravity_distance_scale** **(** **)** const
  89. .. _class_Area_set_gravity_vector:
  90. - void **set_gravity_vector** **(** :ref:`Vector3<class_vector3>` vector **)**
  91. .. _class_Area_get_gravity_vector:
  92. - :ref:`Vector3<class_vector3>` **get_gravity_vector** **(** **)** const
  93. .. _class_Area_set_gravity:
  94. - void **set_gravity** **(** :ref:`float<class_float>` gravity **)**
  95. .. _class_Area_get_gravity:
  96. - :ref:`float<class_float>` **get_gravity** **(** **)** const
  97. .. _class_Area_set_angular_damp:
  98. - void **set_angular_damp** **(** :ref:`float<class_float>` angular_damp **)**
  99. .. _class_Area_get_angular_damp:
  100. - :ref:`float<class_float>` **get_angular_damp** **(** **)** const
  101. .. _class_Area_set_linear_damp:
  102. - void **set_linear_damp** **(** :ref:`float<class_float>` linear_damp **)**
  103. .. _class_Area_get_linear_damp:
  104. - :ref:`float<class_float>` **get_linear_damp** **(** **)** const
  105. .. _class_Area_set_priority:
  106. - void **set_priority** **(** :ref:`float<class_float>` priority **)**
  107. .. _class_Area_get_priority:
  108. - :ref:`float<class_float>` **get_priority** **(** **)** const
  109. .. _class_Area_set_monitorable:
  110. - void **set_monitorable** **(** :ref:`bool<class_bool>` enable **)**
  111. .. _class_Area_is_monitorable:
  112. - :ref:`bool<class_bool>` **is_monitorable** **(** **)** const
  113. .. _class_Area_set_enable_monitoring:
  114. - void **set_enable_monitoring** **(** :ref:`bool<class_bool>` enable **)**
  115. .. _class_Area_is_monitoring_enabled:
  116. - :ref:`bool<class_bool>` **is_monitoring_enabled** **(** **)** const
  117. .. _class_Area_get_overlapping_bodies:
  118. - :ref:`Array<class_array>` **get_overlapping_bodies** **(** **)** const
  119. .. _class_Area_get_overlapping_areas:
  120. - :ref:`Array<class_array>` **get_overlapping_areas** **(** **)** const
  121. .. _class_Area_overlaps_body:
  122. - :ref:`PhysicsBody<class_physicsbody>` **overlaps_body** **(** :ref:`Object<class_object>` body **)** const
  123. .. _class_Area_overlaps_area:
  124. - :ref:`Area<class_area>` **overlaps_area** **(** :ref:`Object<class_object>` area **)** const