scenemanager
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
scenemanager [2021/02/09 16:03] – uninomiconadmin | scenemanager [2025/01/15 04:35] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== SceneManager ====== | ====== SceneManager ====== | ||
- | '' | ||
- | The Unity scene flushing pipeline works differently in the initialization phase of the player. Scene loads thats are queued during initialization are blocked and fully loaded before | + | ==== When does scene loading happen? ==== |
+ | Scene loading and unloading happens at the start of the Update loop, within the '' | ||
- | It is untested if this is also the case for '' | + | Player Loop Phases: |
- | + | * __Initialization__ | |
- | Phases: | + | |
- | + | ||
- | * Initialization | + | |
* Game Loop | * Game Loop | ||
* Early Update | * Early Update | ||
- | * `UpdatePreloading` | + | * __UpdatePreloading__ |
+ | * FixedUpdate | ||
* Update | * Update | ||
- | (The scene load pipeline is fully flushed) I don't yet know how it handles unloads if they are in the pipeline then, so if we need this behaviour we should debug and see how it works. If scene unloads get flushed too, we'll need to add a bit of logic for it, in the same way LoadSceneAsync does. | ||
- | The scene loading pipeline only seems to load one scene, every other frame. | + | ===== The Scene Loading Queue ===== |
+ | |||
+ | The scene loading | ||
+ | |||
+ | During the '' | ||
+ | |||
+ | The scene loading pipeline only seems to execute a single operation, every other frame.< | ||
* Frame N+0: Scene1 | * Frame N+0: Scene1 | ||
- | * Frame N+1: ---- | + | * Frame N+1: --- |
* Frame N+2: Scene 2 | * Frame N+2: Scene 2 | ||
- | * Frame N+3: ---- | + | * Frame N+3: --- |
* Frame N+4: Scene 3 | * Frame N+4: Scene 3 | ||
+ | |||
+ | |||
+ | ==== Initialization ==== | ||
+ | |||
+ | The Engine fully " | ||
+ | |||
+ | **All** AsyncOperations that are queued during initialization are fully loaded during initialization. For example, if '' | ||
+ | |||
+ | Scene unloads are probably flushed if they are in the pipeline, too.< | ||
===== Build Pipeline ===== | ===== Build Pipeline ===== | ||
- | Scenes are built during standalone in the following way: ' | + | Scenes are built during standalone |
- The active scenes are closed. | - The active scenes are closed. | ||
- Each Scene in the BuildSettings is opened. At this point prefabs are still prefab instances. | - Each Scene in the BuildSettings is opened. At this point prefabs are still prefab instances. | ||
- | - EditorSceneManager.sceneOpened callback is called. | + | - '' |
- Prefabs in the scene are flattened (turned into normal game objects). | - Prefabs in the scene are flattened (turned into normal game objects). | ||
- | - [[engine: | + | - [[IProcessScene]] and PostProcessScene callbacks are called. |
- The final scene file is saved into the standalone build file. | - The final scene file is saved into the standalone build file. | ||
- | - Repeat for next scene | + | - Repeat for next scene. |
===== Sample Scene Load (Editor) ===== | ===== Sample Scene Load (Editor) ===== | ||
Line 43: | Line 55: | ||
* Prefabs.MergePrefabs (turning prefabs into gameobjects) happens before any other callback. (editor only) | * Prefabs.MergePrefabs (turning prefabs into gameobjects) happens before any other callback. (editor only) | ||
* Lightmapping is applied / loaded after Awake/ | * Lightmapping is applied / loaded after Awake/ | ||
- | * SceneManager.sceneLoaded happens after PostProcessScene; | + | * SceneManager.sceneLoaded happens after PostProcessScene. |
{{ : | {{ : | ||
+ | |||
+ | ===== Scattered Notes ===== | ||
+ | * During a scene load (ie. Awake) the loading scene has '' | ||
+ | * During a scene unload (ie. Destroy) the unloading scene has '' | ||
+ | * '' | ||
+ | * When using '' | ||
+ | |||
+ | |||
+ | ---- | ||
+ | |||
+ | ===== API Notes: ===== | ||
+ | === SceneManager.sceneLoaded === | ||
+ | * Called **after** the loaded Scene Awakes. | ||
+ |
scenemanager.1612886582.txt.gz · Last modified: 2025/01/15 04:35 (external edit)