1234567891011121314151617181920212223242526272829303132 |
- extends Node
- # Changing scenes is most easily done using the functions change_scene_to_file
- # and change_scene_to_packed of the SceneTree. This script demonstrates how to
- # change scenes without those helpers.
- func goto_scene(path: String):
- # This function will usually be called from a signal callback,
- # or some other function from the running scene.
- # Deleting the current scene at this point might be
- # a bad idea, because it may be inside of a callback or function of it.
- # The worst case will be a crash or unexpected behavior.
- # The way around this is deferring the load to a later time, when
- # it is ensured that no code from the current scene is running:
- _deferred_goto_scene.call_deferred(path)
- func _deferred_goto_scene(path: String):
- # Immediately free the current scene. There is no risk here because the
- # call to this method is already deferred.
- get_tree().current_scene.free()
- var packed_scene := ResourceLoader.load(path) as PackedScene
- var instanced_scene := packed_scene.instantiate()
- # Add it to the scene tree, as direct child of root
- get_tree().root.add_child(instanced_scene)
- # Set it as the current scene, only after it has been added to the tree
- get_tree().current_scene = instanced_scene
|