160 lines
5.7 KiB
C#
160 lines
5.7 KiB
C#
//------------------------------------------------------------
|
|
// Game Framework
|
|
// Copyright © 2013-2021 Jiang Yin. All rights reserved.
|
|
// Homepage: https://gameframework.cn/
|
|
// Feedback: mailto:ellan@gameframework.cn
|
|
//------------------------------------------------------------
|
|
|
|
using DataTable;
|
|
using Definition;
|
|
using GameFramework.DataTable;
|
|
using GameFramework.Event;
|
|
using Scene;
|
|
using StarForce;
|
|
using UnityGameFramework.Runtime;
|
|
using ProcedureOwner = GameFramework.Fsm.IFsm<GameFramework.Procedure.IProcedureManager>;
|
|
using CustomUtility;
|
|
|
|
namespace Procedure
|
|
{
|
|
public class ProcedureChangeScene : ProcedureBase
|
|
{
|
|
private int _nextSceneId = 0;
|
|
private bool _isChangeSceneComplete = false;
|
|
private int _backgroundMusicId = 0;
|
|
|
|
public override bool UseNativeDialog => false;
|
|
|
|
protected override void OnEnter(ProcedureOwner procedureOwner)
|
|
{
|
|
base.OnEnter(procedureOwner);
|
|
|
|
_isChangeSceneComplete = false;
|
|
|
|
GameEntry.Event.Subscribe(LoadSceneSuccessEventArgs.EventId, OnLoadSceneSuccess);
|
|
GameEntry.Event.Subscribe(LoadSceneFailureEventArgs.EventId, OnLoadSceneFailure);
|
|
GameEntry.Event.Subscribe(LoadSceneUpdateEventArgs.EventId, OnLoadSceneUpdate);
|
|
GameEntry.Event.Subscribe(LoadSceneDependencyAssetEventArgs.EventId, OnLoadSceneDependencyAsset);
|
|
|
|
// 停止所有声音
|
|
GameEntry.Sound.StopAllLoadingSounds();
|
|
GameEntry.Sound.StopAllLoadedSounds();
|
|
|
|
// 隐藏所有实体
|
|
GameEntry.Entity.HideAllLoadingEntities();
|
|
GameEntry.Entity.HideAllLoadedEntities();
|
|
|
|
// 卸载所有场景
|
|
string[] loadedSceneAssetNames = GameEntry.Scene.GetLoadedSceneAssetNames();
|
|
for (int i = 0; i < loadedSceneAssetNames.Length; i++)
|
|
{
|
|
GameEntry.Scene.UnloadScene(loadedSceneAssetNames[i]);
|
|
}
|
|
|
|
// 还原游戏速度
|
|
GameEntry.Base.ResetNormalGameSpeed();
|
|
|
|
_nextSceneId = procedureOwner.GetData<VarInt32>("NextSceneId");
|
|
|
|
IDataTable<DRScene> dtScene = GameEntry.DataTable.GetDataTable<DRScene>();
|
|
DRScene drScene = dtScene.GetDataRow(_nextSceneId);
|
|
if (drScene == null)
|
|
{
|
|
Log.Warning("Can not load scene '{0}' from data table.", _nextSceneId.ToString());
|
|
return;
|
|
}
|
|
|
|
GameEntry.Scene.LoadScene(AssetUtility.GetSceneAsset(drScene.AssetName), Constant.AssetPriority.SceneAsset, this);
|
|
_backgroundMusicId = drScene.BackgroundMusicId;
|
|
}
|
|
|
|
protected override void OnLeave(ProcedureOwner procedureOwner, bool isShutdown)
|
|
{
|
|
GameEntry.Event.Unsubscribe(LoadSceneSuccessEventArgs.EventId, OnLoadSceneSuccess);
|
|
GameEntry.Event.Unsubscribe(LoadSceneFailureEventArgs.EventId, OnLoadSceneFailure);
|
|
GameEntry.Event.Unsubscribe(LoadSceneUpdateEventArgs.EventId, OnLoadSceneUpdate);
|
|
GameEntry.Event.Unsubscribe(LoadSceneDependencyAssetEventArgs.EventId, OnLoadSceneDependencyAsset);
|
|
|
|
base.OnLeave(procedureOwner, isShutdown);
|
|
}
|
|
|
|
protected override void OnUpdate(ProcedureOwner procedureOwner, float elapseSeconds, float realElapseSeconds)
|
|
{
|
|
base.OnUpdate(procedureOwner, elapseSeconds, realElapseSeconds);
|
|
|
|
if (!_isChangeSceneComplete)
|
|
{
|
|
return;
|
|
}
|
|
|
|
SceneId sceneId = (SceneId)_nextSceneId;
|
|
switch (sceneId)
|
|
{
|
|
case SceneId.Menu:
|
|
ChangeState<ProcedureStartMenu>(procedureOwner);
|
|
break;
|
|
case SceneId.StressTest:
|
|
ChangeState<ProcedureStressTest>(procedureOwner);
|
|
break;
|
|
case SceneId.Game:
|
|
ChangeState<ProcedureGame>(procedureOwner);
|
|
break;
|
|
default:
|
|
Log.Debug($"Scene {sceneId.ToString()} don't configure a procedure");
|
|
break;
|
|
}
|
|
}
|
|
|
|
private void OnLoadSceneSuccess(object sender, GameEventArgs e)
|
|
{
|
|
LoadSceneSuccessEventArgs ne = (LoadSceneSuccessEventArgs)e;
|
|
if (ne.UserData != this)
|
|
{
|
|
return;
|
|
}
|
|
|
|
Log.Info("Load scene '{0}' OK.", ne.SceneAssetName);
|
|
|
|
if (_backgroundMusicId > 0)
|
|
{
|
|
GameEntry.Sound.PlayMusic(_backgroundMusicId);
|
|
}
|
|
|
|
_isChangeSceneComplete = true;
|
|
}
|
|
|
|
private void OnLoadSceneFailure(object sender, GameEventArgs e)
|
|
{
|
|
LoadSceneFailureEventArgs ne = (LoadSceneFailureEventArgs)e;
|
|
if (ne.UserData != this)
|
|
{
|
|
return;
|
|
}
|
|
|
|
Log.Error("Load scene '{0}' failure, error message '{1}'.", ne.SceneAssetName, ne.ErrorMessage);
|
|
}
|
|
|
|
private void OnLoadSceneUpdate(object sender, GameEventArgs e)
|
|
{
|
|
LoadSceneUpdateEventArgs ne = (LoadSceneUpdateEventArgs)e;
|
|
if (ne.UserData != this)
|
|
{
|
|
return;
|
|
}
|
|
|
|
Log.Info("Load scene '{0}' update, progress '{1}'.", ne.SceneAssetName, ne.Progress.ToString("P2"));
|
|
}
|
|
|
|
private void OnLoadSceneDependencyAsset(object sender, GameEventArgs e)
|
|
{
|
|
LoadSceneDependencyAssetEventArgs ne = (LoadSceneDependencyAssetEventArgs)e;
|
|
if (ne.UserData != this)
|
|
{
|
|
return;
|
|
}
|
|
|
|
Log.Info("Load scene '{0}' dependency asset '{1}', count '{2}/{3}'.", ne.SceneAssetName, ne.DependencyAssetName, ne.LoadedCount.ToString(), ne.TotalCount.ToString());
|
|
}
|
|
}
|
|
}
|