diff --git a/AxibugEmuOnline.Client/Assets/Script/IEmuCore.cs b/AxibugEmuOnline.Client/Assets/Script/IEmuCore.cs
index a054acfd..34c04d67 100644
--- a/AxibugEmuOnline.Client/Assets/Script/IEmuCore.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/IEmuCore.cs
@@ -1,5 +1,3 @@
-using System.Collections;
-using System.Collections.Generic;
using UnityEngine;
namespace AxibugEmuOnline.Client
@@ -17,4 +15,13 @@ namespace AxibugEmuOnline.Client
void SetupScheme();
void StartGame(RomFile romFile);
}
+
+ public static class IEnumCoreTool
+ {
+ public static bool IsNull(this IEmuCore core)
+ {
+ if (core == null) return true;
+ return core.Equals(null);
+ }
+ }
}
diff --git a/AxibugEmuOnline.Client/Assets/Script/Manager/AppEmu.cs b/AxibugEmuOnline.Client/Assets/Script/Manager/AppEmu.cs
index 4b59524a..697bf689 100644
--- a/AxibugEmuOnline.Client/Assets/Script/Manager/AppEmu.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/Manager/AppEmu.cs
@@ -1,17 +1,47 @@
using AxibugEmuOnline.Client.ClientCore;
+using AxibugEmuOnline.Client.Event;
using MyNes.Core;
+using System;
using UnityEngine;
namespace AxibugEmuOnline.Client.Manager
{
public class AppEmu
{
- private GameObject m_emuInstance;
+ ///
+ /// unity的c#实现有bug,以接口类型保存的monobehaviour引用,!=和==运算符没有调用到monobehaviour重写过的运算符
+ /// 但是Equals方法可以,所以,这个接口判断为空请使用Equals
+ ///
private IEmuCore m_emuCore;
+ public AppEmu()
+ {
+ Eventer.Instance.RegisterEvent(EEvent.OnMineJoinRoom, OnSelfJoinRoom);
+ }
+
+ private void OnSelfJoinRoom()
+ {
+ //如果当前正在游戏中,就先结束游戏
+ if (!m_emuCore.IsNull()) StopGame();
+
+ var roomInfo = App.roomMgr.mineRoomMiniInfo;
+ roomInfo.FetchRomFileInRoomInfo(EnumPlatform.NES, (room, romFile) =>
+ {
+ if (!romFile.RomReady) //这个rom并没有下载,所以取消进入房间
+ {
+ App.roomMgr.SendLeavnRoom();
+ }
+ else
+ {
+ BeginGame(romFile);
+ }
+ });
+ }
+
+
public void BeginGame(RomFile romFile)
{
- if (m_emuInstance != null) return;
+ if (!m_emuCore.Equals(null)) return;
switch (romFile.Platform)
{
@@ -20,8 +50,6 @@ namespace AxibugEmuOnline.Client.Manager
break;
}
- m_emuInstance = m_emuCore.gameObject;
-
m_emuCore.StartGame(romFile);
LaunchUI.Instance.HideMainMenu();
InGameUI.Instance.Show(romFile, m_emuCore);
@@ -31,9 +59,9 @@ namespace AxibugEmuOnline.Client.Manager
public void StopGame()
{
- if (m_emuInstance == null) return;
- GameObject.Destroy(m_emuInstance);
- m_emuInstance = null;
+ if (m_emuCore.IsNull()) return;
+ GameObject.Destroy(m_emuCore.gameObject);
+ m_emuCore = null;
InGameUI.Instance.Hide();
LaunchUI.Instance.ShowMainMenu();
diff --git a/AxibugEmuOnline.Client/Assets/Script/Manager/RomLib/RomFile.cs b/AxibugEmuOnline.Client/Assets/Script/Manager/RomLib/RomFile.cs
index a4eb71a7..0508534d 100644
--- a/AxibugEmuOnline.Client/Assets/Script/Manager/RomLib/RomFile.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/Manager/RomLib/RomFile.cs
@@ -48,7 +48,7 @@ namespace AxibugEmuOnline.Client
public int Page { get; private set; }
public string Hash => webData != null ? webData.hash : string.Empty;
- public event Action OnDownloadOver;
+ public event Action OnDownloadOver;
public event Action OnInfoFilled;
public RomFile(EnumPlatform platform, int index, int insidePage)
@@ -73,7 +73,7 @@ namespace AxibugEmuOnline.Client
File.WriteAllBytes(LocalFilePath, bytes);
hasLocalFile = true;
}
- OnDownloadOver?.Invoke();
+ OnDownloadOver?.Invoke(this);
}));
}
@@ -115,13 +115,16 @@ namespace AxibugEmuOnline.Client
downloadRequest = UnityWebRequest.Get($"{App.httpAPI.WebHost}/{webData.url}");
yield return downloadRequest.SendWebRequest();
- if (downloadRequest.result != UnityWebRequest.Result.Success)
+ var request = downloadRequest;
+ downloadRequest = null;
+
+ if (request.result != UnityWebRequest.Result.Success)
{
callback(null);
}
else
{
- callback(downloadRequest.downloadHandler.data);
+ callback(request.downloadHandler.data);
}
}
diff --git a/AxibugEmuOnline.Client/Assets/Script/NesEmulator/NesEmulator.cs b/AxibugEmuOnline.Client/Assets/Script/NesEmulator/NesEmulator.cs
index 4061b1ca..69d64fe5 100644
--- a/AxibugEmuOnline.Client/Assets/Script/NesEmulator/NesEmulator.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/NesEmulator/NesEmulator.cs
@@ -69,7 +69,6 @@ namespace AxibugEmuOnline.Client
}
}
-
public void Pause()
{
m_bPause = true;
diff --git a/AxibugEmuOnline.Client/Assets/Script/UI/InGameUI/StepPerformer.cs b/AxibugEmuOnline.Client/Assets/Script/UI/InGameUI/StepPerformer.cs
index 95646016..1b3f342c 100644
--- a/AxibugEmuOnline.Client/Assets/Script/UI/InGameUI/StepPerformer.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/UI/InGameUI/StepPerformer.cs
@@ -18,7 +18,6 @@ namespace AxibugEmuOnline.Client
{
m_step = step;
-
switch (m_step)
{
//等待主机上报快照
diff --git a/AxibugEmuOnline.Client/Assets/Script/UI/RoomItem.cs b/AxibugEmuOnline.Client/Assets/Script/UI/RoomItem.cs
index 56016ee0..6db698c9 100644
--- a/AxibugEmuOnline.Client/Assets/Script/UI/RoomItem.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/UI/RoomItem.cs
@@ -2,6 +2,7 @@ using AxibugEmuOnline.Client.ClientCore;
using AxibugEmuOnline.Client.Event;
using AxibugEmuOnline.Client.UI;
using AxibugProtobuf;
+using System;
using UnityEngine;
using UnityEngine.UI;
@@ -27,22 +28,15 @@ namespace AxibugEmuOnline.Client
{
base.Awake();
- Eventer.Instance.RegisterEvent(EEvent.OnRoomListSingleUpdate, OnRoomSingleUpdate);
+ Eventer.Instance.RegisterEvent(EEvent.OnRoomListSingleUpdate, OnRoomSignelUpdate);
}
- protected override void OnDestroy()
+ private void OnRoomSignelUpdate(int roomID)
{
- Eventer.Instance.UnregisterEvent(EEvent.OnRoomListSingleUpdate, OnRoomSingleUpdate);
- }
+ if (this.roomID != roomID) return;
- private void OnRoomSingleUpdate(int roomId)
- {
- if (roomId != roomID) return;
-
- if (App.roomMgr.GetRoomListMiniInfo(roomId, out var roomInfo))
- {
+ if (App.roomMgr.GetRoomListMiniInfo(roomID, out var roomInfo))
UpdateUI(roomInfo);
- }
}
public void SetData(object data)
@@ -53,6 +47,20 @@ namespace AxibugEmuOnline.Client
UpdateUI(roomInfo);
}
+ public override bool OnEnterItem()
+ {
+ if (!m_romFile.RomReady)
+ {
+ m_romFile.BeginDownload();
+ return false;
+ }
+ else
+ {
+ App.roomMgr.SendJoinRoom(roomID, 1);
+ return true;
+ }
+ }
+
private void UpdateUI(Protobuf_Room_MiniInfo roomInfo)
{
var hostNick = roomInfo.GetHostNickName();
@@ -60,12 +68,12 @@ namespace AxibugEmuOnline.Client
SetBaseInfo(string.Empty, $"{hostNick}ķ - {cur}/{max}");
SetIcon(null);
- roomInfo.FetchRomFileInRoomInfo(EnumPlatform.NES, (romFile) =>
+ roomInfo.FetchRomFileInRoomInfo(EnumPlatform.NES, (room, romFile) =>
{
- m_romFile = romFile;
+ if (room.RoomID != roomID) return;
- if (romFile.ID == roomInfo.GameRomID)
- Txt.text = romFile.Alias;
+ m_romFile = romFile;
+ Txt.text = romFile.Alias;
UpdateRomInfoView();
App.CacheMgr.GetSpriteCache(romFile.ImageURL, OnGetRomImage);
diff --git a/AxibugEmuOnline.Client/Assets/Script/UI/RoomListMenuItem.cs b/AxibugEmuOnline.Client/Assets/Script/UI/RoomListMenuItem.cs
index 45149131..48a2fb32 100644
--- a/AxibugEmuOnline.Client/Assets/Script/UI/RoomListMenuItem.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/UI/RoomListMenuItem.cs
@@ -12,6 +12,7 @@ namespace AxibugEmuOnline.Client
{
Eventer.Instance.RegisterEvent(EEvent.OnRoomListAllUpdate, OnRoomListUpdateAll);
Eventer.Instance.RegisterEvent(EEvent.OnRoomListSingleClose, OnRoomClosed);
+ Eventer.Instance.RegisterEvent(EEvent.OnRoomListSingleAdd, OnRoomSingleAdd);
base.Awake();
}
@@ -19,6 +20,7 @@ namespace AxibugEmuOnline.Client
protected override void OnDestroy()
{
Eventer.Instance.UnregisterEvent(EEvent.OnRoomListAllUpdate, OnRoomListUpdateAll);
+ Eventer.Instance.UnregisterEvent(EEvent.OnRoomListSingleUpdate, OnRoomSingleAdd);
Eventer.Instance.UnregisterEvent(EEvent.OnRoomListSingleClose, OnRoomClosed);
}
@@ -36,6 +38,14 @@ namespace AxibugEmuOnline.Client
return res;
}
+ private void OnRoomSingleAdd(int obj)
+ {
+ if (m_entering)
+ {
+ RefreshUI();
+ }
+ }
+
private void OnRoomListUpdateAll(int obj)
{
if (m_entering)
diff --git a/AxibugEmuOnline.Client/Assets/Script/UI/VirtualSubMenuItem.cs b/AxibugEmuOnline.Client/Assets/Script/UI/VirtualSubMenuItem.cs
index 9721a825..859d9dec 100644
--- a/AxibugEmuOnline.Client/Assets/Script/UI/VirtualSubMenuItem.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/UI/VirtualSubMenuItem.cs
@@ -20,7 +20,7 @@ namespace AxibugEmuOnline.Client
base.Awake();
RomGroupRoot.gameObject.SetActive(false);
- RomGroupRoot.alpha = 0;
+ RomGroupRoot.alpha = 0;
}
public override void SetSelectState(bool selected)
@@ -58,7 +58,7 @@ namespace AxibugEmuOnline.Client
thirdMenuGroup.itemGroup.Clear();
RefreshUI();
-
+
if (SubMenuItemGroup != null) SubMenuItemGroup.SetSelect(true);
return true;
diff --git a/AxibugEmuOnline.Client/Assets/Script/Utility.cs b/AxibugEmuOnline.Client/Assets/Script/Utility.cs
index 58bc19bf..973471ae 100644
--- a/AxibugEmuOnline.Client/Assets/Script/Utility.cs
+++ b/AxibugEmuOnline.Client/Assets/Script/Utility.cs
@@ -38,11 +38,11 @@ namespace AxibugEmuOnline.Client
}
private static Dictionary s_RomFileCahcesInRoomInfo = new Dictionary();
- public static void FetchRomFileInRoomInfo(this Protobuf_Room_MiniInfo roomInfo, EnumPlatform platform, Action callback)
+ public static void FetchRomFileInRoomInfo(this Protobuf_Room_MiniInfo roomInfo, EnumPlatform platform, Action callback)
{
if (s_RomFileCahcesInRoomInfo.TryGetValue(roomInfo.GameRomID, out RomFile romFile))
{
- callback.Invoke(romFile);
+ callback.Invoke(roomInfo,romFile);
return;
}
switch (platform)
@@ -52,9 +52,9 @@ namespace AxibugEmuOnline.Client
{
RomFile romFile = new RomFile(EnumPlatform.NES, 0, 0);
romFile.SetWebData(romWebData);
- callback.Invoke(romFile);
-
s_RomFileCahcesInRoomInfo[roomInfo.GameRomID] = romFile;
+
+ callback.Invoke(roomInfo,romFile);
}));
break;
}