master #75

Closed
Alienjack wants to merge 510 commits from Alienjack/AxibugEmuOnline_old:master into master
10 changed files with 2232 additions and 1063 deletions
Showing only changes of commit 7c5934bc6b - Show all commits

View File

@ -67,6 +67,6 @@
/// <summary> /// <summary>
/// 当房间中手柄位信息发生任何变化时触发,进入房间后也应该触发 /// 当房间中手柄位信息发生任何变化时触发,进入房间后也应该触发
/// </summary> /// </summary>
OnRoomSlotDataChanged, //todo : 实现这个事件 OnRoomSlotDataChanged,
} }
} }

View File

@ -72,18 +72,5 @@ namespace AxibugEmuOnline.Client.Manager
#endif #endif
} }
#region
void TestCreate()
{
App.roomMgr.SendCreateRoom(1, 0, string.Empty);
}
long TestFrameID = 0;
void TestEmuUpdate()
{
}
#endregion
} }
} }

View File

@ -18,7 +18,6 @@ namespace AxibugEmuOnline.Client.Manager
public bool IsHost => mineRoomMiniInfo?.HostPlayerUID == App.user.userdata.UID; public bool IsHost => mineRoomMiniInfo?.HostPlayerUID == App.user.userdata.UID;
public bool IsScreenProviderUID => mineRoomMiniInfo?.ScreenProviderUID == App.user.userdata.UID; public bool IsScreenProviderUID => mineRoomMiniInfo?.ScreenProviderUID == App.user.userdata.UID;
public RoomGameState RoomState => mineRoomMiniInfo.GameState; public RoomGameState RoomState => mineRoomMiniInfo.GameState;
public int MinePlayerIdx => GetMinePlayerIndex();
public int WaitStep { get; private set; } = -1; public int WaitStep { get; private set; } = -1;
public byte[] RawData { get; private set; } = null; public byte[] RawData { get; private set; } = null;
public NetReplay netReplay { get; private set; } public NetReplay netReplay { get; private set; }
@ -110,64 +109,31 @@ namespace AxibugEmuOnline.Client.Manager
#endregion #endregion
#region #region
int GetMinePlayerIndex() List<Protobuf_Room_GamePlaySlot> GetMinePlayerSlotInfo()
{ {
if (mineRoomMiniInfo == null) if (mineRoomMiniInfo == null)
return -1; return null;
return mineRoomMiniInfo.GamePlaySlotList.Where(w => w.PlayerUID == App.user.userdata.UID).ToList();
if (mineRoomMiniInfo.Player1UID == App.user.userdata.UID)
return 0;
if (mineRoomMiniInfo.Player2UID == App.user.userdata.UID)
return 1;
if (mineRoomMiniInfo.Player3UID == App.user.userdata.UID)
return 2;
if (mineRoomMiniInfo.Player4UID == App.user.userdata.UID)
return 3;
return -1;
} }
long[] GetRoom4PlayerUIDs() long[] GetRoom4PlayerUIDs()
{ {
if (mineRoomMiniInfo == null) if (mineRoomMiniInfo == null)
return null; return null;
long[] result = new long[4]; long[] result = new long[mineRoomMiniInfo.GamePlaySlotList.Count];
if (mineRoomMiniInfo.Player1UID > 0) for (int i = 0; i < mineRoomMiniInfo.GamePlaySlotList.Count; i++)
result[0] = mineRoomMiniInfo.Player1UID; {
if (mineRoomMiniInfo.Player2UID > 0) if (mineRoomMiniInfo.GamePlaySlotList[i].PlayerUID > 0)
result[1] = mineRoomMiniInfo.Player2UID; result[i] = mineRoomMiniInfo.GamePlaySlotList[i].PlayerUID;
if (mineRoomMiniInfo.Player3UID > 0) }
result[2] = mineRoomMiniInfo.Player3UID;
if (mineRoomMiniInfo.Player4UID > 0)
result[3] = mineRoomMiniInfo.Player4UID;
return result; return result;
} }
S_PlayerMiniInfo[] GetRoom4PlayerMiniInfos() Protobuf_Room_GamePlaySlot[] GetRoom4GameSlotMiniInfos()
{ {
if (mineRoomMiniInfo == null) if (mineRoomMiniInfo == null)
return null; return null;
S_PlayerMiniInfo[] result = new S_PlayerMiniInfo[4]; return mineRoomMiniInfo.GamePlaySlotList.ToArray();
if (mineRoomMiniInfo.Player1UID > 0)
{
result[0].UID = mineRoomMiniInfo.Player1UID;
result[0].NickName = mineRoomMiniInfo.Player1NickName;
}
if (mineRoomMiniInfo.Player2UID > 0)
{
result[1].UID = mineRoomMiniInfo.Player2UID;
result[1].NickName = mineRoomMiniInfo.Player2NickName;
}
if (mineRoomMiniInfo.Player3UID > 0)
{
result[2].UID = mineRoomMiniInfo.Player3UID;
result[2].NickName = mineRoomMiniInfo.Player3NickName;
}
if (mineRoomMiniInfo.Player4UID > 0)
{
result[3].UID = mineRoomMiniInfo.Player4UID;
result[3].NickName = mineRoomMiniInfo.Player4NickName;
}
return result;
} }
#endregion #endregion
@ -251,9 +217,8 @@ namespace AxibugEmuOnline.Client.Manager
/// <param name="GameRomID"></param> /// <param name="GameRomID"></param>
/// <param name="JoinPlayerIdx"></param> /// <param name="JoinPlayerIdx"></param>
/// <param name="GameRomHash"></param> /// <param name="GameRomHash"></param>
public void SendCreateRoom(int GameRomID, int JoinPlayerIdx, string GameRomHash = null) public void SendCreateRoom(int GameRomID, string GameRomHash = null)
{ {
_Protobuf_Room_Create.JoinPlayerIdx = JoinPlayerIdx;
_Protobuf_Room_Create.GameRomID = GameRomID; _Protobuf_Room_Create.GameRomID = GameRomID;
_Protobuf_Room_Create.GameRomHash = GameRomHash; _Protobuf_Room_Create.GameRomHash = GameRomHash;
App.log.Info($"创建房间"); App.log.Info($"创建房间");
@ -278,13 +243,12 @@ namespace AxibugEmuOnline.Client.Manager
/// <summary> /// <summary>
/// 创建房间 /// 创建房间
/// </summary> /// </summary>
/// <param name="GameRomID"></param> /// <param name="RoomID"></param>
/// <param name="JoinPlayerIdx"></param> /// <param name="JoinSlotIdx">加入时所在SlotIdx</param>
/// <param name="GameRomHash"></param> /// <param name="LocalJoyIdx">加入时候本地对应JoyIdx</param>
public void SendJoinRoom(int RoomID, int JoinPlayerIdx) public void SendJoinRoom(int RoomID)
{ {
_Protobuf_Room_Join.RoomID = RoomID; _Protobuf_Room_Join.RoomID = RoomID;
_Protobuf_Room_Join.PlayerNum = JoinPlayerIdx;
App.log.Info($"加入房间"); App.log.Info($"加入房间");
App.network.SendToServer((int)CommandID.CmdRoomJoin, ProtoBufHelper.Serizlize(_Protobuf_Room_Join)); App.network.SendToServer((int)CommandID.CmdRoomJoin, ProtoBufHelper.Serizlize(_Protobuf_Room_Join));
} }
@ -336,35 +300,105 @@ namespace AxibugEmuOnline.Client.Manager
{ {
Protobuf_Room_MyRoom_State_Change msg = ProtoBufHelper.DeSerizlize<Protobuf_Room_MyRoom_State_Change>(reqData); Protobuf_Room_MyRoom_State_Change msg = ProtoBufHelper.DeSerizlize<Protobuf_Room_MyRoom_State_Change>(reqData);
long[] oldRoomPlayer = GetRoom4PlayerUIDs(); long[] oldRoomPlayer = GetRoom4PlayerUIDs();
Protobuf_Room_GamePlaySlot[] oldslotArr = GetRoom4GameSlotMiniInfos();
mineRoomMiniInfo = msg.RoomMiniInfo; mineRoomMiniInfo = msg.RoomMiniInfo;
long[] newRoomPlayer = GetRoom4PlayerUIDs(); long[] newRoomPlayer = GetRoom4PlayerUIDs();
Protobuf_Room_GamePlaySlot[] newslotArr = GetRoom4GameSlotMiniInfos();
oldRoomPlayer = oldRoomPlayer.Where(w => w > 0).Distinct().ToArray();
newRoomPlayer = newRoomPlayer.Where(w => w > 0).Distinct().ToArray();
//离开用户
foreach (var leavn in oldRoomPlayer.Where(w => !newRoomPlayer.Contains(w)))
{
UserDataBase oldplayer = App.user.GetUserByUid(leavn);
string oldPlayName = oldplayer != null ? oldplayer.NickName : "Player";
OverlayManager.PopTip($"[{oldPlayName}]离开房间");
Eventer.Instance.PostEvent(EEvent.OnOtherPlayerLeavnRoom, leavn);
}
//新加入用户
foreach (var newJoin in newRoomPlayer.Where(w => !oldRoomPlayer.Contains(w)))
{
UserDataBase newplayer = App.user.GetUserByUid(newJoin);
string newplayerName = newplayer != null ? newplayer.NickName : "Player";
OverlayManager.PopTip($"[{newplayer}]进入房间");
Eventer.Instance.PostEvent(EEvent.OnOtherPlayerJoinRoom, newJoin);
}
bool bChangeSlot = false;
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
long OldPlayer = oldRoomPlayer[i]; var oldSlot = oldslotArr[i];
long NewPlayer = newRoomPlayer[i]; var newSlot = newslotArr[i];
if (OldPlayer == NewPlayer) if (oldSlot.PlayerUID <= 0 && newSlot.PlayerUID <= 0)
continue; continue;
//位置之前有人,但是离开了 if (
if (OldPlayer > 0) oldSlot.PlayerUID != newSlot.PlayerUID
||
oldSlot.PlayerLocalJoyIdx != newSlot.PlayerLocalJoyIdx
)
{ {
Eventer.Instance.PostEvent(EEvent.OnOtherPlayerLeavnRoom, i, OldPlayer); bChangeSlot = true;
UserDataBase oldplayer = App.user.GetUserByUid(OldPlayer); if (newSlot.PlayerUID > 0)
string oldPlayName = oldplayer != null ? oldplayer.NickName : "Player";
OverlayManager.PopTip($"[{oldPlayName}]离开房间,手柄位:P{i}");
if (NewPlayer > 0)//而且害换了一个玩家
{ {
Eventer.Instance.PostEvent(EEvent.OnOtherPlayerJoinRoom, i, NewPlayer); OverlayManager.PopTip($"[{newSlot.PlayerNickName}]使用:P{i}");
mineRoomMiniInfo.GetPlayerNameByPlayerIdx((uint)i, out string PlayerName);
OverlayManager.PopTip($"[{PlayerName}]进入房间,手柄位:P{i}");
} }
} }
else //之前没人
{
Eventer.Instance.PostEvent(EEvent.OnOtherPlayerJoinRoom, i, NewPlayer);
mineRoomMiniInfo.GetPlayerNameByPlayerIdx((uint)i, out string PlayerName);
OverlayManager.PopTip($"[{PlayerName}]进入房间,手柄位:P{i}");
}
} }
if (bChangeSlot)
{
Eventer.Instance.PostEvent(EEvent.OnRoomSlotDataChanged);
}
//for (int i = 0; i < 4; i++)
//{
// long OldPlayer = oldRoomPlayer[i];
// long NewPlayer = newRoomPlayer[i];
// if (OldPlayer == NewPlayer)
// continue;
// //位置之前有人,但是离开了
// if (OldPlayer > 0)
// {
// Eventer.Instance.PostEvent(EEvent.OnOtherPlayerLeavnRoom, i, OldPlayer);
// UserDataBase oldplayer = App.user.GetUserByUid(OldPlayer);
// string oldPlayName = oldplayer != null ? oldplayer.NickName : "Player";
// OverlayManager.PopTip($"[{oldPlayName}]离开房间,手柄位:P{i}");
// if (NewPlayer > 0)//而且害换了一个玩家
// {
// Eventer.Instance.PostEvent(EEvent.OnOtherPlayerJoinRoom, i, NewPlayer);
// mineRoomMiniInfo.GetPlayerNameByPlayerIdx((uint)i, out string PlayerName);
// OverlayManager.PopTip($"[{PlayerName}]进入房间,手柄位:P{i}");
// }
// }
// else //之前没人
// {
// Eventer.Instance.PostEvent(EEvent.OnOtherPlayerJoinRoom, i, NewPlayer);
// mineRoomMiniInfo.GetPlayerNameByPlayerIdx((uint)i, out string PlayerName);
// OverlayManager.PopTip($"[{PlayerName}]进入房间,手柄位:P{i}");
// }
// //位置之前有人,但是离开了
// if (OldPlayer > 0)
// {
// Eventer.Instance.PostEvent(EEvent.OnOtherPlayerLeavnRoom, i, OldPlayer);
// UserDataBase oldplayer = App.user.GetUserByUid(OldPlayer);
// string oldPlayName = oldplayer != null ? oldplayer.NickName : "Player";
// OverlayManager.PopTip($"[{oldPlayName}]离开房间,手柄位:P{i}");
// if (NewPlayer > 0)//而且害换了一个玩家
// {
// Eventer.Instance.PostEvent(EEvent.OnOtherPlayerJoinRoom, i, NewPlayer);
// mineRoomMiniInfo.GetPlayerNameByPlayerIdx((uint)i, out string PlayerName);
// OverlayManager.PopTip($"[{PlayerName}]进入房间,手柄位:P{i}");
// }
// }
// else //之前没人
// {
// Eventer.Instance.PostEvent(EEvent.OnOtherPlayerJoinRoom, i, NewPlayer);
// mineRoomMiniInfo.GetPlayerNameByPlayerIdx((uint)i, out string PlayerName);
// OverlayManager.PopTip($"[{PlayerName}]进入房间,手柄位:P{i}");
// }
//}
} }
/// <summary> /// <summary>
@ -461,14 +495,11 @@ namespace AxibugEmuOnline.Client.Manager
if (mineRoomMiniInfo == null) if (mineRoomMiniInfo == null)
{ {
if (mineRoomMiniInfo.Player1UID == uid) foreach (var gameslot in mineRoomMiniInfo.GamePlaySlotList)
mineRoomMiniInfo.Player1NickName = userdata.NickName; {
else if (mineRoomMiniInfo.Player2UID == uid) if (gameslot.PlayerUID == uid)
mineRoomMiniInfo.Player2NickName = userdata.NickName; gameslot.PlayerNickName = userdata.NickName;
else if (mineRoomMiniInfo.Player3UID == uid) }
mineRoomMiniInfo.Player3NickName = userdata.NickName;
else if (mineRoomMiniInfo.Player4UID == uid)
mineRoomMiniInfo.Player4NickName = userdata.NickName;
} }
} }
} }
@ -484,34 +515,38 @@ namespace AxibugEmuOnline.Client.Manager
public static bool GetFreeSlot(this Protobuf_Room_MiniInfo roomMiniInfo, out int[] freeSlots) public static bool GetFreeSlot(this Protobuf_Room_MiniInfo roomMiniInfo, out int[] freeSlots)
{ {
List<int> temp = new List<int>(); List<int> temp = new List<int>();
if (roomMiniInfo.Player1UID <= 0) temp.Add(0); for (int i = 0; i < roomMiniInfo.GamePlaySlotList.Count; i++)
if (roomMiniInfo.Player2UID <= 0) temp.Add(1); {
if (roomMiniInfo.Player3UID <= 0) temp.Add(2); if (roomMiniInfo.GamePlaySlotList[i].PlayerUID <= 0)
if (roomMiniInfo.Player4UID <= 0) temp.Add(3); temp.Add(i);
}
freeSlots = temp.ToArray(); freeSlots = temp.ToArray();
return freeSlots.Length > 0; return freeSlots.Length > 0;
} }
/// <summary> /// <summary>
/// 指定uid和该uid的本地手柄序号,获取占用的手柄位 /// 指定uid和该uid的本地手柄序号,获取占用的手柄位
/// </summary> /// </summary>
public static bool GetPlayerSlotIdxByUid(this Protobuf_Room_MiniInfo roomMiniInfo, long uid ,int controllerIndex, out uint? slotID) public static bool GetPlayerSlotIdxByUid(this Protobuf_Room_MiniInfo roomMiniInfo, long uid, int joyIdx, out uint? slotIdx)
{ {
slotID = null; slotIdx = null;
//joyIdx取值返回[0,3],这个序号代表玩家本地的手柄编号
//controllerIndex取值返回[0,3],这个序号代表玩家本地的手柄编号
//todo : 根据uid和controllerIndex 返回占用的位置 //todo : 根据uid和controllerIndex 返回占用的位置
//目前未实现,所有非0号位置的手柄,都返回false //目前未实现,所有非0号位置的手柄,都返回false
if (controllerIndex != 0) return false;
if (roomMiniInfo.Player1UID == uid) slotID = 0; for (int i = 0; i < roomMiniInfo.GamePlaySlotList.Count; i++)
if (roomMiniInfo.Player2UID == uid) slotID = 1; {
if (roomMiniInfo.Player3UID == uid) slotID = 2; if (roomMiniInfo.GamePlaySlotList[i].PlayerUID == uid)
if (roomMiniInfo.Player4UID == uid) slotID = 3; {
return true; slotIdx = (uint)i;
return true;
}
}
return false;
} }
/// <summary> /// <summary>
/// 按照房间玩家下标获取昵称 /// 按照房间玩家下标获取昵称
/// </summary> /// </summary>
@ -519,16 +554,11 @@ namespace AxibugEmuOnline.Client.Manager
/// <param name="PlayerIndex"></param> /// <param name="PlayerIndex"></param>
/// <param name="PlayerName"></param> /// <param name="PlayerName"></param>
/// <returns></returns> /// <returns></returns>
public static bool GetPlayerNameByPlayerIdx(this Protobuf_Room_MiniInfo roomMiniInfo,uint PlayerIndex, out string PlayerName) public static bool GetPlayerNameByPlayerIdx(this Protobuf_Room_MiniInfo roomMiniInfo, uint GameSlotIdx, out string PlayerName)
{ {
PlayerName = string.Empty; PlayerName = string.Empty;
switch (PlayerIndex) if (roomMiniInfo.GamePlaySlotList[(int)GameSlotIdx].PlayerUID > 0)
{ PlayerName = roomMiniInfo.GamePlaySlotList[(int)GameSlotIdx].PlayerNickName;
case 0: PlayerName = roomMiniInfo.Player1UID > 0 ? roomMiniInfo.Player1NickName : null; break;
case 1: PlayerName = roomMiniInfo.Player2UID > 0 ? roomMiniInfo.Player2NickName : null; break;
case 2: PlayerName = roomMiniInfo.Player3UID > 0 ? roomMiniInfo.Player3NickName : null; break;
case 3: PlayerName = roomMiniInfo.Player4UID > 0 ? roomMiniInfo.Player4NickName : null; break;
}
return string.IsNullOrEmpty(PlayerName); return string.IsNullOrEmpty(PlayerName);
} }
} }

