master #40
@ -204,12 +204,12 @@ namespace AxibugEmuOnline.Client.Manager
|
||||
if (msg.UpdateType == 0)
|
||||
{
|
||||
AddOrUpdateRoomList(msg.RoomMiniInfo);
|
||||
Eventer.Instance.PostEvent(EEvent.OnRoomListSingleUpdate, msg.RoomMiniInfo.GameRomID);
|
||||
Eventer.Instance.PostEvent(EEvent.OnRoomListSingleUpdate, msg.RoomMiniInfo.RoomID);
|
||||
}
|
||||
else
|
||||
{
|
||||
RemoveRoomList(msg.RoomMiniInfo.GameRomID);
|
||||
Eventer.Instance.PostEvent(EEvent.OnRoomListSingleClose, msg.RoomMiniInfo.GameRomID);
|
||||
RemoveRoomList(msg.RoomMiniInfo.RoomID);
|
||||
Eventer.Instance.PostEvent(EEvent.OnRoomListSingleClose, msg.RoomMiniInfo.RoomID);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
using AxibugEmuOnline.Client.ClientCore;
|
||||
using AxibugEmuOnline.Client.Event;
|
||||
using AxibugEmuOnline.Client.UI;
|
||||
using AxibugProtobuf;
|
||||
using System;
|
||||
using UnityEngine;
|
||||
using UnityEngine.UI;
|
||||
|
||||
@ -21,11 +21,39 @@ namespace AxibugEmuOnline.Client
|
||||
private RomFile m_romFile;
|
||||
|
||||
public int Index { get; set; }
|
||||
public int roomID { get; private set; }
|
||||
|
||||
protected override void Awake()
|
||||
{
|
||||
base.Awake();
|
||||
|
||||
Eventer.Instance.RegisterEvent<int>(EEvent.OnRoomListSingleUpdate, OnRoomSingleUpdate);
|
||||
}
|
||||
|
||||
protected override void OnDestroy()
|
||||
{
|
||||
Eventer.Instance.UnregisterEvent<int>(EEvent.OnRoomListSingleUpdate, OnRoomSingleUpdate);
|
||||
}
|
||||
|
||||
private void OnRoomSingleUpdate(int roomId)
|
||||
{
|
||||
if (roomId != roomID) return;
|
||||
|
||||
if (App.roomMgr.GetRoomListMiniInfo(roomId, out var roomInfo))
|
||||
{
|
||||
UpdateUI(roomInfo);
|
||||
}
|
||||
}
|
||||
|
||||
public void SetData(object data)
|
||||
{
|
||||
if (data is Protobuf_Room_MiniInfo roomInfo)
|
||||
var roomInfo = data as Protobuf_Room_MiniInfo;
|
||||
roomID = roomInfo.RoomID;
|
||||
|
||||
UpdateUI(roomInfo);
|
||||
}
|
||||
|
||||
private void UpdateUI(Protobuf_Room_MiniInfo roomInfo)
|
||||
{
|
||||
var hostNick = roomInfo.GetHostNickName();
|
||||
roomInfo.GetRoomPlayers(out var cur, out var max);
|
||||
@ -43,7 +71,6 @@ namespace AxibugEmuOnline.Client
|
||||
App.CacheMgr.GetSpriteCache(romFile.ImageURL, OnGetRomImage);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
private void Update()
|
||||
{
|
||||
|
@ -11,12 +11,15 @@ namespace AxibugEmuOnline.Client
|
||||
protected override void Awake()
|
||||
{
|
||||
Eventer.Instance.RegisterEvent<int>(EEvent.OnRoomListAllUpdate, OnRoomListUpdateAll);
|
||||
Eventer.Instance.RegisterEvent<int>(EEvent.OnRoomListSingleClose, OnRoomClosed);
|
||||
base.Awake();
|
||||
}
|
||||
|
||||
|
||||
protected override void OnDestroy()
|
||||
{
|
||||
Eventer.Instance.UnregisterEvent<int>(EEvent.OnRoomListAllUpdate, OnRoomListUpdateAll);
|
||||
Eventer.Instance.UnregisterEvent<int>(EEvent.OnRoomListSingleClose, OnRoomClosed);
|
||||
}
|
||||
|
||||
public override bool OnEnterItem()
|
||||
@ -40,6 +43,13 @@ namespace AxibugEmuOnline.Client
|
||||
RefreshUI();
|
||||
}
|
||||
}
|
||||
private void OnRoomClosed(int obj)
|
||||
{
|
||||
if (m_entering)
|
||||
{
|
||||
RefreshUI();
|
||||
}
|
||||
}
|
||||
|
||||
protected override void GetVirtualListDatas(Action<object> datas)
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user