Legacy Documentation: Version 5.5
LanguageEnglish
  • C#
  • JS

Script language

Select your preferred scripting language. All code snippets will be displayed in this language.

SceneManager.LoadScene

Suggest a change

Success!

Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.

Close

Submission failed

For some reason your suggested change could not be submitted. Please <a>try again</a> in a few minutes. And thank you for taking the time to help us improve the quality of Unity Documentation.

Close

Cancel

public static function LoadScene(sceneBuildIndex: int, mode: SceneManagement.LoadSceneMode = LoadSceneMode.Single): void;
public static void LoadScene(int sceneBuildIndex, SceneManagement.LoadSceneMode mode = LoadSceneMode.Single);
public static function LoadScene(sceneName: string, mode: SceneManagement.LoadSceneMode = LoadSceneMode.Single): void;
public static void LoadScene(string sceneName, SceneManagement.LoadSceneMode mode = LoadSceneMode.Single);

Parameters

sceneName Name or path of the scene to load.
sceneBuildIndex Index of the scene in the Build Settings to load.
mode Allows you to specify whether or not to load the scene additively. See LoadSceneMode for more information about the options.

Description

Loads the scene by its name or index in Build Settings.

Note: In most cases, to avoid pauses or performance hiccups while loading, you should use the asynchronous version of this command which is: LoadSceneAsync.

When using this SceneManager.LoadScene, the loading does not happen immediately, it completes in the next frame. This semi-asynchronous behavior can cause frame stuttering and can be confusing because load does not complete immediately.

The given sceneName can either be the scene name only, without the .unity extension, or the path as shown in the BuildSettings window still without the .unity extension. If only the scene name is given this will load the first scene in the list that matches. If you have multiple scenes with same name but different paths, you should use the full path. Note that sceneName is case insensitive.

For opening scenes in the Editor see EditorSceneManager.OpenScene.

#pragma strict
function Start() {
	// Only specifying the sceneName or sceneBuildIndex will load the scene with the Single mode
	SceneManager.LoadScene("OtherSceneName", LoadSceneMode.Additive);
}
using UnityEngine;
using UnityEngine.SceneManagement;

public class ExampleClass : MonoBehaviour { void Start () { // Only specifying the sceneName or sceneBuildIndex will load the scene with the Single mode SceneManager.LoadScene ("OtherSceneName", LoadSceneMode.Additive); } }
#pragma strict
// Load an assetbundle which contains scenes.
// When the user clicks a button the first scene in the assetbundle is
// loaded and replaces the current scene.
public class LoadScene extends MonoBehaviour {
	private var myLoadedAssetBundle: AssetBundle;
	private var scenePaths: String[];
	// Use this for initialization
	function Start() {
		myLoadedAssetBundle = AssetBundle.LoadFromFile("Assets/AssetBundles/scenes");
		scenePaths = myLoadedAssetBundle.GetAllScenePaths();
	}
	function OnGUI() {
		if (GUI.Button(new Rect(10, 10, 100, 30), "Change scene")) {
			Debug.Log("scene2 loading: " + scenePaths[0]);
			SceneManager.LoadScene(scenePaths[0], LoadSceneMode.Single);
		}
	}
}
// Load an assetbundle which contains scenes.
// When the user clicks a button the first scene in the assetbundle is
// loaded and replaces the current scene.

using UnityEngine; using UnityEngine.SceneManagement;

public class LoadScene : MonoBehaviour {

private AssetBundle myLoadedAssetBundle; private string[] scenePaths;

// Use this for initialization void Start() { myLoadedAssetBundle = AssetBundle.LoadFromFile("Assets/AssetBundles/scenes"); scenePaths = myLoadedAssetBundle.GetAllScenePaths(); }

void OnGUI() { if (GUI.Button(new Rect(10, 10, 100, 30), "Change scene")) { Debug.Log("scene2 loading: " + scenePaths[0]); SceneManager.LoadScene(scenePaths[0], LoadSceneMode.Single); } }

}