Loading Unity’s Scenes via SceneManager.LoadScene.
data:image/s3,"s3://crabby-images/77339/773396e4898aed221af486208c7d39329398f7ec" alt=""
If you are working on a larger game or something with multiple levels, you will need to know how to load scenes in unity. First let’s talk about what makes up a scene. A scene is where you work with content in Unity. A simple game might only have one scene with the same type of environment, whereas a more complex game might use one scene per level, or even multiple scenes in a level. The more complex games might change the environment, characters, obstacles and UI in each scene. Now the big question is how do you load them?
One wat is to use Unities SceneManager to facilitate the loading of the different scenes in your project. We will go over the SceneManager.LoadScene first, then touch on the async command.
data:image/s3,"s3://crabby-images/a9a31/a9a31b148ae29a15854c8deb280fd572ae726d7c" alt=""
data:image/s3,"s3://crabby-images/fd631/fd631c53a497fad5cfef939472ecfe9722c48d6b" alt=""
As you can see from the above code you can load a scene with the use of a string name or the build index in your project. A build index is located in your project build settings, the index numbers are to the right of the scene name.
data:image/s3,"s3://crabby-images/643c3/643c30cb9342875cfb27a2775972a0693d7c85f2" alt=""
To load a scene you will need to have the Using statement followed by the class name SceneManager as the examlpe below:
data:image/s3,"s3://crabby-images/e98c2/e98c29eed43b4f6b759a3311e846c859b7e60e68" alt=""
You will then need to call LoadScene with the proper index or scene name.
Unity — Scripting API: SceneManagement.SceneManager.LoadScene (unity3d.com)
data:image/s3,"s3://crabby-images/2bbe7/2bbe719d324b100f75796b8b50643a6e19dcfe74" alt=""
data:image/s3,"s3://crabby-images/129ef/129ef548c47ae4c74d1ef280c3ef231354cab498" alt=""
data:image/s3,"s3://crabby-images/b39e0/b39e06abea02d507f99e5cacab4147b581573b0f" alt=""
The scene name is NOT case sensitive but proper spelling is a must. The scene needs to be active in the build settings.
There are scene modes you can specify, and they are Single and Additive. Single is the most widely used for beginners and are the default without a selection made. Single will close the current scene and load the new one. Additive will load the scene to the current loaded scene or scenes, does not close out the one running.
Unity — Scripting API: LoadSceneMode (unity3d.com)
LoadScene is really not the go to for loading scenes, due to the issue of pauses or performance. The most often used should be LoadSceneAsync. This command will load the scene asynchronously in the background. For more on this see the link below:
Unity — Scripting API: SceneManagement.SceneManager.LoadSceneAsync (unity3d.com)