AxibugEmuOnline/AxibugEmuOnline.Client/Assets/Script/AppMain/App.cs

238 lines
7.3 KiB
C#
Raw Normal View History

using AxibugEmuOnline.Client.Manager;
2024-12-11 21:21:27 +08:00
using AxibugEmuOnline.Client.Network;
using AxibugProtobuf;
2025-01-07 00:27:59 +08:00
using System;
2024-12-11 21:21:27 +08:00
using System.Collections;
using System.IO;
using System.Threading.Tasks;
using UnityEngine;
using UnityEngine.Networking;
using static AxibugEmuOnline.Client.HttpAPI;
using static AxibugEmuOnline.Client.Manager.LogManager;
namespace AxibugEmuOnline.Client.ClientCore
{
public static class App
{
public static string TokenStr;
public static string IP;
public static int Port;
public static LogManager log;
public static NetworkHelper network;
public static AppLogin login;
public static AppChat chat;
public static UserDataManager user;
//public static AppNetGame netgame;
public static AppEmu emu;
public static RomLib nesRomLib;
public static HttpAPI httpAPI;
public static CacheManager CacheMgr;
public static AppRoom roomMgr;
public static AppSettings settings;
public static AppShare share;
2024-12-11 21:29:19 +08:00
static bool bTest;
static string mTestSrvIP;
2024-12-11 21:21:27 +08:00
#region Mono
public static TickLoop tickLoop;
private static CoroutineRunner coRunner;
2024-12-25 18:35:38 +08:00
#if UNITY_PSP2
public static SonyVitaCommonDialog sonyVitaCommonDialog;
#endif
2024-12-11 21:21:27 +08:00
#endregion
#if UNITY_PSP2 && !UNITY_EDITOR //PSV真机
2024-12-11 21:21:27 +08:00
public static string PersistentDataPath => "ux0:data/AxibugEmu";
#else
public static string PersistentDataPath => Application.persistentDataPath;
#endif
public static void Init( bool isTest = false, string testSrvIP = "")
2024-12-11 21:21:27 +08:00
{
2025-01-02 15:39:13 +08:00
log = new LogManager(OnLogOut);
2024-12-25 18:35:38 +08:00
//其他平台必要的初始化
if (UnityEngine.Application.platform == RuntimePlatform.PSP2)
{
PSP2Init();
}
settings = new AppSettings();
2024-12-11 21:21:27 +08:00
network = new NetworkHelper();
login = new AppLogin();
chat = new AppChat();
user = new UserDataManager();
emu = new AppEmu();
//netgame = new AppNetGame();
httpAPI = new HttpAPI();
nesRomLib = new RomLib(RomPlatformType.Nes);
2024-12-11 21:21:27 +08:00
CacheMgr = new CacheManager();
roomMgr = new AppRoom();
share = new AppShare();
2024-12-11 21:29:19 +08:00
bTest = isTest;
mTestSrvIP = testSrvIP;
2024-12-11 21:21:27 +08:00
var go = new GameObject("[AppAxibugEmuOnline]");
GameObject.DontDestroyOnLoad(go);
tickLoop = go.AddComponent<TickLoop>();
coRunner = go.AddComponent<CoroutineRunner>();
var importNode = GameObject.Find("IMPORTENT");
if (importNode != null) GameObject.DontDestroyOnLoad(importNode);
StartCoroutine(AppTickFlow());
RePullNetInfo();
}
private static void PSP2Init()
2024-12-11 21:21:27 +08:00
{
//PSVita最好手动创建目录
2024-12-11 21:21:27 +08:00
if (!Directory.Exists(PersistentDataPath))
Directory.CreateDirectory(PersistentDataPath);
#if UNITY_PSP2
2024-12-25 18:35:38 +08:00
//创建PSV弹窗UI
sonyVitaCommonDialog = new GameObject().AddComponent<SonyVitaCommonDialog>();
//释放解码 FMV的26M内存一般游戏用不上PSP才用那破玩意儿
UnityEngine.PSVita.PSVitaVideoPlayer.TransferMemToMonoHeap();
#endif
2024-12-25 18:35:38 +08:00
2024-12-11 21:21:27 +08:00
}
private static IEnumerator AppTickFlow()
{
while (true)
{
Tick();
yield return null;
}
}
public static void RePullNetInfo()
{
StartCoroutine(StartNetInit());
}
static IEnumerator StartNetInit()
{
if (App.network.isConnected)
yield break;
int platform = 0;
if (bTest)
{
yield return null;
2024-12-11 21:29:19 +08:00
Connect(mTestSrvIP, 10492);
2024-12-11 21:21:27 +08:00
yield break;
}
2025-01-07 00:27:59 +08:00
bool bHttpCheckDone = false;
Resp_CheckStandInfo resp = null;
while (true)
{
2025-01-07 00:27:59 +08:00
AxiHttpProxy.SendWebRequestProxy request = AxiHttpProxy.Get($"{App.httpAPI.WebSiteApi}/CheckStandInfo?platform={platform}&version={Application.version}");
yield return request.SendWebRequest;
if (!request.downloadHandler.isDone)
{
bHttpCheckDone = false;
}
else if (request.downloadHandler.bHadErr)
{
bHttpCheckDone = false;
App.log.Error(request.downloadHandler.ErrInfo);
}
else
{
try
{
resp = JsonUtility.FromJson<Resp_CheckStandInfo>(request.downloadHandler.text);
bHttpCheckDone = true;
}
catch (Exception ex)
{
bHttpCheckDone = false;
App.log.Error(ex.ToString());
}
}
//请求成功
if (bHttpCheckDone)
{
break;
}
else
{
yield return new WaitForSeconds(1);
App.log.Debug("请求失败重试请求API...");
}
}
/*UnityWebRequest request = UnityWebRequest.Get($"{App.httpAPI.WebSiteApi}/CheckStandInfo?platform={platform}&version={Application.version}");
2024-12-11 21:21:27 +08:00
yield return request.SendWebRequest();
if (request.result != UnityWebRequest.Result.Success)
yield break;
App.log.Debug($"ApiResp => {request.downloadHandler.text}");
Resp_CheckStandInfo resp = JsonUtility.FromJson<Resp_CheckStandInfo>(request.downloadHandler.text);*/
2024-12-11 21:21:27 +08:00
//需要更新
if (resp.needUpdateClient == 1)
{
//TODO
}
yield return null;
//Connect("127.0.0.1", 10492);
Connect(resp.serverIp, resp.serverPort);
}
private static void Tick()
{
nesRomLib.ExecuteFetchRomInfo();
}
public static Coroutine StartCoroutine(IEnumerator itor)
{
return coRunner.StartCoroutine(itor);
}
public static void StopCoroutine(Coroutine cor)
{
coRunner.StopCoroutine(cor);
}
public static void Connect(string IP, int port)
{
Task task = new Task(() =>
{
network.Init(IP, port);
});
task.Start();
}
public static void Close()
{
App.log.Info("停止");
}
2025-01-02 15:39:13 +08:00
static void OnLogOut(int LogLevel, string msg)
2024-12-11 21:21:27 +08:00
{
E_LogType logType = (E_LogType)LogLevel;
switch (logType)
{
case E_LogType.Debug:
case E_LogType.Info:
2025-01-02 15:39:13 +08:00
Debug.Log("[AxiNet]:" + msg);
2024-12-11 21:21:27 +08:00
break;
case E_LogType.Warning:
2025-01-02 15:39:13 +08:00
Debug.LogWarning("[AxiNet]:" + msg);
2024-12-11 21:21:27 +08:00
break;
case E_LogType.Error:
2025-01-02 15:39:13 +08:00
Debug.LogError("[AxiNet]:" + msg);
2024-12-11 21:21:27 +08:00
break;
}
}
}
}