View File

@ -1,4 +1,5 @@
using AxibugEmuOnline.Client.ClientCore; using AxibugEmuOnline.Client.ClientCore;
using AxibugProtobuf;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
@ -83,6 +84,12 @@ namespace AxibugEmuOnline.Client.Network
public void PostNetMsgEvent(int cmd, int ERRCODE, byte[] arg) public void PostNetMsgEvent(int cmd, int ERRCODE, byte[] arg)
{ {
ErrorCode err = ((ErrorCode)ERRCODE);
if (err != ErrorCode.ErrorOk)
{
OverlayManager.PopTip("错误:"+err.ToString());
}
List<Delegate> eventList = GetNetEventDicList(cmd); List<Delegate> eventList = GetNetEventDicList(cmd);
if (eventList != null) if (eventList != null)
{ {

View File

@ -83,7 +83,7 @@ namespace AxibugEmuOnline.Client
{ {
if (App.user.IsLoggedIn) if (App.user.IsLoggedIn)
{ {
App.roomMgr.SendCreateRoom(RomFile.ID, 0, RomFile.Hash); App.roomMgr.SendCreateRoom(RomFile.ID, RomFile.Hash);
} }
else else
{ {
@ -116,7 +116,7 @@ namespace AxibugEmuOnline.Client
private void OnLoggedIn() private void OnLoggedIn()
{ {
if (m_delayCreateRoom) App.roomMgr.SendCreateRoom(RomFile.ID, 0, RomFile.Hash); if (m_delayCreateRoom) App.roomMgr.SendCreateRoom(RomFile.ID, RomFile.Hash);
} }
private void OnServerStepUpdate(int step) private void OnServerStepUpdate(int step)

View File

@ -39,7 +39,7 @@ namespace AxibugEmuOnline.Client
public void SetData(object data) public void SetData(object data)
{ {
Debug.Assert(data is Protobuf_Room_MiniInfo); Debug.Assert(data is Protobuf_Room_MiniInfo);
var roomInfo = (Protobuf_Room_MiniInfo)data; var roomInfo = (Protobuf_Room_MiniInfo)data;
RoomID = roomInfo.RoomID; RoomID = roomInfo.RoomID;
@ -69,7 +69,7 @@ namespace AxibugEmuOnline.Client
return false; return false;
} }
App.roomMgr.SendJoinRoom(RoomID, freeSlots[0]); App.roomMgr.SendJoinRoom(RoomID);
return true; return true;
} }
} }

View File

@ -2,6 +2,7 @@ using AxibugEmuOnline.Client.ClientCore;
using AxibugProtobuf; using AxibugProtobuf;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq;
using UnityEngine; using UnityEngine;
namespace AxibugEmuOnline.Client namespace AxibugEmuOnline.Client
@ -19,21 +20,17 @@ namespace AxibugEmuOnline.Client
public static string GetHostNickName(this Protobuf_Room_MiniInfo roomInfo) public static string GetHostNickName(this Protobuf_Room_MiniInfo roomInfo)
{ {
var hostUID = roomInfo.HostPlayerUID; var hostUID = roomInfo.HostPlayerUID;
if (hostUID == roomInfo.Player1UID) return roomInfo.Player1NickName; Protobuf_Room_GamePlaySlot slotdata = roomInfo.GamePlaySlotList.FirstOrDefault(w => w.PlayerUID == hostUID);
else if (hostUID == roomInfo.Player2UID) return roomInfo.Player2NickName; if (slotdata != null)
else if (hostUID == roomInfo.Player3UID) return roomInfo.Player3NickName; return slotdata.PlayerNickName;
else if (hostUID == roomInfo.Player4UID) return roomInfo.Player4NickName; else
else return string.Empty; return string.Empty;
} }
public static void GetRoomPlayers(this Protobuf_Room_MiniInfo roomInfo, out int current, out int max) public static void GetRoomPlayers(this Protobuf_Room_MiniInfo roomInfo, out int current, out int max)
{ {
current = 0; max = 4; current = 0; max = 4;
current = roomInfo.GamePlaySlotList.Count(w => w.PlayerUID > 0);
if (roomInfo.Player1UID > 0) current++;
if (roomInfo.Player2UID > 0) current++;
if (roomInfo.Player3UID > 0) current++;
if (roomInfo.Player4UID > 0) current++;
} }
private static Dictionary<int, RomFile> s_RomFileCahcesInRoomInfo = new Dictionary<int, RomFile>(); private static Dictionary<int, RomFile> s_RomFileCahcesInRoomInfo = new Dictionary<int, RomFile>();

File diff suppressed because it is too large Load Diff

View File

@ -300,8 +300,6 @@ message Protobuf_Room_Create
{ {
int32 GameRomID = 1; int32 GameRomID = 1;
string GameRomHash = 2; string GameRomHash = 2;
int32 PlayerSlotIdx = 3;//P1~P4编号
int32 PlayerLocalJoyIdx = 4;//Joy编号
} }
message Protobuf_Room_Create_RESP message Protobuf_Room_Create_RESP
@ -312,8 +310,6 @@ message Protobuf_Room_Create_RESP
message Protobuf_Room_Join message Protobuf_Room_Join
{ {
int32 RoomID = 1;//ID int32 RoomID = 1;//ID
int32 PlayerSlotIdx = 2;//P1~P4编号
int32 PlayerLocalJoyIdx = 3;//Joy编号
} }
message Protobuf_Room_Join_RESP message Protobuf_Room_Join_RESP