服务端房间功能
This commit is contained in:
parent
90a64b85fe
commit
b394410ab0
31
AxibugEmuOnline.Server/AxibugEmuOnline.Server.sln
Normal file
31
AxibugEmuOnline.Server/AxibugEmuOnline.Server.sln
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
|
||||||
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
|
# Visual Studio Version 17
|
||||||
|
VisualStudioVersion = 17.8.34511.84
|
||||||
|
MinimumVisualStudioVersion = 10.0.40219.1
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AxibugEmuOnline.Server", "AxibugEmuOnline.Server\AxibugEmuOnline.Server.csproj", "{38E193D4-3BEC-42D0-9616-53D7AF3937FC}"
|
||||||
|
EndProject
|
||||||
|
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Lib", "Lib", "{F151804D-CF60-437E-ACE6-F1C04DCECBF8}"
|
||||||
|
ProjectSection(SolutionItems) = preProject
|
||||||
|
..\Lib\Google.Protobuf.dll = ..\Lib\Google.Protobuf.dll
|
||||||
|
..\Lib\HaoYueNet.ServerNetwork.dll = ..\Lib\HaoYueNet.ServerNetwork.dll
|
||||||
|
EndProjectSection
|
||||||
|
EndProject
|
||||||
|
Global
|
||||||
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug|Any CPU = Debug|Any CPU
|
||||||
|
Release|Any CPU = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{38E193D4-3BEC-42D0-9616-53D7AF3937FC}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{38E193D4-3BEC-42D0-9616-53D7AF3937FC}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{38E193D4-3BEC-42D0-9616-53D7AF3937FC}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{38E193D4-3BEC-42D0-9616-53D7AF3937FC}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
|
HideSolutionNode = FALSE
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||||
|
SolutionGuid = {705EF8E0-A868-4412-BC48-A7DD735C2DBD}
|
||||||
|
EndGlobalSection
|
||||||
|
EndGlobal
|
@ -111,7 +111,7 @@ namespace AxibugEmuOnline.Server.Event
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Error(e.Message);
|
AppSrv.g_Log.Error(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -130,7 +130,7 @@ namespace AxibugEmuOnline.Server.Event
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Error(e.Message);
|
AppSrv.g_Log.Error(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -149,7 +149,7 @@ namespace AxibugEmuOnline.Server.Event
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Error(e.Message);
|
AppSrv.g_Log.Error(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -168,7 +168,7 @@ namespace AxibugEmuOnline.Server.Event
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Error(e.Message + ", method name : " + callback.Method);
|
AppSrv.g_Log.Error(e.Message + ", method name : " + callback.Method);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -188,7 +188,7 @@ namespace AxibugEmuOnline.Server.Event
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Error(e.Message);
|
AppSrv.g_Log.Error(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,13 +5,14 @@ using System.Net;
|
|||||||
namespace AxibugEmuOnline.Server
|
namespace AxibugEmuOnline.Server
|
||||||
{
|
{
|
||||||
|
|
||||||
public static class ServerManager
|
public static class AppSrv
|
||||||
{
|
{
|
||||||
public static ClientManager g_ClientMgr;
|
public static ClientManager g_ClientMgr;
|
||||||
public static LogManager g_Log;
|
public static LogManager g_Log;
|
||||||
public static LoginManager g_Login;
|
public static LoginManager g_Login;
|
||||||
public static ChatManager g_Chat;
|
public static ChatManager g_Chat;
|
||||||
public static IOCPNetWork g_SocketMgr;
|
public static IOCPNetWork g_SocketMgr;
|
||||||
|
public static RoomManager g_Room;
|
||||||
public static GameManager g_Game;
|
public static GameManager g_Game;
|
||||||
|
|
||||||
public static void InitServer(int port)
|
public static void InitServer(int port)
|
||||||
@ -23,6 +24,7 @@ namespace AxibugEmuOnline.Server
|
|||||||
g_Chat = new ChatManager();
|
g_Chat = new ChatManager();
|
||||||
//g_SocketMgr = new IOCPNetWork(1024, 1024);
|
//g_SocketMgr = new IOCPNetWork(1024, 1024);
|
||||||
g_SocketMgr = new IOCPNetWork(1024, 4096);
|
g_SocketMgr = new IOCPNetWork(1024, 4096);
|
||||||
|
g_Room = new RoomManager();
|
||||||
g_Game = new GameManager();
|
g_Game = new GameManager();
|
||||||
|
|
||||||
g_SocketMgr.Init();
|
g_SocketMgr.Init();
|
@ -14,8 +14,8 @@ namespace AxibugEmuOnline.Server.Manager
|
|||||||
|
|
||||||
public void RecvPlayerChatMsg(Socket sk, byte[] reqData)
|
public void RecvPlayerChatMsg(Socket sk, byte[] reqData)
|
||||||
{
|
{
|
||||||
ClientInfo _c = ServerManager.g_ClientMgr.GetClientForSocket(sk);
|
ClientInfo _c = AppSrv.g_ClientMgr.GetClientForSocket(sk);
|
||||||
ServerManager.g_Log.Debug("收到聊天消息请求");
|
AppSrv.g_Log.Debug("收到聊天消息请求");
|
||||||
Protobuf_ChatMsg msg = ProtoBufHelper.DeSerizlize<Protobuf_ChatMsg>(reqData);
|
Protobuf_ChatMsg msg = ProtoBufHelper.DeSerizlize<Protobuf_ChatMsg>(reqData);
|
||||||
byte[] respData = ProtoBufHelper.Serizlize(new Protobuf_ChatMsg_RESP()
|
byte[] respData = ProtoBufHelper.Serizlize(new Protobuf_ChatMsg_RESP()
|
||||||
{
|
{
|
||||||
@ -23,7 +23,7 @@ namespace AxibugEmuOnline.Server.Manager
|
|||||||
NickName = _c.Account,
|
NickName = _c.Account,
|
||||||
Date = Helper.GetNowTimeStamp()
|
Date = Helper.GetNowTimeStamp()
|
||||||
});
|
});
|
||||||
ServerManager.g_ClientMgr.ClientSendALL((int)CommandID.CmdChatmsg, (int)ErrorCode.ErrorOk, respData);
|
AppSrv.g_ClientMgr.ClientSendALL((int)CommandID.CmdChatmsg, (int)ErrorCode.ErrorOk, respData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -7,6 +7,7 @@ namespace AxibugEmuOnline.Server.Manager
|
|||||||
public class ClientInfo
|
public class ClientInfo
|
||||||
{
|
{
|
||||||
public long UID { get; set; }
|
public long UID { get; set; }
|
||||||
|
public string NickName { get; set; }
|
||||||
public string Account { get; set; }
|
public string Account { get; set; }
|
||||||
public Socket _socket { get; set; }
|
public Socket _socket { get; set; }
|
||||||
public bool IsOffline { get; set; } = false;
|
public bool IsOffline { get; set; } = false;
|
||||||
@ -131,7 +132,7 @@ namespace AxibugEmuOnline.Server.Manager
|
|||||||
/// 清理连接
|
/// 清理连接
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="client"></param>
|
/// <param name="client"></param>
|
||||||
public bool GetClientByUID(long uid,out ClientInfo client)
|
public bool GetClientByUID(long uid, out ClientInfo client, bool bNeedOnline = false)
|
||||||
{
|
{
|
||||||
lock (ClientList)
|
lock (ClientList)
|
||||||
{
|
{
|
||||||
@ -142,6 +143,10 @@ namespace AxibugEmuOnline.Server.Manager
|
|||||||
}
|
}
|
||||||
|
|
||||||
client = _DictUIDClient[uid];
|
client = _DictUIDClient[uid];
|
||||||
|
|
||||||
|
|
||||||
|
if (bNeedOnline && client.IsOffline)
|
||||||
|
return false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -209,14 +214,14 @@ namespace AxibugEmuOnline.Server.Manager
|
|||||||
if(SkipUID > -1 && _toclientlist[i].UID == SkipUID)
|
if(SkipUID > -1 && _toclientlist[i].UID == SkipUID)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
ServerManager.g_SocketMgr.SendToSocket(_toclientlist[i]._socket, CMDID, ERRCODE, data);
|
AppSrv.g_SocketMgr.SendToSocket(_toclientlist[i]._socket, CMDID, ERRCODE, data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ClientSend(Socket _socket, int CMDID, int ERRCODE, byte[] data)
|
public void ClientSend(Socket _socket, int CMDID, int ERRCODE, byte[] data)
|
||||||
{
|
{
|
||||||
//Console.WriteLine("发送数据 CMDID->"+ CMDID);
|
//Console.WriteLine("发送数据 CMDID->"+ CMDID);
|
||||||
ServerManager.g_SocketMgr.SendToSocket(_socket, CMDID, ERRCODE, data);
|
AppSrv.g_SocketMgr.SendToSocket(_socket, CMDID, ERRCODE, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -230,7 +235,7 @@ namespace AxibugEmuOnline.Server.Manager
|
|||||||
{
|
{
|
||||||
if (_c == null || _c.IsOffline)
|
if (_c == null || _c.IsOffline)
|
||||||
return;
|
return;
|
||||||
ServerManager.g_SocketMgr.SendToSocket(_c._socket, CMDID, ERRCODE, data);
|
AppSrv.g_SocketMgr.SendToSocket(_c._socket, CMDID, ERRCODE, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int GetOnlineClient()
|
public int GetOnlineClient()
|
||||||
|
@ -17,10 +17,21 @@ namespace AxibugEmuOnline.Server
|
|||||||
|
|
||||||
public void OnCmdScreen(Socket sk, byte[] reqData)
|
public void OnCmdScreen(Socket sk, byte[] reqData)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Debug($"OnCmdScreen lenght:{reqData.Length}");
|
AppSrv.g_Log.Debug($"OnCmdScreen lenght:{reqData.Length}");
|
||||||
ClientInfo _c = ServerManager.g_ClientMgr.GetClientForSocket(sk);
|
ClientInfo _c = AppSrv.g_ClientMgr.GetClientForSocket(sk);
|
||||||
Protobuf_Screnn_Frame msg = ProtoBufHelper.DeSerizlize<Protobuf_Screnn_Frame>(reqData);
|
Protobuf_Screnn_Frame msg = ProtoBufHelper.DeSerizlize<Protobuf_Screnn_Frame>(reqData);
|
||||||
ServerManager.g_ClientMgr.ClientSendALL((int)CommandID.CmdScreen, (int)ErrorCode.ErrorOk, reqData, _c.UID);
|
|
||||||
|
Data_RoomData room = AppSrv.g_Room.GetRoomData(msg.RoomID);
|
||||||
|
|
||||||
|
if (room == null)
|
||||||
|
{
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c,(int)CommandID.CmdScreen, (int)ErrorCode.ErrorRoomNotFound, new byte[1]);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
List<ClientInfo> userlist = room.GetAllPlayerClientList();
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(userlist, (int)CommandID.CmdScreen, (int)ErrorCode.ErrorOk, reqData, _c.UID);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -14,9 +14,9 @@ namespace AxibugEmuOnline.Server.Manager
|
|||||||
|
|
||||||
public void UserLogin(Socket _socket, byte[] reqData)
|
public void UserLogin(Socket _socket, byte[] reqData)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Debug("收到新的登录请求");
|
AppSrv.g_Log.Debug("收到新的登录请求");
|
||||||
Protobuf_Login msg = ProtoBufHelper.DeSerizlize<Protobuf_Login>(reqData);
|
Protobuf_Login msg = ProtoBufHelper.DeSerizlize<Protobuf_Login>(reqData);
|
||||||
ClientInfo cinfo = ServerManager.g_ClientMgr.JoinNewClient(msg, _socket);
|
ClientInfo cinfo = AppSrv.g_ClientMgr.JoinNewClient(msg, _socket);
|
||||||
|
|
||||||
byte[] respData = ProtoBufHelper.Serizlize(new Protobuf_Login_RESP()
|
byte[] respData = ProtoBufHelper.Serizlize(new Protobuf_Login_RESP()
|
||||||
{
|
{
|
||||||
|
@ -0,0 +1,370 @@
|
|||||||
|
using AxibugEmuOnline.Server.Common;
|
||||||
|
using AxibugEmuOnline.Server.Manager;
|
||||||
|
using AxibugEmuOnline.Server.NetWork;
|
||||||
|
using AxibugProtobuf;
|
||||||
|
using System.Net;
|
||||||
|
using System.Net.Sockets;
|
||||||
|
using static System.Runtime.InteropServices.JavaScript.JSType;
|
||||||
|
|
||||||
|
namespace AxibugEmuOnline.Server
|
||||||
|
{
|
||||||
|
|
||||||
|
public class RoomManager
|
||||||
|
{
|
||||||
|
Dictionary<int, Data_RoomData> mDictRoom = new Dictionary<int, Data_RoomData>();
|
||||||
|
int RoomIDSeed = 1;
|
||||||
|
public RoomManager()
|
||||||
|
{
|
||||||
|
NetMsg.Instance.RegNetMsgEvent((int)CommandID.CmdRoomList, OnCmdRoomList);
|
||||||
|
|
||||||
|
NetMsg.Instance.RegNetMsgEvent((int)CommandID.CmdRoomCreate, OnCmdRoomCreate);
|
||||||
|
NetMsg.Instance.RegNetMsgEvent((int)CommandID.CmdRoomJoin, OnCmdRoomJoin);
|
||||||
|
NetMsg.Instance.RegNetMsgEvent((int)CommandID.CmdRoomLeave, OnCmdRoomLeave);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region 房间管理
|
||||||
|
|
||||||
|
int GetNewRoomID()
|
||||||
|
{
|
||||||
|
return RoomIDSeed++;
|
||||||
|
}
|
||||||
|
|
||||||
|
void AddRoom(Data_RoomData data)
|
||||||
|
{
|
||||||
|
lock (mDictRoom)
|
||||||
|
{
|
||||||
|
if (!mDictRoom.ContainsKey(data.RoomID))
|
||||||
|
{
|
||||||
|
mDictRoom.Add(data.RoomID, data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void RemoveRoom(int RoomID)
|
||||||
|
{
|
||||||
|
lock(mDictRoom)
|
||||||
|
{
|
||||||
|
if (mDictRoom.ContainsKey(RoomID))
|
||||||
|
{
|
||||||
|
mDictRoom.Remove(RoomID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Data_RoomData GetRoomData(int RoomID)
|
||||||
|
{
|
||||||
|
if (!mDictRoom.ContainsKey(RoomID))
|
||||||
|
return null;
|
||||||
|
|
||||||
|
return mDictRoom[RoomID];
|
||||||
|
}
|
||||||
|
|
||||||
|
List<Data_RoomData> GetRoomList()
|
||||||
|
{
|
||||||
|
lock (mDictRoom)
|
||||||
|
{
|
||||||
|
List<Data_RoomData> temp = new List<Data_RoomData>();
|
||||||
|
foreach (var room in mDictRoom)
|
||||||
|
{
|
||||||
|
temp.AddRange(mDictRoom.Values);
|
||||||
|
}
|
||||||
|
return temp;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
private Protobuf_Room_MiniInfo GetProtoDataRoom(Data_RoomData room)
|
||||||
|
{
|
||||||
|
Protobuf_Room_MiniInfo result = new Protobuf_Room_MiniInfo()
|
||||||
|
{
|
||||||
|
GameRomID = room.GameRomID,
|
||||||
|
RoomID = room.RoomID,
|
||||||
|
GameRomHash = room.RomHash,
|
||||||
|
GameState = room.GameState,
|
||||||
|
PlayerState = room.PlayerState,
|
||||||
|
ObsUserCount = 0,//TODO
|
||||||
|
Player1UID = room.Player1_UID,
|
||||||
|
Player2UID = room.Player2_UID,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (result.Player1UID >= 0 && AppSrv.g_ClientMgr.GetClientByUID(result.Player1UID, out ClientInfo _c1))
|
||||||
|
result.Player1NickName = _c1.NickName;
|
||||||
|
|
||||||
|
if (result.Player2UID >= 0 && AppSrv.g_ClientMgr.GetClientByUID(result.Player2UID, out ClientInfo _c2))
|
||||||
|
result.Player2NickName = _c2.NickName;
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnCmdRoomList(Socket sk, byte[] reqData)
|
||||||
|
{
|
||||||
|
AppSrv.g_Log.Debug($"OnCmdRoomList ");
|
||||||
|
ClientInfo _c = AppSrv.g_ClientMgr.GetClientForSocket(sk);
|
||||||
|
Protobuf_Room_List msg = ProtoBufHelper.DeSerizlize<Protobuf_Room_List>(reqData);
|
||||||
|
|
||||||
|
Protobuf_Room_List_RESP resp = new Protobuf_Room_List_RESP();
|
||||||
|
List<Data_RoomData> temp = GetRoomList();
|
||||||
|
foreach (var room in temp)
|
||||||
|
resp.RoomMiniInfoList.Add(GetProtoDataRoom(room));
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c, (int)CommandID.CmdChatmsg, (int)ErrorCode.ErrorOk, ProtoBufHelper.Serizlize(resp));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
///
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="RoomID"></param>
|
||||||
|
/// <param name="type">//[0] 更新或新增 [1] 删除</param>
|
||||||
|
public void SendRoomUpdateToAll(int RoomID,int type)
|
||||||
|
{
|
||||||
|
Data_RoomData room = GetRoomData(RoomID);
|
||||||
|
if (room == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Protobuf_Room_Update_RESP resp = new Protobuf_Room_Update_RESP()
|
||||||
|
{
|
||||||
|
UpdateType = type,
|
||||||
|
RoomMiniInfo = GetProtoDataRoom(room)
|
||||||
|
};
|
||||||
|
|
||||||
|
AppSrv.g_ClientMgr.ClientSendALL((int)CommandID.CmdRoomListUpdate, (int)ErrorCode.ErrorOk, ProtoBufHelper.Serizlize(resp));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnCmdRoomCreate(Socket sk, byte[] reqData)
|
||||||
|
{
|
||||||
|
AppSrv.g_Log.Debug($"OnCmdRoomCreate ");
|
||||||
|
ClientInfo _c = AppSrv.g_ClientMgr.GetClientForSocket(sk);
|
||||||
|
Protobuf_Room_Create msg = ProtoBufHelper.DeSerizlize<Protobuf_Room_Create>(reqData);
|
||||||
|
|
||||||
|
Data_RoomData newRoom = new Data_RoomData();
|
||||||
|
newRoom.Init(GetNewRoomID(), msg.GameRomID,msg.GameRomHash);
|
||||||
|
AddRoom(newRoom);
|
||||||
|
|
||||||
|
|
||||||
|
//加入
|
||||||
|
if (!Join(newRoom.GameRomID, 0, _c, out ErrorCode joinErrcode))
|
||||||
|
{
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c, (int)CommandID.CmdRoomCreate, (int)joinErrcode, new byte[1]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//创建成功下行
|
||||||
|
Protobuf_Room_Create_RESP resp = new Protobuf_Room_Create_RESP()
|
||||||
|
{
|
||||||
|
RoomMiniInfo = GetProtoDataRoom(newRoom)
|
||||||
|
};
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c, (int)CommandID.CmdRoomCreate, (int)ErrorCode.ErrorOk, ProtoBufHelper.Serizlize(resp));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnCmdRoomJoin(Socket sk, byte[] reqData)
|
||||||
|
{
|
||||||
|
AppSrv.g_Log.Debug($"OnCmdRoomJoin ");
|
||||||
|
ClientInfo _c = AppSrv.g_ClientMgr.GetClientForSocket(sk);
|
||||||
|
Protobuf_Room_Join msg = ProtoBufHelper.DeSerizlize<Protobuf_Room_Join>(reqData);
|
||||||
|
|
||||||
|
//加入
|
||||||
|
if (!Join(msg.RoomID, msg.PlayerNum, _c, out ErrorCode joinErrcode))
|
||||||
|
{
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c, (int)CommandID.CmdRoomJoin, (int)joinErrcode, new byte[1]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Data_RoomData roomData = GetRoomData(msg.RoomID);
|
||||||
|
|
||||||
|
//创建成功下行
|
||||||
|
Protobuf_Room_Join_RESP resp = new Protobuf_Room_Join_RESP()
|
||||||
|
{
|
||||||
|
RoomMiniInfo = GetProtoDataRoom(roomData)
|
||||||
|
};
|
||||||
|
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c, (int)CommandID.CmdRoomJoin, (int)ErrorCode.ErrorOk, ProtoBufHelper.Serizlize(resp));
|
||||||
|
Protobuf_Room_MyRoom_State_Change(msg.RoomID);
|
||||||
|
}
|
||||||
|
public void OnCmdRoomLeave(Socket sk, byte[] reqData)
|
||||||
|
{
|
||||||
|
AppSrv.g_Log.Debug($"OnCmdRoomJoin ");
|
||||||
|
ClientInfo _c = AppSrv.g_ClientMgr.GetClientForSocket(sk);
|
||||||
|
Protobuf_Room_Leave msg = ProtoBufHelper.DeSerizlize<Protobuf_Room_Leave>(reqData);
|
||||||
|
|
||||||
|
//加入
|
||||||
|
if (!Leave(msg.RoomID, _c, out ErrorCode joinErrcode))
|
||||||
|
{
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c, (int)CommandID.CmdRoomLeave, (int)joinErrcode, new byte[1]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//创建成功下行
|
||||||
|
Protobuf_Room_Leave_RESP resp = new Protobuf_Room_Leave_RESP()
|
||||||
|
{
|
||||||
|
RoomID = msg.RoomID,
|
||||||
|
};
|
||||||
|
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c, (int)CommandID.CmdRoomLeave, (int)ErrorCode.ErrorOk, ProtoBufHelper.Serizlize(resp));
|
||||||
|
Protobuf_Room_MyRoom_State_Change(msg.RoomID);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 广播房间状态变化
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="RoomID"></param>
|
||||||
|
public void Protobuf_Room_MyRoom_State_Change(int RoomID)
|
||||||
|
{
|
||||||
|
Data_RoomData room = GetRoomData(RoomID);
|
||||||
|
if (room == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Protobuf_Room_MyRoom_State_Change resp = new Protobuf_Room_MyRoom_State_Change()
|
||||||
|
{
|
||||||
|
RoomMiniInfo = GetProtoDataRoom(room)
|
||||||
|
};
|
||||||
|
|
||||||
|
List<ClientInfo> userlist = room.GetAllPlayerClientList();
|
||||||
|
|
||||||
|
foreach(ClientInfo _c in userlist)
|
||||||
|
{
|
||||||
|
AppSrv.g_ClientMgr.ClientSend(_c,(int)CommandID.CmdRoomMyRoomStateChanged, (int)ErrorCode.ErrorOk, ProtoBufHelper.Serizlize(resp));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#region 房间内逻辑
|
||||||
|
/// <summary>
|
||||||
|
/// 进入房间
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="RoomID"></param>
|
||||||
|
/// <param name="PlayerNum"></param>
|
||||||
|
/// <param name="_c"></param>
|
||||||
|
/// <param name="errcode"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
bool Join(int RoomID,int PlayerNum,ClientInfo _c,out ErrorCode errcode)
|
||||||
|
{
|
||||||
|
Data_RoomData room = GetRoomData(RoomID);
|
||||||
|
if (room == null)
|
||||||
|
{
|
||||||
|
errcode = ErrorCode.ErrorRoomNotFound;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
//玩家1
|
||||||
|
if (PlayerNum == 0)
|
||||||
|
{
|
||||||
|
if (room.PlayerState != RoomPlayerState.NonePlayerState)
|
||||||
|
{
|
||||||
|
errcode = ErrorCode.ErrorRoomSlotReadlyHadPlayer;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
room.Player1_UID = _c.UID;
|
||||||
|
}
|
||||||
|
//其他玩家
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (room.PlayerState != RoomPlayerState.OnlyP1)
|
||||||
|
{
|
||||||
|
errcode = ErrorCode.ErrorRoomSlotReadlyHadPlayer;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
room.Player2_UID = _c.UID;
|
||||||
|
}
|
||||||
|
|
||||||
|
//广播房间
|
||||||
|
SendRoomUpdateToAll(RoomID, 0);
|
||||||
|
errcode = ErrorCode.ErrorOk;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 离开房间
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="RoomID"></param>
|
||||||
|
/// <param name="_c"></param>
|
||||||
|
/// <param name="errcode"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
bool Leave(int RoomID, ClientInfo _c, out ErrorCode errcode)
|
||||||
|
{
|
||||||
|
Data_RoomData room = GetRoomData(RoomID);
|
||||||
|
if (room == null)
|
||||||
|
{
|
||||||
|
errcode = ErrorCode.ErrorRoomNotFound;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (room.Player1_UID == _c.UID)
|
||||||
|
room.Player1_UID = -1;
|
||||||
|
if (room.Player2_UID == _c.UID)
|
||||||
|
room.Player2_UID = -1;
|
||||||
|
|
||||||
|
if (room.PlayerState == RoomPlayerState.NonePlayerState)
|
||||||
|
{
|
||||||
|
SendRoomUpdateToAll(RoomID, 1);
|
||||||
|
RemoveRoom(RoomID);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//广播房间变化
|
||||||
|
SendRoomUpdateToAll(RoomID, 0);
|
||||||
|
}
|
||||||
|
errcode = ErrorCode.ErrorOk;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
|
||||||
|
public class Data_RoomData
|
||||||
|
{
|
||||||
|
public int RoomID;
|
||||||
|
public int GameRomID;
|
||||||
|
public string RomHash;
|
||||||
|
public long Player1_UID;
|
||||||
|
public long Player2_UID;
|
||||||
|
public RoomPlayerState PlayerState => getPlayerState();
|
||||||
|
public RoomGameState GameState;
|
||||||
|
|
||||||
|
public void Init(int roomID,int gameRomID,string roomHash)
|
||||||
|
{
|
||||||
|
RoomID = roomID;
|
||||||
|
GameRomID = gameRomID;
|
||||||
|
RomHash = roomHash;
|
||||||
|
Player1_UID = -1;
|
||||||
|
Player2_UID = -1;
|
||||||
|
GameState = RoomGameState.NoneGameState;
|
||||||
|
}
|
||||||
|
|
||||||
|
RoomPlayerState getPlayerState()
|
||||||
|
{
|
||||||
|
if (Player1_UID < 0 && Player2_UID < 0)
|
||||||
|
return RoomPlayerState.NonePlayerState;
|
||||||
|
|
||||||
|
if (Player1_UID < 0)
|
||||||
|
return RoomPlayerState.OnlyP2;
|
||||||
|
|
||||||
|
if (Player2_UID < 0)
|
||||||
|
return RoomPlayerState.OnlyP1;
|
||||||
|
|
||||||
|
return RoomPlayerState.BothOnline;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<long> GetAllPlayerUIDs()
|
||||||
|
{
|
||||||
|
List<long> list = new List<long>();
|
||||||
|
if (Player1_UID > 0) list.Add(Player1_UID);
|
||||||
|
if (Player2_UID > 0) list.Add(Player2_UID);
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<ClientInfo> GetAllPlayerClientList()
|
||||||
|
{
|
||||||
|
List<ClientInfo> list = new List<ClientInfo>();
|
||||||
|
|
||||||
|
List<long> Uids = GetAllPlayerUIDs();
|
||||||
|
|
||||||
|
foreach (long uid in Uids)
|
||||||
|
{
|
||||||
|
if (!AppSrv.g_ClientMgr.GetClientByUID(uid, out ClientInfo _c,true))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
list.Add(_c);
|
||||||
|
}
|
||||||
|
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -32,7 +32,7 @@ namespace AxibugEmuOnline.Server.NetWork
|
|||||||
|
|
||||||
public void DataCallBack(Socket sk, int CMDID, byte[] data)
|
public void DataCallBack(Socket sk, int CMDID, byte[] data)
|
||||||
{
|
{
|
||||||
//ServerManager.g_Log.Debug("收到消息 CMDID =>" + CMDID + " 数据长度=>" + data.Length);
|
//AppSrv.g_Log.Debug("收到消息 CMDID =>" + CMDID + " 数据长度=>" + data.Length);
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
//抛出网络数据
|
//抛出网络数据
|
||||||
@ -51,12 +51,12 @@ namespace AxibugEmuOnline.Server.NetWork
|
|||||||
public void OnDisconnect(AsyncUserToken token)
|
public void OnDisconnect(AsyncUserToken token)
|
||||||
{
|
{
|
||||||
Console.WriteLine("断开连接");
|
Console.WriteLine("断开连接");
|
||||||
ServerManager.g_ClientMgr.SetClientOfflineForSocket(token.Socket);
|
AppSrv.g_ClientMgr.SetClientOfflineForSocket(token.Socket);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void OnShowNetLog(string msg)
|
public void OnShowNetLog(string msg)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Debug(msg);
|
AppSrv.g_Log.Debug(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -68,7 +68,7 @@ namespace AxibugEmuOnline.Server.NetWork
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
ServerManager.g_Log.Error(e.Message);
|
AppSrv.g_Log.Error(e.Message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
{
|
{
|
||||||
Console.ForegroundColor = ConsoleColor.Green;
|
Console.ForegroundColor = ConsoleColor.Green;
|
||||||
Console.Title = Title;
|
Console.Title = Title;
|
||||||
ServerManager.InitServer(10492);
|
AppSrv.InitServer(10492);
|
||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
Console.ReadLine();
|
Console.ReadLine();
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -12,5 +12,5 @@ for /f "delims=" %%i in ('dir /b proto "proto/*.proto"') do (
|
|||||||
echo "==>>build finish"
|
echo "==>>build finish"
|
||||||
echo "==>>copy cs"
|
echo "==>>copy cs"
|
||||||
|
|
||||||
::copy %cd%\out\CS\ ..\AxibugEmuOnline.Server\AxibugEmuOnline.Server\Protobuf
|
copy %cd%\out\CS\ ..\AxibugEmuOnline.Server\AxibugEmuOnline.Server\Protobuf
|
||||||
pause
|
pause
|
File diff suppressed because it is too large
Load Diff
@ -10,18 +10,21 @@ enum CommandID
|
|||||||
|
|
||||||
CMD_CHATMSG = 4001; //广播聊天信息上行 | 下行 对应 Protobuf_ChatMsg | Protobuf_ChatMsg_RESP
|
CMD_CHATMSG = 4001; //广播聊天信息上行 | 下行 对应 Protobuf_ChatMsg | Protobuf_ChatMsg_RESP
|
||||||
|
|
||||||
//房间相关
|
//房间列表相关
|
||||||
CMD_Room_List = 5001; //房间列表 上行 | 下行 对应 Protobuf_Room_List | Protobuf_Room_List_RESP
|
CMD_Room_List = 5001; //房间列表 上行 | 下行 对应 Protobuf_Room_List | Protobuf_Room_List_RESP
|
||||||
|
|
||||||
CMD_Room_List_Update = 5002; //房间列表更新 对应 Protobuf_Room_Update_RESP
|
CMD_Room_List_Update = 5002; //房间单个房间信息更新 对应 Protobuf_Room_Update_RESP
|
||||||
|
|
||||||
CMD_Room_Create = 5003; //房间列表创建 对应 Protobuf_Room_Create
|
//房间内相关
|
||||||
|
CMD_Room_Create = 5101; //房间列表创建 对应 Protobuf_Room_Create | Protobuf_Room_Create_RESP
|
||||||
|
|
||||||
CMD_Room_Leave = 5004; //房间列表离开 对应 Protobuf_Room_Leave
|
CMD_Room_Join = 5105; //房间列表加入 对应 Protobuf_Room_Join | Protobuf_Room_Join_RESP
|
||||||
|
|
||||||
CMD_Room_Join = 5005; //房间列表加入 对应 Protobuf_Room_Join
|
CMD_Room_Leave = 5106; //房间列表离开 对应 Protobuf_Room_Leave | Protobuf_Room_Leave_RESP
|
||||||
|
|
||||||
//画面同步相关
|
CMD_Room_MyRoom_State_Changed = 5110; //我所在的房间内状态发生变化 对应 Protobuf_Room_MyRoom_State_Change;
|
||||||
|
|
||||||
|
//游戏同步
|
||||||
CMD_Screen = 6001; //画面同步 | 同步广播 对应 Protobuf_Screnn_Frame
|
CMD_Screen = 6001; //画面同步 | 同步广播 对应 Protobuf_Screnn_Frame
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29,6 +32,9 @@ enum ErrorCode
|
|||||||
{
|
{
|
||||||
ERROR_DEFAUL = 0;//缺省不使用
|
ERROR_DEFAUL = 0;//缺省不使用
|
||||||
ERROR_OK = 1; //成功
|
ERROR_OK = 1; //成功
|
||||||
|
|
||||||
|
ERROR_ROOM_NOT_FOUND = 10;//房间不存在
|
||||||
|
ERROR_ROOM_SLOT_READLY_HAD_PLAYER=11;//加入目标位置已经有人
|
||||||
}
|
}
|
||||||
|
|
||||||
enum LoginType
|
enum LoginType
|
||||||
@ -47,7 +53,7 @@ enum DeviceType
|
|||||||
|
|
||||||
enum RoomPlayerState
|
enum RoomPlayerState
|
||||||
{
|
{
|
||||||
None = 0;//缺省
|
None_PlayerState = 0;//缺省
|
||||||
OnlyP1 = 1; //仅P1
|
OnlyP1 = 1; //仅P1
|
||||||
OnlyP2 = 2; //仅P2
|
OnlyP2 = 2; //仅P2
|
||||||
BothOnline = 3; //玩家都在
|
BothOnline = 3; //玩家都在
|
||||||
@ -55,7 +61,7 @@ enum RoomPlayerState
|
|||||||
|
|
||||||
enum RoomGameState
|
enum RoomGameState
|
||||||
{
|
{
|
||||||
None = 0;//缺省
|
None_GameState = 0;//缺省
|
||||||
InGame = 1;//游戏中
|
InGame = 1;//游戏中
|
||||||
Pause = 2;//暂停
|
Pause = 2;//暂停
|
||||||
}
|
}
|
||||||
@ -116,19 +122,21 @@ message Protobuf_Room_List_RESP
|
|||||||
message Protobuf_Room_MiniInfo
|
message Protobuf_Room_MiniInfo
|
||||||
{
|
{
|
||||||
int32 RoomID = 1;//房间ID
|
int32 RoomID = 1;//房间ID
|
||||||
int32 GameID = 2;//游戏ID
|
int32 GameRomID = 2;//游戏ID
|
||||||
RoomPlayerState PlayerState = 3;//玩家加入状态
|
string GameRomHash = 3;
|
||||||
RoomGameState GameState = 4;//游戏状态
|
RoomPlayerState PlayerState = 4;//玩家加入状态
|
||||||
int32 ObsUserCount = 5;//观战用户数量
|
RoomGameState GameState = 5;//游戏状态
|
||||||
int64 Player1_UID = 6;//玩家1 UID
|
int32 ObsUserCount = 6;//观战用户数量
|
||||||
string Player1_NickName = 7;//玩家1 昵称
|
int64 Player1_UID = 7;//玩家1 UID
|
||||||
int64 Player2_UID = 8;//玩家2 UID
|
string Player1_NickName = 8;//玩家1 昵称
|
||||||
string Player2_NickName = 9;//玩家2 昵称
|
int64 Player2_UID = 9;//玩家2 UID
|
||||||
|
string Player2_NickName = 10;//玩家2 昵称
|
||||||
}
|
}
|
||||||
|
|
||||||
message Protobuf_Room_Update_RESP
|
message Protobuf_Room_Update_RESP
|
||||||
{
|
{
|
||||||
Protobuf_Room_MiniInfo RoomMiniInfo = 1;//房间信息
|
int32 UpdateType = 1;//[0] 更新或新增 [1] 删除
|
||||||
|
Protobuf_Room_MiniInfo RoomMiniInfo = 2;//房间信息
|
||||||
}
|
}
|
||||||
|
|
||||||
message Protobuf_Screnn_Frame
|
message Protobuf_Screnn_Frame
|
||||||
@ -137,3 +145,40 @@ message Protobuf_Screnn_Frame
|
|||||||
int32 FrameID = 2;//帧编号
|
int32 FrameID = 2;//帧编号
|
||||||
bytes RawBitmap = 3;//渲染层画面
|
bytes RawBitmap = 3;//渲染层画面
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message Protobuf_Room_Create
|
||||||
|
{
|
||||||
|
int32 GameRomID = 1;
|
||||||
|
string GameRomHash = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message Protobuf_Room_Create_RESP
|
||||||
|
{
|
||||||
|
Protobuf_Room_MiniInfo RoomMiniInfo = 1;//房间信息
|
||||||
|
}
|
||||||
|
|
||||||
|
message Protobuf_Room_Join
|
||||||
|
{
|
||||||
|
int32 RoomID = 1;//房间ID
|
||||||
|
int32 PlayerNum = 2;//玩家编号 [0]1号玩家 [1]2号玩家
|
||||||
|
}
|
||||||
|
|
||||||
|
message Protobuf_Room_Join_RESP
|
||||||
|
{
|
||||||
|
Protobuf_Room_MiniInfo RoomMiniInfo = 1;//房间信息
|
||||||
|
}
|
||||||
|
|
||||||
|
message Protobuf_Room_Leave
|
||||||
|
{
|
||||||
|
int32 RoomID = 1;//离开的房间ID
|
||||||
|
}
|
||||||
|
|
||||||
|
message Protobuf_Room_Leave_RESP
|
||||||
|
{
|
||||||
|
int32 RoomID = 1;//离开的房间ID
|
||||||
|
}
|
||||||
|
|
||||||
|
message Protobuf_Room_MyRoom_State_Change
|
||||||
|
{
|
||||||
|
Protobuf_Room_MiniInfo RoomMiniInfo = 1;//更新房间信息
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user