Unity SceneManager

目录

API

官方文档

SceneManagerclass in UnityEngine.SceneManagement
描述运行时的场景管理。
静态变量
sceneCount当前加载的场景总数。
sceneCountInBuildSettingsBuild Settings 中的场景数量。
静态函数
CreateScene在运行时使用给定名称创建一个新的空场景。
GetActiveScene获取当前活动的场景。
GetSceneAt获取 SceneManager 的已加载场景列表中索引处的场景。
GetSceneByBuildIndex从构建索引中获取场景结构。
GetSceneByName搜索已加载的场景,查找包含给定名称的场景。
GetSceneByPath搜索所有已加载的场景,查找具有给定资源路径的场景。
LoadScene按照 Build Settings 中的名称或索引加载场景。
LoadSceneAsync在后台异步加载场景。
MergeScenes这会将源场景合并到 destinationScene 中。
MoveGameObjectToScene将游戏对象从当前场景移至新场景。
SetActiveScene将场景设置为活动状态。
UnloadSceneAsync销毁所有与给定场景关联的游戏对象,并将场景从 SceneManager 中移除。
Events
activeSceneChanged订阅此事件可在活动场景发生变化时收到通知。
sceneLoaded向此事件添加委托,以在加载场景时收到通知。
sceneUnloaded向此事件添加委托以在卸载场景时收到通知。

存疑

  1. LoadScene函数官方描述不会立即加载场景,而是在下一帧加载。GetSceneByBuildIndex函数官方描述如果将场景添加到 Build Settings 中的给定构建索引处,且场景已加载,则此方法将返回有效场景。如果场景未加载,SceneManager 将无法返回有效场景。但是Update中执行以下语句会打印上面刚加载的场景的名字
	if (Input.GetKeyDown(KeyCode.Space) && !Touch) {
    	Touch = !Touch;		//确保执行一次
    	Debug.Log(SceneManager.GetSceneByBuildIndex(1).name);	//打印:null
    	SceneManager.LoadScene(1, LoadSceneMode.Single);
    	Debug.Log(SceneManager.GetSceneByBuildIndex(1).name);	//打印:Scene2
    	SceneManager.SetActiveScene(SceneManager.GetSceneByBuildIndex(1));		//报空
    }

加载了但没完全加载


版权声明:本文为ZuoXuanZuo原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。