using System; using Cysharp.Threading.Tasks; using TEngine; using YooAsset; using ProcedureOwner = TEngine.IFsm; namespace GameMain { /// /// 流程 => 初始化Package。 /// public class ProcedureInitPackage : ProcedureBase { public override bool UseNativeDialog { get; } protected override void OnEnter(ProcedureOwner procedureOwner) { base.OnEnter(procedureOwner); //Fire Forget立刻触发UniTask初始化Package InitPackage(procedureOwner).Forget(); } private async UniTaskVoid InitPackage(ProcedureOwner procedureOwner) { if (GameModule.Resource.PlayMode == EPlayMode.HostPlayMode) { UpdateData updateData = await RequestUpdateData(); if (updateData!=null) { if (!string.IsNullOrEmpty(updateData.HostServerURL)) { SettingsUtils.FrameworkGlobalSettings.HostServerURL = updateData.HostServerURL; } if (!string.IsNullOrEmpty(updateData.FallbackHostServerURL)) { SettingsUtils.FrameworkGlobalSettings.FallbackHostServerURL = updateData.FallbackHostServerURL; } } } var initializationOperation = GameModule.Resource.InitPackage(); await UniTask.Delay(TimeSpan.FromSeconds(1f)); await initializationOperation.ToUniTask(); if (initializationOperation.Status == EOperationStatus.Succeed) { EPlayMode playMode = GameModule.Resource.PlayMode; // 编辑器模式。 if (playMode == EPlayMode.EditorSimulateMode) { Log.Info("Editor resource mode detected."); ChangeState(procedureOwner); } // 单机模式。 else if (playMode == EPlayMode.OfflinePlayMode) { Log.Info("Package resource mode detected."); ChangeState(procedureOwner); } // 可更新模式。 else if (playMode == EPlayMode.HostPlayMode) { // 打开启动UI。 UILoadMgr.Show(UIDefine.UILoadUpdate); Log.Info("Updatable resource mode detected."); ChangeState(procedureOwner); } else { Log.Error("UnKnow resource mode detected Please check???"); } } else { // 打开启动UI。 UILoadMgr.Show(UIDefine.UILoadUpdate); Log.Error($"{initializationOperation.Error}"); // 打开启动UI。 UILoadMgr.Show(UIDefine.UILoadUpdate, $"资源初始化失败!"); UILoadTip.ShowMessageBox($"资源初始化失败!点击确认重试 \n \n 原因{initializationOperation.Error}", MessageShowType.TwoButton, LoadStyle.StyleEnum.Style_Retry , () => { Retry(procedureOwner); }, UnityEngine.Application.Quit); } } private void Retry(ProcedureOwner procedureOwner) { // 打开启动UI。 UILoadMgr.Show(UIDefine.UILoadUpdate, $"重新初始化资源中..."); InitPackage(procedureOwner).Forget(); } /// /// 请求更新配置数据。 /// private async UniTask RequestUpdateData() { var checkVersionUrl = SettingsUtils.GetUpdateDataUrl(); if (string.IsNullOrEmpty(checkVersionUrl)) { Log.Error("LoadMgr.RequestVersion, remote url is empty or null"); return null; } Log.Info("RequestUpdateData, proxy:" + checkVersionUrl); var updateDataStr = await Utility.Http.Get(checkVersionUrl); try { UpdateData updateData = Utility.Json.ToObject(updateDataStr); return updateData; } catch (Exception e) { Log.Fatal(e); return null; } } } }