sceneName | 要加载的场景的名称或路径。 |
sceneBuildIndex | Build Settings 中要加载场景的索引。 |
mode | Allows you to specify whether or not to load the Scene additively. See LoadSceneMode for more information about the options. |
按照 Build Settings 中的名称或索引加载场景。
注意:在大多数情况下,为了避免在加载时出现暂停或性能中断现象,
您应该使用此命令的异步版,即:
LoadSceneAsync。
When using 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.
Since loading is set to complete in the next rendered frame, calling SceneManager.LoadScene forces all previous AsynOperations to complete, even if AsyncOperation.allowSceneActivation is set to false. This can be avoided by using LoadSceneAsync instead.
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, except when you load the Scene from an AssetBundle.
For opening Scenes in the Editor see EditorSceneManager.OpenScene.
SceneA
can additively load SceneB
multiple times. The regular name is used for each loaded scene. If SceneA
loads SceneB
ten times each SceneB
with have the same name. Finding a particular added scene is not possible.
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); } }
// 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); } } }
The following two script examples show how LoadScene can load Scenes from Build Settings. LoadSceneA
uses the name of the Scene to load. LoadSceneB
uses the number of the Scene to load. The scripts work together.LoadSceneA
文件。
// SceneA. // SceneA is given the sceneName which will // load SceneB from the Build Settings
using UnityEngine; using UnityEngine.SceneManagement;
public class LoadScenesA : MonoBehaviour { void Start() { Debug.Log("LoadSceneA"); }
public void LoadA(string scenename) { Debug.Log("sceneName to load: " + scenename); SceneManager.LoadScene(scenename); } }
LoadSceneB
文件。
// SceneB. // SceneB is given the sceneBuildIndex of 0 which will // load SceneA from the Build Settings
using UnityEngine; using UnityEngine.SceneManagement;
public class LoadScenesB : MonoBehaviour { void Start() { Debug.Log("LoadSceneB"); }
public void LoadB(int sceneANumber) { Debug.Log("sceneBuildIndex to load: " + sceneANumber); SceneManager.LoadScene(sceneANumber); } }
sceneName | 要加载的场景的名称或路径。 |
sceneBuildIndex | Build Settings 中要加载场景的索引。 |
parameters | Various parameters used to load the Scene. |
Scene A handle to the Scene being loaded.
按照 Build Settings 中的名称或索引加载场景。
An example using two scenes called Scene1
and Scene2
. ExampleScript1.cs is for scene1
and ExampleScript2.cs is for scene2
.
using UnityEngine; using UnityEngine.SceneManagement;
// This is scene1. It loads 3 copies of scene2. // Each copy has the same name.
public class ExampleScript1 : MonoBehaviour { private Scene scene;
private void Start() { var parameters = new LoadSceneParameters(LoadSceneMode.Additive);
scene = SceneManager.LoadScene("scene2", parameters); Debug.Log("Load 1 of scene2: " + scene.name); scene = SceneManager.LoadScene("scene2", parameters); Debug.Log("Load 2 of scene2: " + scene.name); scene = SceneManager.LoadScene("scene2", parameters); Debug.Log("Load 3 of scene2: " + scene.name); } }
Scene2:
using UnityEngine;
// create a randomly placed cube
public class ExampleScript2 : MonoBehaviour { private void Start() { GameObject cube = GameObject.CreatePrimitive(PrimitiveType.Cube); cube.transform.position = new Vector3(Random.Range(-5.0f, 5.0f), 0.0f, Random.Range(-5.0f, 5.0f)); } }