-
Notifications
You must be signed in to change notification settings - Fork 18
API (Godot 4)
SceneManager.change_scene(scene: (String || PackedScene)?, options: Dictionary = defaultOptions) -> void
This method lets you easily change scenes with transitions. They're highly customizable and we will consider adding progressive loading if it's requested enough.
The scene
paremeter accepts an absolute file path for your new scene (i.e: 'res://demo/test.tscn') or a PackedScene
. If null
is passed as the scene, it will reload the current scene,
but for ease-of-use we recommend using the reload_scene(options)
function explained further down.
You can pass the following options to this function in a dictionary:
-
speed : float = 2
: Speed of the moving transition. (Also affects custom animations) -
color : Color = Color('#000000')
: Color to use for the transition screen. It's black by default. -
wait_time : float = 0.5
: Time spent in the transition screen while switching scenes. Leaving it at 0 with fade will result in the screen not turning black, so it waits a little bit by default. -
skip_scene_change : Bool = false
: If set to true, skips the actual scene change/reload, leaving only the transition. -
skip_fade_out : Bool = false
: If set to true, skips the initial "fade" part of the transition -
skip_fade_in : Bool = false
: If set to true, skips the final "fade" part of the transition -
pattern : (String || Texture) = 'fade'
: Pattern to use for the transition. Using a simple name will load the premade patterns we have designed (you can see them inaddons/scene_manager/shader_patterns
). Otherwise, you may pass an absolute path to your own pattern"res://my_pattern.png"
or aTexture
object. You can also specify'fade'
for a simple fade transition. -
pattern_enter : (String || Texture) = pattern
: Same aspattern
, but overrides the pattern only for the fade-to-black transition. -
pattern_leave : (String || Texture) = pattern
: Same aspattern
, but overrides the pattern only for the fade-from-black transition. -
invert_on_leave : Bool = true
: Wether the transition should invert when fading out of black. This usually looks better on, the effect is that the first pixels that turned black are the first ones that fade into the new screen. This generally works for "sweep" transitions like"horizontal"
, but others such as"curtains"
might look better with this flag turned off -
ease : float = 1.0
: Amount of ease the animation should have during the transition. -
ease_enter : float = ease
: Amount of ease the animation should have during the fade-to-black transition. -
ease_leave : float = ease
: Amount of ease the animation should have during the fade-from-black transition. -
animation_name : String
: Name of an animation set inset_animation_player()
which will be played for both in and out transitions -
animation_name_enter : String
: Name of an animation set inset_animation_player()
which will be played for the fade-to-black transition -
animation_name_leave : String
: Name of an animation set inset_animation_player()
which will be played for the fade-from-black transition -
on_tree_enter : Callable(new_scene: Node)
: Custom callback called when the new scene enters the tree hierarchy -
on_ready : Callable(new_scene: Node)
: Custom callback called when the new scene is ready -
on_fade_out : Callable()
: Custom callback called when the fade_out is finished (screen completely black) -
on_fade_in : Callable()
: Custom callback called when the fade_in is finished (transition completely finished)
The following patterns are available out-of-the-box:
"fade"
"circle"
"curtains"
"diagonal"
"horizontal"
"radial"
"scribbles"
"squares"
"vertical"
SceneManager.reload_scene(options: Dictionary = defaultOptions) -> void
This method functions exactly like change_scene(current_scene_path, options)
, but you do not have to provide the path and it should be slightly faster since it reloads the scene rather than removing it and instantiating again.
Of note, is that this method will not trigger the scene_unloaded
signal, since nothing is being unloaded. It will however trigger the scene_loaded
signal. If a legitimate use-case for a scene_reloaded
signal arises please open an issue and we will change it.
SceneManager.fade_in_place(options: Dictionary = defaultOptions)
This method functions exactly like reload_scene({ "skip_scene_change": true })
, it will simply trigger the transition used in options, without modifying anything. You can use the fade_complete
signal or the on_fade_out
callback if you want to change something while the screen is completely black.
SceneManager.fade_out(options: Dictionary = defaultOptions)
This method fades out the screen, useful when you want to fade to black and do some calculations/processing manually. Works well in conjunction with the "skip_fade_out"
option.
await SceneManager.fade_out()
// Do something
SceneManager.change_scene(new_scene, { "skip_fade_out": true })
It can take the following options, with the same defaults as change_scene
:
speed
color
pattern
ease
SceneManager.fade_in(options: Dictionary = defaultOptions)
This method fades in the screen, useful to do if you want an initial transition when opening the game.
It can take the following options, with the same defaults as change_scene
:
speed
color
pattern
invert_on_leave
ease
SceneManager.set_animation_player(animation_player: String || PackedScene)
Set a custom AnimationPlayer
make your own transitions easily. We recommend doing this only once as early as possible in your game, for example in the _ready()
method of an autoload or your first scene.
This method receives a path to (or a PackedScene
of) the location of your AnimationPlayer
scene.
SceneManager.set_animation_player('res://demo/animation_player.tscn')
Your AnimationPlayer
scene must follow these rules:
- The root node must be a Godot
AnimationPlayer
- The animation player must have a
RESET
animation that keeps all your graphics outside of the viewport. This is because the animation player will always be rendered on top of your screen, so any leftovers will always be rendered (you should notice right away if this is the case)
Add your animations to this AnimationPlayer
and then use their names in the options of any SceneManager transition function as animation_name
, animation_name_enter
or animation_name_leave
Please check the demo files in this repository for a complete example.
SceneManager.get_entity(entity_name: String)
Get a reference to a named entity (node) in your scene. To define entity names go to the desired node in the editor inspector and you'll see two new properties: Singleton entity
and Entity name
. Check the Singleton entity
checkbox to have this node saved to the SceneManager entity dictionary and write a friendly Entity name
to be used in this function. Afterwards, you'll be able to access it within the scene.
NOTE: If accessing the node in a _ready()
method within your scene, get_entity
will throw an error. This is because saving the entities to the SceneManager requires the scene to be completely loaded, which hasn't happened yet in the _ready()
method. To circumvent this problem, you will have to wait until the scene is completely loaded. To do this, you can take advantage of the scene_loaded
signal provided by SceneManager
, like so:
await SceneManager.scene_loaded
Player = SceneManager.get_entity("Player")
-
SceneManager.is_transitioning: bool
: This variable changes depending of whether a transition is active or not. You can use this to make sure a transition is finished before starting a new one if thetransition_finished
signal does not suit your use-case.
Signals are useful to connect methods to them, or wait for them to happen before executing the next line.
# wait for the "scene_loaded" signal to be emitted
await SceneManager.scene_loaded
# connect the method "_on_scene_loaded" from your object so it runs when SceneManager emits the signal
SceneManager.scene_loaded.connect(_on_scene_loaded)
-
scene_unloaded
: Emitted when the first scene is unloaded -
scene_loaded
: Emitted when the new scene is loaaded -
fade_complete
: Emitted when the fade-to-black animation finishes -
transition_finished
: Emitted when the transition finishes