class_scenetree.rst 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. .. Generated automatically by doc/tools/makerst.py in Godot's source tree.
  2. .. DO NOT EDIT THIS FILE, but the doc/base/classes.xml source instead.
  3. .. _class_SceneTree:
  4. SceneTree
  5. =========
  6. **Inherits:** :ref:`MainLoop<class_mainloop>` **<** :ref:`Object<class_object>`
  7. **Category:** Core
  8. Brief Description
  9. -----------------
  10. Member Functions
  11. ----------------
  12. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  13. | :ref:`Variant<class_variant>` | :ref:`call_group<class_SceneTree_call_group>` **(** :ref:`String<class_string>` group, :ref:`String<class_string>` method **)** vararg |
  14. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  15. | :ref:`Variant<class_variant>` | :ref:`call_group_flags<class_SceneTree_call_group_flags>` **(** :ref:`int<class_int>` flags, :ref:`String<class_string>` group, :ref:`String<class_string>` method **)** vararg |
  16. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  17. | :ref:`int<class_int>` | :ref:`change_scene<class_SceneTree_change_scene>` **(** :ref:`String<class_string>` path **)** |
  18. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  19. | :ref:`int<class_int>` | :ref:`change_scene_to<class_SceneTree_change_scene_to>` **(** :ref:`PackedScene<class_packedscene>` packed_scene **)** |
  20. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  21. | :ref:`SceneTreeTimer<class_scenetreetimer>` | :ref:`create_timer<class_SceneTree_create_timer>` **(** :ref:`float<class_float>` time_sec, :ref:`bool<class_bool>` pause_mode_process=true **)** |
  22. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  23. | :ref:`Node<class_node>` | :ref:`get_current_scene<class_SceneTree_get_current_scene>` **(** **)** const |
  24. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  25. | :ref:`Node<class_node>` | :ref:`get_edited_scene_root<class_SceneTree_get_edited_scene_root>` **(** **)** const |
  26. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  27. | :ref:`int<class_int>` | :ref:`get_frame<class_SceneTree_get_frame>` **(** **)** const |
  28. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  29. | :ref:`PoolIntArray<class_poolintarray>` | :ref:`get_network_connected_peers<class_SceneTree_get_network_connected_peers>` **(** **)** const |
  30. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  31. | :ref:`int<class_int>` | :ref:`get_network_unique_id<class_SceneTree_get_network_unique_id>` **(** **)** const |
  32. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  33. | :ref:`int<class_int>` | :ref:`get_node_count<class_SceneTree_get_node_count>` **(** **)** const |
  34. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  35. | :ref:`Array<class_array>` | :ref:`get_nodes_in_group<class_SceneTree_get_nodes_in_group>` **(** :ref:`String<class_string>` group **)** |
  36. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  37. | :ref:`Viewport<class_viewport>` | :ref:`get_root<class_SceneTree_get_root>` **(** **)** const |
  38. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  39. | :ref:`int<class_int>` | :ref:`get_rpc_sender_id<class_SceneTree_get_rpc_sender_id>` **(** **)** const |
  40. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  41. | :ref:`bool<class_bool>` | :ref:`has_group<class_SceneTree_has_group>` **(** :ref:`String<class_string>` name **)** const |
  42. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  43. | :ref:`bool<class_bool>` | :ref:`has_network_peer<class_SceneTree_has_network_peer>` **(** **)** const |
  44. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  45. | :ref:`bool<class_bool>` | :ref:`is_debugging_collisions_hint<class_SceneTree_is_debugging_collisions_hint>` **(** **)** const |
  46. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  47. | :ref:`bool<class_bool>` | :ref:`is_debugging_navigation_hint<class_SceneTree_is_debugging_navigation_hint>` **(** **)** const |
  48. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  49. | :ref:`bool<class_bool>` | :ref:`is_input_handled<class_SceneTree_is_input_handled>` **(** **)** |
  50. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  51. | :ref:`bool<class_bool>` | :ref:`is_network_server<class_SceneTree_is_network_server>` **(** **)** const |
  52. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  53. | :ref:`bool<class_bool>` | :ref:`is_paused<class_SceneTree_is_paused>` **(** **)** const |
  54. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  55. | :ref:`bool<class_bool>` | :ref:`is_refusing_new_network_connections<class_SceneTree_is_refusing_new_network_connections>` **(** **)** const |
  56. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  57. | void | :ref:`notify_group<class_SceneTree_notify_group>` **(** :ref:`String<class_string>` group, :ref:`int<class_int>` notification **)** |
  58. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  59. | void | :ref:`notify_group_flags<class_SceneTree_notify_group_flags>` **(** :ref:`int<class_int>` call_flags, :ref:`String<class_string>` group, :ref:`int<class_int>` notification **)** |
  60. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  61. | void | :ref:`queue_delete<class_SceneTree_queue_delete>` **(** :ref:`Object<class_object>` obj **)** |
  62. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  63. | void | :ref:`quit<class_SceneTree_quit>` **(** **)** |
  64. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  65. | :ref:`int<class_int>` | :ref:`reload_current_scene<class_SceneTree_reload_current_scene>` **(** **)** |
  66. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  67. | void | :ref:`set_auto_accept_quit<class_SceneTree_set_auto_accept_quit>` **(** :ref:`bool<class_bool>` enabled **)** |
  68. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  69. | void | :ref:`set_current_scene<class_SceneTree_set_current_scene>` **(** :ref:`Node<class_node>` child_node **)** |
  70. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  71. | void | :ref:`set_debug_collisions_hint<class_SceneTree_set_debug_collisions_hint>` **(** :ref:`bool<class_bool>` enable **)** |
  72. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  73. | void | :ref:`set_debug_navigation_hint<class_SceneTree_set_debug_navigation_hint>` **(** :ref:`bool<class_bool>` enable **)** |
  74. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  75. | void | :ref:`set_edited_scene_root<class_SceneTree_set_edited_scene_root>` **(** :ref:`Node<class_node>` scene **)** |
  76. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  77. | void | :ref:`set_group<class_SceneTree_set_group>` **(** :ref:`String<class_string>` group, :ref:`String<class_string>` property, :ref:`Variant<class_variant>` value **)** |
  78. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  79. | void | :ref:`set_group_flags<class_SceneTree_set_group_flags>` **(** :ref:`int<class_int>` call_flags, :ref:`String<class_string>` group, :ref:`String<class_string>` property, :ref:`Variant<class_variant>` value **)** |
  80. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  81. | void | :ref:`set_input_as_handled<class_SceneTree_set_input_as_handled>` **(** **)** |
  82. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  83. | void | :ref:`set_network_peer<class_SceneTree_set_network_peer>` **(** :ref:`NetworkedMultiplayerPeer<class_networkedmultiplayerpeer>` peer **)** |
  84. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  85. | void | :ref:`set_pause<class_SceneTree_set_pause>` **(** :ref:`bool<class_bool>` enable **)** |
  86. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  87. | void | :ref:`set_refuse_new_network_connections<class_SceneTree_set_refuse_new_network_connections>` **(** :ref:`bool<class_bool>` refuse **)** |
  88. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  89. | void | :ref:`set_screen_stretch<class_SceneTree_set_screen_stretch>` **(** :ref:`int<class_int>` mode, :ref:`int<class_int>` aspect, :ref:`Vector2<class_vector2>` minsize, :ref:`int<class_int>` shrink=1 **)** |
  90. +----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  91. Signals
  92. -------
  93. - **connected_to_server** **(** **)**
  94. - **connection_failed** **(** **)**
  95. - **files_dropped** **(** :ref:`PoolStringArray<class_poolstringarray>` files, :ref:`int<class_int>` screen **)**
  96. - **fixed_frame** **(** **)**
  97. - **idle_frame** **(** **)**
  98. - **network_peer_connected** **(** :ref:`int<class_int>` id **)**
  99. - **network_peer_disconnected** **(** :ref:`int<class_int>` id **)**
  100. - **node_configuration_warning_changed** **(** :ref:`Object<class_object>` node **)**
  101. - **node_removed** **(** :ref:`Object<class_object>` node **)**
  102. - **screen_resized** **(** **)**
  103. - **server_disconnected** **(** **)**
  104. - **tree_changed** **(** **)**
  105. Numeric Constants
  106. -----------------
  107. - **GROUP_CALL_DEFAULT** = **0**
  108. - **GROUP_CALL_REVERSE** = **1**
  109. - **GROUP_CALL_REALTIME** = **2**
  110. - **GROUP_CALL_UNIQUE** = **4**
  111. - **STRETCH_MODE_DISABLED** = **0**
  112. - **STRETCH_MODE_2D** = **1**
  113. - **STRETCH_MODE_VIEWPORT** = **2**
  114. - **STRETCH_ASPECT_IGNORE** = **0**
  115. - **STRETCH_ASPECT_KEEP** = **1**
  116. - **STRETCH_ASPECT_KEEP_WIDTH** = **2**
  117. - **STRETCH_ASPECT_KEEP_HEIGHT** = **3**
  118. Member Function Description
  119. ---------------------------
  120. .. _class_SceneTree_call_group:
  121. - :ref:`Variant<class_variant>` **call_group** **(** :ref:`String<class_string>` group, :ref:`String<class_string>` method **)** vararg
  122. .. _class_SceneTree_call_group_flags:
  123. - :ref:`Variant<class_variant>` **call_group_flags** **(** :ref:`int<class_int>` flags, :ref:`String<class_string>` group, :ref:`String<class_string>` method **)** vararg
  124. .. _class_SceneTree_change_scene:
  125. - :ref:`int<class_int>` **change_scene** **(** :ref:`String<class_string>` path **)**
  126. .. _class_SceneTree_change_scene_to:
  127. - :ref:`int<class_int>` **change_scene_to** **(** :ref:`PackedScene<class_packedscene>` packed_scene **)**
  128. .. _class_SceneTree_create_timer:
  129. - :ref:`SceneTreeTimer<class_scenetreetimer>` **create_timer** **(** :ref:`float<class_float>` time_sec, :ref:`bool<class_bool>` pause_mode_process=true **)**
  130. .. _class_SceneTree_get_current_scene:
  131. - :ref:`Node<class_node>` **get_current_scene** **(** **)** const
  132. .. _class_SceneTree_get_edited_scene_root:
  133. - :ref:`Node<class_node>` **get_edited_scene_root** **(** **)** const
  134. .. _class_SceneTree_get_frame:
  135. - :ref:`int<class_int>` **get_frame** **(** **)** const
  136. .. _class_SceneTree_get_network_connected_peers:
  137. - :ref:`PoolIntArray<class_poolintarray>` **get_network_connected_peers** **(** **)** const
  138. .. _class_SceneTree_get_network_unique_id:
  139. - :ref:`int<class_int>` **get_network_unique_id** **(** **)** const
  140. .. _class_SceneTree_get_node_count:
  141. - :ref:`int<class_int>` **get_node_count** **(** **)** const
  142. .. _class_SceneTree_get_nodes_in_group:
  143. - :ref:`Array<class_array>` **get_nodes_in_group** **(** :ref:`String<class_string>` group **)**
  144. .. _class_SceneTree_get_root:
  145. - :ref:`Viewport<class_viewport>` **get_root** **(** **)** const
  146. .. _class_SceneTree_get_rpc_sender_id:
  147. - :ref:`int<class_int>` **get_rpc_sender_id** **(** **)** const
  148. .. _class_SceneTree_has_group:
  149. - :ref:`bool<class_bool>` **has_group** **(** :ref:`String<class_string>` name **)** const
  150. .. _class_SceneTree_has_network_peer:
  151. - :ref:`bool<class_bool>` **has_network_peer** **(** **)** const
  152. Returns true if there is a :ref:`NetworkedMultiplayerPeer<class_networkedmultiplayerpeer>` set (with :ref:`SceneTree.set_network_peer<class_SceneTree_set_network_peer>`).
  153. .. _class_SceneTree_is_debugging_collisions_hint:
  154. - :ref:`bool<class_bool>` **is_debugging_collisions_hint** **(** **)** const
  155. .. _class_SceneTree_is_debugging_navigation_hint:
  156. - :ref:`bool<class_bool>` **is_debugging_navigation_hint** **(** **)** const
  157. .. _class_SceneTree_is_input_handled:
  158. - :ref:`bool<class_bool>` **is_input_handled** **(** **)**
  159. .. _class_SceneTree_is_network_server:
  160. - :ref:`bool<class_bool>` **is_network_server** **(** **)** const
  161. Returns true if this SceneTree's :ref:`NetworkedMultiplayerPeer<class_networkedmultiplayerpeer>` is in server mode (listening for connections).
  162. .. _class_SceneTree_is_paused:
  163. - :ref:`bool<class_bool>` **is_paused** **(** **)** const
  164. .. _class_SceneTree_is_refusing_new_network_connections:
  165. - :ref:`bool<class_bool>` **is_refusing_new_network_connections** **(** **)** const
  166. .. _class_SceneTree_notify_group:
  167. - void **notify_group** **(** :ref:`String<class_string>` group, :ref:`int<class_int>` notification **)**
  168. .. _class_SceneTree_notify_group_flags:
  169. - void **notify_group_flags** **(** :ref:`int<class_int>` call_flags, :ref:`String<class_string>` group, :ref:`int<class_int>` notification **)**
  170. .. _class_SceneTree_queue_delete:
  171. - void **queue_delete** **(** :ref:`Object<class_object>` obj **)**
  172. .. _class_SceneTree_quit:
  173. - void **quit** **(** **)**
  174. .. _class_SceneTree_reload_current_scene:
  175. - :ref:`int<class_int>` **reload_current_scene** **(** **)**
  176. .. _class_SceneTree_set_auto_accept_quit:
  177. - void **set_auto_accept_quit** **(** :ref:`bool<class_bool>` enabled **)**
  178. .. _class_SceneTree_set_current_scene:
  179. - void **set_current_scene** **(** :ref:`Node<class_node>` child_node **)**
  180. .. _class_SceneTree_set_debug_collisions_hint:
  181. - void **set_debug_collisions_hint** **(** :ref:`bool<class_bool>` enable **)**
  182. .. _class_SceneTree_set_debug_navigation_hint:
  183. - void **set_debug_navigation_hint** **(** :ref:`bool<class_bool>` enable **)**
  184. .. _class_SceneTree_set_edited_scene_root:
  185. - void **set_edited_scene_root** **(** :ref:`Node<class_node>` scene **)**
  186. .. _class_SceneTree_set_group:
  187. - void **set_group** **(** :ref:`String<class_string>` group, :ref:`String<class_string>` property, :ref:`Variant<class_variant>` value **)**
  188. .. _class_SceneTree_set_group_flags:
  189. - void **set_group_flags** **(** :ref:`int<class_int>` call_flags, :ref:`String<class_string>` group, :ref:`String<class_string>` property, :ref:`Variant<class_variant>` value **)**
  190. .. _class_SceneTree_set_input_as_handled:
  191. - void **set_input_as_handled** **(** **)**
  192. .. _class_SceneTree_set_network_peer:
  193. - void **set_network_peer** **(** :ref:`NetworkedMultiplayerPeer<class_networkedmultiplayerpeer>` peer **)**
  194. Set the peer object to handle the RPC system (effectively enabling networking). Depending on the peer itself, the SceneTree will become a network server (check with :ref:`is_network_server()<class_SceneTree_is_network_server()>`) and will set root node's network mode to master (see NETWORK_MODE\_\* constants in :ref:`Node<class_node>`), or it will become a regular peer with root node set to slave. All child nodes are set to inherit the network mode by default. Handling of networking-related events (connection, disconnection, new clients) is done by connecting to SceneTree's signals.
  195. .. _class_SceneTree_set_pause:
  196. - void **set_pause** **(** :ref:`bool<class_bool>` enable **)**
  197. .. _class_SceneTree_set_refuse_new_network_connections:
  198. - void **set_refuse_new_network_connections** **(** :ref:`bool<class_bool>` refuse **)**
  199. .. _class_SceneTree_set_screen_stretch:
  200. - void **set_screen_stretch** **(** :ref:`int<class_int>` mode, :ref:`int<class_int>` aspect, :ref:`Vector2<class_vector2>` minsize, :ref:`int<class_int>` shrink=1 **)**