class_visibilityenabler2d.rst 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  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 VisibilityEnabler2D.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_VisibilityEnabler2D:
  6. VisibilityEnabler2D
  7. ===================
  8. **Inherits:** :ref:`VisibilityNotifier2D<class_VisibilityNotifier2D>` **<** :ref:`Node2D<class_Node2D>` **<** :ref:`CanvasItem<class_CanvasItem>` **<** :ref:`Node<class_Node>` **<** :ref:`Object<class_Object>`
  9. Enables certain nodes only when approximately visible.
  10. Description
  11. -----------
  12. The VisibilityEnabler2D will disable :ref:`RigidBody2D<class_RigidBody2D>`, :ref:`AnimationPlayer<class_AnimationPlayer>`, and other nodes when they are not visible. It will only affect nodes with the same root node as the VisibilityEnabler2D, and the root node itself.
  13. If you just want to receive notifications, use :ref:`VisibilityNotifier2D<class_VisibilityNotifier2D>` instead.
  14. **Note:** For performance reasons, VisibilityEnabler2D uses an approximate heuristic with precision determined by :ref:`ProjectSettings.world/2d/cell_size<class_ProjectSettings_property_world/2d/cell_size>`. If you need precise visibility checking, use another method such as adding an :ref:`Area2D<class_Area2D>` node as a child of a :ref:`Camera2D<class_Camera2D>` node.
  15. **Note:** VisibilityEnabler2D will not affect nodes added after scene initialization.
  16. Properties
  17. ----------
  18. +-------------------------+------------------------------------------------------------------------------------------+-----------+
  19. | :ref:`bool<class_bool>` | :ref:`freeze_bodies<class_VisibilityEnabler2D_property_freeze_bodies>` | ``true`` |
  20. +-------------------------+------------------------------------------------------------------------------------------+-----------+
  21. | :ref:`bool<class_bool>` | :ref:`pause_animated_sprites<class_VisibilityEnabler2D_property_pause_animated_sprites>` | ``true`` |
  22. +-------------------------+------------------------------------------------------------------------------------------+-----------+
  23. | :ref:`bool<class_bool>` | :ref:`pause_animations<class_VisibilityEnabler2D_property_pause_animations>` | ``true`` |
  24. +-------------------------+------------------------------------------------------------------------------------------+-----------+
  25. | :ref:`bool<class_bool>` | :ref:`pause_particles<class_VisibilityEnabler2D_property_pause_particles>` | ``true`` |
  26. +-------------------------+------------------------------------------------------------------------------------------+-----------+
  27. | :ref:`bool<class_bool>` | :ref:`physics_process_parent<class_VisibilityEnabler2D_property_physics_process_parent>` | ``false`` |
  28. +-------------------------+------------------------------------------------------------------------------------------+-----------+
  29. | :ref:`bool<class_bool>` | :ref:`process_parent<class_VisibilityEnabler2D_property_process_parent>` | ``false`` |
  30. +-------------------------+------------------------------------------------------------------------------------------+-----------+
  31. Methods
  32. -------
  33. +-------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  34. | :ref:`bool<class_bool>` | :ref:`is_enabler_enabled<class_VisibilityEnabler2D_method_is_enabler_enabled>` **(** :ref:`Enabler<enum_VisibilityEnabler2D_Enabler>` enabler **)** |const| |
  35. +-------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  36. | void | :ref:`set_enabler<class_VisibilityEnabler2D_method_set_enabler>` **(** :ref:`Enabler<enum_VisibilityEnabler2D_Enabler>` enabler, :ref:`bool<class_bool>` enabled **)** |
  37. +-------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  38. Enumerations
  39. ------------
  40. .. _enum_VisibilityEnabler2D_Enabler:
  41. .. _class_VisibilityEnabler2D_constant_ENABLER_PAUSE_ANIMATIONS:
  42. .. _class_VisibilityEnabler2D_constant_ENABLER_FREEZE_BODIES:
  43. .. _class_VisibilityEnabler2D_constant_ENABLER_PAUSE_PARTICLES:
  44. .. _class_VisibilityEnabler2D_constant_ENABLER_PARENT_PROCESS:
  45. .. _class_VisibilityEnabler2D_constant_ENABLER_PARENT_PHYSICS_PROCESS:
  46. .. _class_VisibilityEnabler2D_constant_ENABLER_PAUSE_ANIMATED_SPRITES:
  47. .. _class_VisibilityEnabler2D_constant_ENABLER_MAX:
  48. enum **Enabler**:
  49. - **ENABLER_PAUSE_ANIMATIONS** = **0** --- This enabler will pause :ref:`AnimationPlayer<class_AnimationPlayer>` nodes.
  50. - **ENABLER_FREEZE_BODIES** = **1** --- This enabler will freeze :ref:`RigidBody2D<class_RigidBody2D>` nodes.
  51. - **ENABLER_PAUSE_PARTICLES** = **2** --- This enabler will stop :ref:`Particles2D<class_Particles2D>` nodes.
  52. - **ENABLER_PARENT_PROCESS** = **3** --- This enabler will stop the parent's _process function.
  53. - **ENABLER_PARENT_PHYSICS_PROCESS** = **4** --- This enabler will stop the parent's _physics_process function.
  54. - **ENABLER_PAUSE_ANIMATED_SPRITES** = **5** --- This enabler will stop :ref:`AnimatedSprite<class_AnimatedSprite>` nodes animations.
  55. - **ENABLER_MAX** = **6** --- Represents the size of the :ref:`Enabler<enum_VisibilityEnabler2D_Enabler>` enum.
  56. Property Descriptions
  57. ---------------------
  58. .. _class_VisibilityEnabler2D_property_freeze_bodies:
  59. - :ref:`bool<class_bool>` **freeze_bodies**
  60. +-----------+----------------------+
  61. | *Default* | ``true`` |
  62. +-----------+----------------------+
  63. | *Setter* | set_enabler(value) |
  64. +-----------+----------------------+
  65. | *Getter* | is_enabler_enabled() |
  66. +-----------+----------------------+
  67. If ``true``, :ref:`RigidBody2D<class_RigidBody2D>` nodes will be paused.
  68. ----
  69. .. _class_VisibilityEnabler2D_property_pause_animated_sprites:
  70. - :ref:`bool<class_bool>` **pause_animated_sprites**
  71. +-----------+----------------------+
  72. | *Default* | ``true`` |
  73. +-----------+----------------------+
  74. | *Setter* | set_enabler(value) |
  75. +-----------+----------------------+
  76. | *Getter* | is_enabler_enabled() |
  77. +-----------+----------------------+
  78. If ``true``, :ref:`AnimatedSprite<class_AnimatedSprite>` nodes will be paused.
  79. ----
  80. .. _class_VisibilityEnabler2D_property_pause_animations:
  81. - :ref:`bool<class_bool>` **pause_animations**
  82. +-----------+----------------------+
  83. | *Default* | ``true`` |
  84. +-----------+----------------------+
  85. | *Setter* | set_enabler(value) |
  86. +-----------+----------------------+
  87. | *Getter* | is_enabler_enabled() |
  88. +-----------+----------------------+
  89. If ``true``, :ref:`AnimationPlayer<class_AnimationPlayer>` nodes will be paused.
  90. ----
  91. .. _class_VisibilityEnabler2D_property_pause_particles:
  92. - :ref:`bool<class_bool>` **pause_particles**
  93. +-----------+----------------------+
  94. | *Default* | ``true`` |
  95. +-----------+----------------------+
  96. | *Setter* | set_enabler(value) |
  97. +-----------+----------------------+
  98. | *Getter* | is_enabler_enabled() |
  99. +-----------+----------------------+
  100. If ``true``, :ref:`Particles2D<class_Particles2D>` nodes will be paused.
  101. ----
  102. .. _class_VisibilityEnabler2D_property_physics_process_parent:
  103. - :ref:`bool<class_bool>` **physics_process_parent**
  104. +-----------+----------------------+
  105. | *Default* | ``false`` |
  106. +-----------+----------------------+
  107. | *Setter* | set_enabler(value) |
  108. +-----------+----------------------+
  109. | *Getter* | is_enabler_enabled() |
  110. +-----------+----------------------+
  111. If ``true``, the parent's :ref:`Node._physics_process<class_Node_method__physics_process>` will be stopped.
  112. ----
  113. .. _class_VisibilityEnabler2D_property_process_parent:
  114. - :ref:`bool<class_bool>` **process_parent**
  115. +-----------+----------------------+
  116. | *Default* | ``false`` |
  117. +-----------+----------------------+
  118. | *Setter* | set_enabler(value) |
  119. +-----------+----------------------+
  120. | *Getter* | is_enabler_enabled() |
  121. +-----------+----------------------+
  122. If ``true``, the parent's :ref:`Node._process<class_Node_method__process>` will be stopped.
  123. Method Descriptions
  124. -------------------
  125. .. _class_VisibilityEnabler2D_method_is_enabler_enabled:
  126. - :ref:`bool<class_bool>` **is_enabler_enabled** **(** :ref:`Enabler<enum_VisibilityEnabler2D_Enabler>` enabler **)** |const|
  127. Returns whether the enabler identified by given :ref:`Enabler<enum_VisibilityEnabler2D_Enabler>` constant is active.
  128. ----
  129. .. _class_VisibilityEnabler2D_method_set_enabler:
  130. - void **set_enabler** **(** :ref:`Enabler<enum_VisibilityEnabler2D_Enabler>` enabler, :ref:`bool<class_bool>` enabled **)**
  131. Sets active state of the enabler identified by given :ref:`Enabler<enum_VisibilityEnabler2D_Enabler>` constant.
  132. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  133. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  134. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`