public void InitBaseMessage(OdaoClient client) { _gsProxy = client; var playerInfo = UIOperation.playerLobbyInfo; _gsProxy.on(BaseMessage.LOGIN_REQ_MSG, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; //BaseMessage.LoginResDef data = XConvert.ConvertToObject<BaseMessage.LoginResDef>(msg.data); var serializer = MsgPack.Serialization.MessagePackSerializer.Get <BaseMessage.LoginResDef>(); var data = serializer.UnpackSingleObject(msg.data); Debug.LogError("LOGIN_RES_MSG: " + BaseMessage.LOGIN_REQ_MSG + ",cErrorCode:" + data.cErrorCode + ", iUserID:" + data.iUserID + ",accountId:" + data.accountId + ",serviceId:" + data.serviceId + ",szPasswdToken:" + data.szPasswdToken + ",cGender:" + data.cGender + ",cVipLv:" + data.cVipLv + ",llGameCoin:" + data.llGameCoin + ",llBankCoin:" + data.llBankCoin + ",llDiamondNum:" + data.llDiamondNum + ",llGoldBean:" + data.llGoldBean + ",szNickName:" + data.szNickName + ",szWXIconURL:" + data.szWXIconURL + ",szWXNickName:" + data.szWXNickName + ",iVipExp:" + data.iVipExp + ",cLevel:" + data.cLevel + ",iLevelExp:" + data.iLevelExp); playerInfo.iUserID = data.iUserID; playerInfo.accountId = data.accountId; playerInfo.serviceId = data.serviceId; playerInfo.szPasswdToken = data.szPasswdToken; playerInfo.cGender = data.cGender; playerInfo.cVipLv = data.cVipLv; playerInfo.llGameCoin = data.llGameCoin; playerInfo.llBankCoin = data.llBankCoin; playerInfo.llDiamondNum = data.llDiamondNum; playerInfo.llGoldBean = data.llGoldBean; playerInfo.szNickName = data.szNickName; playerInfo.szWXIconURL = data.szWXIconURL; playerInfo.szWXNickName = data.szWXNickName; playerInfo.iVipExp = data.iVipExp; playerInfo.cLevel = data.cLevel; playerInfo.iLevelExp = data.iLevelExp; #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { //GameLoading.SwitchScene(2); UnityEngine.SceneManagement.SceneManager.LoadScene(2); }); if (data.cErrorCode == 0) { var gameClient = GameClient.Instance; gameClient.MahjongGamePlayer.ConnectGameServer(UIOperation.ipRes, 36665, delegate() { gameClient.MahjongGamePlayer.LobbyLoginReqDef(data.iUserID, data.szPasswdToken); }); } #endif }); _gsProxy.on(BaseMessage.LOBBY_LOGIN_RES_MSG, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; //BaseMessage.LoginResDef data = XConvert.ConvertToObject<BaseMessage.LoginResDef>(msg.data); var serializer = MsgPack.Serialization.MessagePackSerializer.Get <BaseMessage.LobbyLoginResDef>(); var data = serializer.UnpackSingleObject(msg.data); Debug.LogError("LOBBY_LOGIN_RES_MSG: " + BaseMessage.LOBBY_LOGIN_RES_MSG + ", cErrorCode:" + data.cErrorCode + ",iUserID:" + data.iUserID); #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { //GameLoading.SwitchScene(2); //UnityEngine.SceneManagement.SceneManager.LoadScene(2); }); #endif }); _gsProxy.on(BaseMessage.LOBBY_SHOP_EXCHANGE_COIN_RES_MSG, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; //BaseMessage.LoginResDef data = XConvert.ConvertToObject<BaseMessage.LoginResDef>(msg.data); var serializer = MsgPack.Serialization.MessagePackSerializer.Get <BaseMessage.BuyGoldResDef>(); var data = serializer.UnpackSingleObject(msg.data); Debug.LogError("LOBBY_SHOP_EXCHANGE_COIN_RES_MSG: " + BaseMessage.LOBBY_SHOP_EXCHANGE_COIN_RES_MSG + ", cErrorCode:" + data.cErrorCode + ",iAddCoin:" + data.iAddCoin + ",iSubIDiamond:" + data.iSubIDiamond); if (data.cErrorCode == 0) { playerInfo.llGameCoin += data.iAddCoin; playerInfo.llDiamondNum -= data.iSubIDiamond; } else if (data.cErrorCode == 1) { //钻石不足 } else { //配置错误 } }); _gsProxy.on(BaseMessage.LOBBY_MODIFY_NICK_NAME_RES_MSG, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; //BaseMessage.LoginResDef data = XConvert.ConvertToObject<BaseMessage.LoginResDef>(msg.data); var serializer = MsgPack.Serialization.MessagePackSerializer.Get <BaseMessage.ChangeNameResDef>(); var data = serializer.UnpackSingleObject(msg.data); Debug.LogError("LOBBY_MODIFY_NICK_NAME_RES_MSG: " + BaseMessage.LOBBY_MODIFY_NICK_NAME_RES_MSG + ", cErrorCode:" + data.cErrorCode + ",iSubDiamond:" + data.iSubDiamond + ",szNickName:" + data.szNickName); if (data.cErrorCode == 0) { playerInfo.szNickName = data.szNickName; playerInfo.llDiamondNum -= data.iSubDiamond; //GameObject.Find("Canvas/personalInfoPanel/comfirmPanel").SetActive(false); } else if (data.cErrorCode == 1) { //钻石不足 } else { //配置错误 } }); _gsProxy.on(BaseMessage.LOBBY_MODIFY_GENDER_RES_MSG, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; //BaseMessage.LoginResDef data = XConvert.ConvertToObject<BaseMessage.LoginResDef>(msg.data); var serializer = MsgPack.Serialization.MessagePackSerializer.Get <BaseMessage.ChangeGenderResDef>(); var data = serializer.UnpackSingleObject(msg.data); Debug.LogError("LOBBY_MODIFY_GENDER_RES_MSG: " + BaseMessage.LOBBY_MODIFY_GENDER_RES_MSG + ", cErrorCode:" + data.cErrorCode + ",cGender:" + data.cGender); if (data.cErrorCode == 0) { playerInfo.cGender = data.cGender; Loom.QueueOnMainThread(delegate() { PlayerDataManager.Instance.LoadGenderImage(); }); } else if (data.cErrorCode == 1) { //钻石不足 } else { //配置错误 } }); _gsProxy.on(BaseMessage.AUTHEN_RES_MSG, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; BaseMessage.AuthenResDef data = XConvert.ConvertToObject <BaseMessage.AuthenResDef> (msg.data); Debug.Log("AUTHEN_RES_MSG " + data.cError + "," + data.iPlayerServerID + "," + data.iPlayerGameID); #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { GameLoading.SwitchScene(2); }); #endif }); _gsProxy.on(BaseMessage.AGAIN_LOGIN_RES_MSG, delegate(Message obj) { Debug.Log("AGAIN_LOGIN_RES_MSG "); OdaoMessage msg = (OdaoMessage)obj; int offset = 0; BaseMessage.AgainLoginRes data = XConvert.ConvertToObject <BaseMessage.AgainLoginRes> (msg.data, ref offset); Debug.Log("AGAIN_LOGIN_RES_MSG " + data.iUserID + "," + data.iServerTime + "," + data.iTableNum + "," + data.usTableNumExtra + "," + data.cPlayerNum); //userinfo for (int i = 0; i < data.cPlayerNum; ++i) { BaseMessage.PlayerInfoExtra userInfo = XConvert.ConvertToObject <BaseMessage.PlayerInfoExtra> (msg.data, ref offset); //byte[] bytes = System.Text.Encoding.GetEncoding("GBK").GetBytes(userInfo.szUserName); //string name = System.Text.Encoding.UTF8.GetString(bytes); } int tempHandCardLen = 0; #if USER_MP byte[] dataMP = msg.data.Skip(offset).ToArray(); /* * System.IO.FileStream fsForWrite = new System.IO.FileStream("MP.GameMessage.GameStateDef.bytes", System.IO.FileMode.Create); * try * { * fsForWrite.Write(dataMP,0,dataMP.Length); * } * catch(Exception ex) * { * Debug.Log(ex.ToString()); * } * finally * { * fsForWrite.Close(); * } */ var serializer = MsgPack.Serialization.MessagePackSerializer.Get <MP.GameMessage.GameStateDef>(); GameMessage.GameStateDef info = serializer.UnpackSingleObject(dataMP); tempHandCardLen = info.cHandCards.Count; #else GameMessage.GameStateDef info = XConvert.ConvertToObject <GameMessage.GameStateDef>(msg.data, ref offset); tempHandCardLen = info.cHandCards.Length; #endif #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN GameClient.Instance.GameStateDef = info; #endif PocketList.Clear(); // total 14 for (int i = 0; i < tempHandCardLen; ++i) { if (TileDef.IsValid(info.cHandCards [i])) { TileDef def = TileDef.Create(info.cHandCards [i]); PocketList.Add(def); } } #if USER_MP //玩家已经出的牌 List <TileDef> list = new List <TileDef>(); for (int i = 0; i < GameMessage.TABLE_PLAYER_NUM; ++i) { for (int j = 0; j < info.cSendCards[i].cCards.Count; ++j) { byte card = info.cSendCards[i].cCards[j]; Console.Write("{0} ", card); list.Add(TileDef.Create(card)); } Debug.Log("##################"); } #else //玩家已经出的牌 List <TileDef> list = new List <TileDef> (); for (int i = 0; i < GameMessage.TABLE_PLAYER_NUM; ++i) { for (int j = 0; j < 21; ++j) { byte card = info.cSendCards [i * 21 + j]; Console.Write("{0} ", card); list.Add(TileDef.Create(card)); } Debug.Log("##################"); } #endif MahjongTile.TotalClickCount = 1; //HUAN PAI if (info.iGameStates == GameMessage.GS_WK_HUANPAI) { for (int i = 0; i < GameMessage.TABLE_PLAYER_NUM; i++) { UIOperation.Instance._headDatas[i].gameState = UIOperation.gameState.XUANPAI; UIOperation.Instance._headDatas[i].isShow = true; } for (int i = 0; i < info.v_RecommendCard.Count; i++) { if (i < GameMessage.MAXHUANPAINUM) { UIOperation.Instance._HuanPaiOldDef[i] = TileDef.Create(info.v_RecommendCard[i]); } } MahjongTile.TotalClickCount = 3; } else if (info.iGameStates == GameMessage.GS_WK_DINGQUE) { //DING QUE for (int i = 0; i < GameMessage.TABLE_PLAYER_NUM; i++) { UIOperation.Instance._headDatas[i].gameState = UIOperation.gameState.DINGQUE; UIOperation.Instance._headDatas[i].isShow = true; } } if (info.cDingQueCards.Count > 0) { //定缺完毕 for (int i = 0; i < info.cDingQueCards.Count; ++i) { TileDef.Kind k = (TileDef.Kind)info.cDingQueCards[i]; if (k != TileDef.Kind.NONE) { UIOperation.Instance._headDatas[i].dingque = k; UIOperation.Instance._headDatas[i].gameState = UIOperation.gameState.NONE; } } } GameClient.Instance.SpecialType = 0; if (info.iSpecialTypeTotal > 0 && info.v_SpecialCard.Count > 0) { //等待吃碰杠胡 GameClient.Instance.SpecialCard = info.v_SpecialCard[0]; GameClient.Instance.SpecialType = info.iSpecialTypeTotal; } #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { if (GameClient.Instance.IsInMahjongGame()) { GameClient.Instance.MahjongGamePlayer.Index = data.usTableNumExtra; GameClient.Instance.MG.OnRestoreGameState(info); //游戏状态 换牌:0x50, 定缺:0x53 等待吃胡碰杠状态:0x08 等待出牌:0x09 // if(info.iGameStates == 0x50) // { // UIGameSetingController.Instance.OnRefreshPlayerState(); // // }else if(info.iGameStates == 0x53) // { // UIGameSetingController.Instance.OnRefreshHeadDingqueState(); // } UIGameSetingController.Instance.OnRefreshHeadAll(); } else { GameClient.Instance.MahjongGamePlayer.Index = data.usTableNumExtra; GameLoading.SwitchScene(3); } }); #endif }); _gsProxy.on(BaseMessage.AGAIN_LOGIN_OTHER_NOTICE_MSG, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; Debug.Log("AGAIN_LOGIN_OTHER_NOTICE_MSG"); //userid /* * typedef struct OtherAgainLoginNotice * //AGAIN_LOGIN_OTHER_NOTICE_MSG重入通知其他玩家 { * MsgHeader msgHeadInfo; * int iUserID; * } OtherAgainLoginNoticeDef; */ }); _gsProxy.on(BaseMessage.SITDOWN_RES_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : SITDOWN_RES_MSG"); return; OdaoMessage msg = (OdaoMessage)obj; BaseMessage.SitDownResDef data = new BaseMessage.SitDownResDef(); data = XConvert.ConvertToObject <BaseMessage.SitDownResDef> (msg.data); Debug.Log(string.Format("NotImplementedException : SITDOWN_RES_MSG -> {0},{1},{2},{3}", data.iTableNum, data.cError, data.usTableNumExtra, data.cPlayerNum)); }); _gsProxy.on(BaseMessage.TABLE_PLAYER_JOIN_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : TABLE_PLAYER_JOIN_MSG"); }); _gsProxy.on(BaseMessage.TABLE_PLAYER_LEAVE_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : TABLE_PLAYER_LEAVE_MSG"); }); _gsProxy.on(BaseMessage.READY_RES_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : READY_RES_MSG"); return; OdaoMessage msg = (OdaoMessage)obj; BaseMessage.ReadyResDef data = new BaseMessage.ReadyResDef(); data = XConvert.ConvertToObject <BaseMessage.ReadyResDef> (msg.data); Debug.Log(string.Format("椅子号{0}", data.usTableNumExtra)); }); //玩家输赢数据,经验值 _gsProxy.on(BaseMessage.USER_SCORE_INFO_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : USER_SCORE_INFO_MSG"); }); //旁观玩家进入桌子 _gsProxy.on(BaseMessage.JOIN_TABLE_AS_VISITOR, delegate(Message obj) { Debug.Log("NotImplementedException : JOIN_TABLE_AS_VISITOR"); }); //更新一桌玩家身份 _gsProxy.on(BaseMessage.UPDATE_TABLE_PLAYER_STATUS, delegate(Message obj) { Debug.Log("NotImplementedException : UPDATE_TABLE_PLAYER_STATUS"); }); //VIP踢人请求 _gsProxy.on(BaseMessage.VIP_KICKOUT_PLAYER_REQ, delegate(Message obj) { Debug.Log("NotImplementedException : VIP_KICKOUT_PLAYER_REQ"); }); //VIP踢人回应 _gsProxy.on(BaseMessage.VIP_KICKOUT_PLAYER_RES, delegate(Message obj) { Debug.Log("NotImplementedException : VIP_KICKOUT_PLAYER_RES"); }); //自由设定桌子人数 0XA013后在Odao_SiteActivity_Msg.h中用 _gsProxy.on(BaseMessage.TABLE_SET_PLAYER_NUMBER, delegate(Message obj) { Debug.Log("NotImplementedException : TABLE_SET_PLAYER_NUMBER"); }); //充值同步积分 _gsProxy.on(BaseMessage.CLIENT_CHARGE_REFRESH_MONEY_REQ, delegate(Message obj) { Debug.Log("NotImplementedException : CLIENT_CHARGE_REFRESH_MONEY_REQ"); }); //服务器踢除玩家 _gsProxy.on(BaseMessage.KICK_OUT_SERVER_MSG, delegate(Message obj) { Debug.Log("KICK_OUT_SERVER_MSG"); OdaoMessage msg = (OdaoMessage)obj; BaseMessage.TablePlayerLeaveDef data = new BaseMessage.TablePlayerLeaveDef(); data = XConvert.ConvertToObject <BaseMessage.TablePlayerLeaveDef> (msg.data); Debug.Log("***************KICK_OUT_SERVER_MSG type:" + data.cLeaveType); #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { GameClient.Instance.MahjongGamePlayer.LeaveOut(data.cLeaveType); UIDebugViewController.Instance.SetText("你为啥把我踢下去????????KICK_OUT_SERVER_MSG"); UIDebugViewController.Instance.OnRefresh(); }); #endif }); //入座请求密码 _gsProxy.on(BaseMessage.CHECK_SITDOWN_PASSWD_REQ, delegate(Message obj) { Debug.Log("NotImplementedException : CHECK_SITDOWN_PASSWD_REQ"); }); //请求设定桌底柱消息 _gsProxy.on(BaseMessage.SET_TABLE_BASEPOINT_REQ, delegate(Message obj) { Debug.Log("NotImplementedException : SET_TABLE_BASEPOINT_REQ"); }); _gsProxy.on(BaseMessage.TABLE_PLAYER_LEAVE_NOTICE, delegate(Message obj) { Debug.Log("NotImplementedException : TABLE_PLAYER_LEAVE_NOTICE"); }); _gsProxy.on(BaseMessage.SEND_ALL_USERINFO_TO_CLIENT, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_ALL_USERINFO_TO_CLIENT"); return; OdaoMessage msg = (OdaoMessage)obj; int offset = 0; BaseMessage.SendAllUserInfo data = XConvert.ConvertToObject <BaseMessage.SendAllUserInfo> (msg.data, ref offset); for (int i = 0; i < data.iUserCount; ++i) { BaseMessage.UserInfo userInfo = XConvert.ConvertToObject <BaseMessage.UserInfo> (msg.data, ref offset); byte[] bytes = System.Text.Encoding.GetEncoding("GBK").GetBytes(userInfo.szUserName); string name = System.Text.Encoding.UTF8.GetString(bytes); Debug.Log("SEND_ALL_USERINFO_TO_CLIENT---->" + name); } }); //游戏结束服务器通知 所有游戏公用 _gsProxy.on(BaseMessage.GAME_RESULT_SERVER_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : GAME_RESULT_SERVER_MSG"); }); //游戏公告消息 _gsProxy.on(BaseMessage.GAME_BULL_NOTICE_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : GAME_BULL_NOTICE_MSG"); }); //对应玩家的催牌消息 _gsProxy.on(BaseMessage.URGR_CARD_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : URGR_CARD_MSG"); }); //玩家的喊话消息 _gsProxy.on(BaseMessage.SHOUT_INFO_RES_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : SHOUT_INFO_RES_MSG"); }); //游戏基本房间信息 _gsProxy.on(BaseMessage.SEND_GAME_ROOM_INFO, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_GAME_ROOM_INFO"); }); //发送所有玩家的桌信息 _gsProxy.on(BaseMessage.SEND_ALL_TABLE_INFO, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_ALL_TABLE_INFO"); /* * OdaoMessage msg = (OdaoMessage)obj; * int offset = 0; * BaseMessage.TableInfo tableInfo = XConvert.ConvertToObject<BaseMessage.TableInfo>(msg.data, ref offset); * Debug.Log(tableInfo.iAllTableCount); * for (int i = 0; i < tableInfo.iAllTableCount; ++i) * { * BaseMessage.TableStatusInfo tableStatusInfo = XConvert.ConvertToObject<BaseMessage.TableStatusInfo>(msg.data, ref offset); * //Debug.Log(i + "," + offset); * } */ }); //群发消息处理 //发送所有玩家信息给客户端 _gsProxy.on(BaseMessage.SEND_ALLUSER_STATUS_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_ALLUSER_STATUS_MSG"); return; OdaoMessage msg = (OdaoMessage)obj; BaseMessage.UserStatusInfo userStatusInfo = XConvert.ConvertToObject <BaseMessage.UserStatusInfo> (msg.data); Debug.Log(string.Format("{0}", userStatusInfo.iMsgCount)); }); _gsProxy.on(BaseMessage.SEND_TABLE_STAUTS_TO_CLIENT, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_TABLE_STAUTS_TO_CLIENT"); }); _gsProxy.on(BaseMessage.SEND_TABLE_LOCKED_TO_CLIENT, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_TABLE_LOCKED_TO_CLIENT"); }); _gsProxy.on(BaseMessage.SEND_TABLE_LEVEL_TO_CLIENT, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_TABLE_LEVEL_TO_CLIENT"); return; OdaoMessage msg = (OdaoMessage)obj; BaseMessage.TableLevel tableLevel = XConvert.ConvertToObject <BaseMessage.TableLevel> (msg.data); Debug.Log(string.Format("{0},{1}", tableLevel.cTableLevel, tableLevel.usTableNum)); }); _gsProxy.on(BaseMessage.SEND_TABLE_SETTING_TO_CLIENT, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_TABLE_SETTING_TO_CLIENT"); }); _gsProxy.on(BaseMessage.SEND_TABLE_ANTE_TO_CLIENT, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_TABLE_ANTE_TO_CLIENT"); }); //是否需要发送底注 _gsProxy.on(BaseMessage.SET_BASE_POINT_SERVER, delegate(Message obj) { Debug.Log("NotImplementedException : SET_BASE_POINT_SERVER"); }); //游戏开始通知 _gsProxy.on(BaseMessage.GAME_START_NOTICE_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : GAME_START_NOTICE_MSG"); }); //入座成功收到道具信息 _gsProxy.on(BaseMessage.SIT_DOWN_SUCCESS_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : SIT_DOWN_SUCCESS_MSG"); }); //同意底注请求 _gsProxy.on(BaseMessage.TABLE_BASEINFO_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : TABLE_BASEINFO_MSG"); }); //是否需要发送底注(特殊) _gsProxy.on(BaseMessage.SET_BASE_POINT_SPE_SERVER, delegate(Message obj) { Debug.Log("NotImplementedException : SET_BASE_POINT_SPE_SERVER"); }); //同意底注请求(特殊) _gsProxy.on(BaseMessage.TABLE_BASEINFO_SPE_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : TABLE_BASEINFO_SPE_MSG"); }); //是否需要发送底注(特殊) _gsProxy.on(BaseMessage.HONGBAO_TABLE_INFO, delegate(Message obj) { Debug.Log("NotImplementedException : HONGBAO_TABLE_INFO"); }); //玩家登录银行请求 _gsProxy.on(BaseMessage.USER_LOGIN_BANK_REQ, delegate(Message obj) { Debug.Log("NotImplementedException : USER_LOGIN_BANK_REQ"); }); //银行登录结果相应 _gsProxy.on(BaseMessage.USER_LOGIN_RESULT_NOTICE, delegate(Message obj) { Debug.Log("NotImplementedException : USER_LOGIN_RESULT_NOTICE"); }); //取款清求 _gsProxy.on(BaseMessage.GET_BANK_COIN_REQ, delegate(Message obj) { Debug.Log("NotImplementedException : GET_BANK_COIN_REQ"); }); //取款结果响应 _gsProxy.on(BaseMessage.GET_COIN_RESULT_RES, delegate(Message obj) { Debug.Log("NotImplementedException : GET_COIN_RESULT_RES"); }); //存款请求 _gsProxy.on(BaseMessage.USER_SAVE_COIN_REQ, delegate(Message obj) { Debug.Log("NotImplementedException : USER_SAVE_COIN_REQ"); }); //存款结果响应 _gsProxy.on(BaseMessage.USER_SAVE_COIN_RES, delegate(Message obj) { Debug.Log("NotImplementedException : USER_SAVE_COIN_RES"); }); //用户修改银行密码请求 _gsProxy.on(BaseMessage.MODIFY_BANK_PASSWD_REQ, delegate(Message obj) { Debug.Log("NotImplementedException : MODIFY_BANK_PASSWD_REQ"); }); //用户修改银行密码响应 //玩家积分变化时,通知同桌其他玩家 _gsProxy.on(BaseMessage.MODIFY_BANK_PASSWD_RES, delegate(Message obj) { Debug.Log("NotImplementedException : MODIFY_BANK_PASSWD_RES"); }); _gsProxy.on(BaseMessage.SC_MSG_NOTIFY_TABLE_PLAYERS_COIN_CHANGE, delegate(Message obj) { Debug.Log("NotImplementedException : SC_MSG_NOTIFY_TABLE_PLAYERS_COIN_CHANGE"); }); //玩家身上的额外道具 _gsProxy.on(BaseMessage.GAME_USER_PROPEX_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : GAME_USER_PROPEX_MSG"); }); //客户端站点类型 _gsProxy.on(BaseMessage.GAME_CLIENT_SITE_TYPE_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : GAME_CLIENT_SITE_TYPE_MSG"); }); }
public void InitGameMessage(OdaoClient client) { _gsProxy = client; //客户端发送换牌消息 _gsProxy.on(GameMessage.c2s_HuanPaiDef, delegate(Message obj) { Debug.Log("NotImplementedException : SUB_C_HUANPAI"); }); //客户端发送认输消息 _gsProxy.on(GameMessage.SUB_C_QUEDINGRENSHU, delegate(Message obj) { Debug.Log("NotImplementedException : SUB_C_QUEDINGRENSHU"); }); //客户端托管 _gsProxy.on(GameMessage.s2c_TrusteeShipDef, delegate(Message obj) { Debug.Log("TRUSTEESHIP_NOTICE_MSG"); OdaoMessage msg = (OdaoMessage)obj; GameMessage.TrusteeShipDef data = XConvert.ConvertToObject <GameMessage.TrusteeShipDef>(msg.data); Debug.Log("托管 " + (data.flag > 0 ? "开启" : "关闭") + "," + "椅子号 " + data.cTableNumExtra); #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { GameClient.Instance.MG.ComputerManageFor(data.cTableNumExtra, data.flag); }, delegate(){ return(GameClient.Instance.MG != null); }); #endif }); //2:Server 服务器通知客户端消息(将某玩家的动作告诉所有桌上的玩家) //出牌通知 _gsProxy.on(GameMessage.s2c_SendCardNoticeDef, delegate(Message obj) { Debug.Log("SEND_CARDS_NOTICE_MSG"); OdaoMessage msg = (OdaoMessage)obj; #if USE_MSGPACK2 var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.SendCardNoticeDef>(); var data = serializer.UnpackSingleObject(msg.data); #else GameMessage.SendCardNoticeDef data = XConvert.ConvertToObject <GameMessage.SendCardNoticeDef>(msg.data); #endif TileDef def = TileDef.Create(data.cCard); Debug.Log(string.Format("椅子号{0},出牌{1}", data.cTableNumExtra, def.ToString())); #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { GameClient.Instance.MG.AutoPlay(data.cTableNumExtra, def, data.flag); }, delegate() { return(GameClient.Instance.MG != null); }); #endif }); //吃杠碰胡请求 _gsProxy.on(GameMessage.s2c_SpecialCardDef, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; #if USE_MSGPACK2 var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.SpecialCardDef>(); var data = serializer.UnpackSingleObject(msg.data); #else GameMessage.SpecialCardDef data = XConvert.ConvertToObject <GameMessage.SpecialCardDef>(msg.data); #endif Debug.Log(string.Format("s2c_SpecialCardDef0x{0:x} --> {1:x}", data.specialType, data.card)); #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { GameClient.Instance.SpecialCard = data.card; if (IsSpecialType(data.specialType, (byte)GameMessage.SPECIAL_TYPE.PASS)) { Debug.Log("---OpenCombo PASS---"); UIGameComboController.Instance.OpenCombo(TileDef.ComboType.PASS, GameClient.Instance.MG.Self); } if (IsSpecialType(data.specialType, (byte)GameMessage.SPECIAL_TYPE.PONG)) { Debug.Log("---OpenCombo PONG---"); UIGameComboController.Instance.OpenCombo(TileDef.ComboType.PONG, GameClient.Instance.MG.Self); } if (IsSpecialType(data.specialType, (byte)GameMessage.SPECIAL_TYPE.KONG)) { Debug.Log("---OpenCombo KONG---"); UIGameComboController.Instance.OpenCombo(TileDef.ComboType.KONG_DARK, GameClient.Instance.MG.Self); } if (IsSpecialType(data.specialType, (byte)GameMessage.SPECIAL_TYPE.DARK_KONG)) { Debug.Log("---OpenCombo DARK_KONG---"); UIGameComboController.Instance.OpenCombo(TileDef.ComboType.KONG_DARK, GameClient.Instance.MG.Self); } if (IsSpecialType(data.specialType, (byte)GameMessage.SPECIAL_TYPE.SPECIAL_TYPE_PENGGANG)) { Debug.Log("---OpenCombo SPECIAL_TYPE_PENGGANG---"); UIGameComboController.Instance.OpenCombo(TileDef.ComboType.KONG_TURN, GameClient.Instance.MG.Self); } if (IsSpecialType(data.specialType, (byte)GameMessage.SPECIAL_TYPE.WIN)) { Debug.Log("---OpenCombo WIN---"); UIGameComboController.Instance.OpenCombo(TileDef.ComboType.WIN, GameClient.Instance.MG.Self); } }, delegate() { return(GameClient.Instance.MG != null); }); #endif }); //玩家吃杠碰胡通知 _gsProxy.on(GameMessage.s2c_SpecialNoticeSerDef, delegate(Message obj) { Debug.Log("********************s2c_SpecialNoticeSerDef********************"); OdaoMessage msg = (OdaoMessage)obj; #if USE_MSGPACK2 var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.SpecialNoticeSerDef>(); var data = serializer.UnpackSingleObject(msg.data); #else GameMessage.SpecialNoticeSerDef data = XConvert.ConvertToObject <GameMessage.SpecialNoticeSerDef>(msg.data); #endif TileComboDef tileComboDef = null; if (IsSpecialType(data.cSpecialType, (byte)GameMessage.SPECIAL_TYPE.PONG)) { tileComboDef = TileComboDef.Create(data.cDianPao, TileDef.ComboType.PONG, TileDef.Create(data.cCard)); } if (IsSpecialType(data.cSpecialType, (byte)GameMessage.SPECIAL_TYPE.KONG)) { tileComboDef = TileComboDef.Create(data.cDianPao, TileDef.ComboType.KONG, TileDef.Create(data.cCard)); } if (IsSpecialType(data.cSpecialType, (byte)GameMessage.SPECIAL_TYPE.DARK_KONG)) { tileComboDef = TileComboDef.Create(data.cDianPao, TileDef.ComboType.KONG_DARK, TileDef.Create(data.cCard)); } if (IsSpecialType(data.cSpecialType, (byte)GameMessage.SPECIAL_TYPE.SPECIAL_TYPE_PENGGANG)) { tileComboDef = TileComboDef.Create(data.cDianPao, TileDef.ComboType.KONG_TURN, TileDef.Create(data.cCard)); } if (IsSpecialType(data.cSpecialType, (byte)GameMessage.SPECIAL_TYPE.WIN)) { WinState = true; tileComboDef = TileComboDef.Create(data.cDianPao, TileDef.ComboType.WIN, TileDef.Create(data.cCard)); } if (null != tileComboDef) { Debug.Log("--------------------->s2c_SpecialNoticeSerDef " + tileComboDef.ToString()); } #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { UIGameComboController.Instance.Close(); if (!IsSpecialType(data.cSpecialType, (byte)GameMessage.SPECIAL_TYPE.PASS)) { GameClient.Instance.MG.AutoCombo(data.cExtraTableNum, tileComboDef, data.flag); if (data.cExtraTableNum == Index) { UIGameEffectController.Instance.ShowComboEffect(tileComboDef.Combo); } } }); #endif }); //通知玩家定缺 _gsProxy.on(GameMessage.s2c_DingQueDef, delegate(Message obj) { Debug.Log("******************s2c_DingQueDef"); #if USE_MSGPACK2 OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.DingQueDef>(); var lactKind = serializer.UnpackSingleObject(msg.data); #else Debug.Log("s2c_DingQueDef"); OdaoMessage msg = (OdaoMessage)obj; GameMessage.DingQueDef lactKind = XConvert.ConvertToObject <GameMessage.DingQueDef>(msg.data); #endif #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN for (int i = 0; i < GameMessage.TABLE_PLAYER_NUM; i++) { UIOperation.Instance._headDatas[i].gameState = UIOperation.gameState.DINGQUE; UIOperation.Instance._headDatas[i].isShow = true; } Loom.QueueOnMainThread(delegate() { UIDQSettingController.Instance.Open(); UIGameSetingController.Instance.OnRefreshPlayerState(); //default lackKind }, delegate() { if (GameClient.Instance.MG != null) { //UnityEngine.Debug.Log("!!!&&&&&&&&&"+GameClient.Instance.MG.GameInitDone); } return(GameClient.Instance.MG != null && GameClient.Instance.MG.GameInitDone); }); #endif }); //服务器通知玩家换牌 _gsProxy.on(GameMessage.s2c_HuaiPaiDef, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.HuanPaiDef>(); var data = serializer.UnpackSingleObject(msg.data); for (int i = 0; i < GameMessage.MAXHUANPAINUM; i++) { if (i < data.vHuanPai.Count) { TileDef def = TileDef.Create(data.vHuanPai[i]); UIOperation.Instance._HuanPaiOldDef[i] = def; Debug.Log("开始换牌[" + i + "]:" + def.ToString()); } } for (int i = 0; i < GameMessage.TABLE_PLAYER_NUM; i++) { UIOperation.Instance._headDatas[i].gameState = UIOperation.gameState.XUANPAI; UIOperation.Instance._headDatas[i].isShow = true; } Loom.QueueOnMainThread(delegate() { UIGameSetingController.Instance.OnRefreshPlayerState(); MahjongTile.TotalClickCount = 3; }, delegate() { return(GameClient.Instance.MG != null && UIGameSetingController.Instance.IsOpen() && GameClient.Instance.MG.GameInitDone); }); }); //const int SC_MSG_NOTIFY_TABLE_PLAYERS_COIN_CHANGE = 59432;//当玩家取钱后更新玩家身上的钱 //ADD //通知玩家有人定缺完毕 //_gsProxy.on(GameMessage.SEND_SOMEONEDINGQUE_MSG, delegate (Message obj) // { // Debug.Log("SEND_SOMEONEDINGQUE_MSG"); // }); //服务器的发牌请求 _gsProxy.on(GameMessage.s2c_SendMjSerDef, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; #if USE_MSGPACK2 var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.SendMjSerDef>(); var data = serializer.UnpackSingleObject(msg.data); #else GameMessage.SendMjSerDef data = XConvert.ConvertToObject <GameMessage.SendMjSerDef>(msg.data); #endif Debug.Log("s2c_SendMjSerDef " + "椅子号" + data.tableNumExtra + "需要出牌" + data.draw + "#######" + data.specialType); /* * public class SendMjSerDef * { * public byte cTableNumExtra; //出牌的那个人 * public byte cGetMj; //摸的那张牌 0表示没有从剩余的牌墙中取牌,也就是刚才的动作是碰,然后该出牌了 * public int iSpeciaType; //胡,暗杠,碰杠的二进制合 * }*/ //*只有胡和转弯杠* GameClient.Instance.SpecialCard = data.draw; #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN Loom.QueueOnMainThread(delegate() { GameClient.Instance.MG.TurnTo(data.tableNumExtra); // dont draw, because last operation is pong, now you should play if (data.draw == 0) { } else { TileDef def = TileDef.Create(data.draw); GameClient.Instance.MG.Draw(data.tableNumExtra, def); } //GameClient.Instance.SpecialCard = data.draw; // if(IsSpecialType(data.specialType, (byte)GameMessage.SPECIAL_TYPE.PASS)) // { // UIGameComboController.Instance.OpenCombo(TileDef.ComboType.PASS,GameClient.Instance.MG.Self); // } // // if(IsSpecialType(data.specialType,(byte)GameMessage.SPECIAL_TYPE.PONG)) // { // UIGameComboController.Instance.OpenCombo(TileDef.ComboType.PONG,GameClient.Instance.MG.Self); // } // // if(IsSpecialType(data.specialType,(byte)GameMessage.SPECIAL_TYPE.KONG)) // { // UIGameComboController.Instance.OpenCombo(TileDef.ComboType.KONG_DARK,GameClient.Instance.MG.Self); // } // // if(IsSpecialType(data.specialType,(byte)GameMessage.SPECIAL_TYPE.DARK_KONG)) // { // UIGameComboController.Instance.OpenCombo(TileDef.ComboType.KONG_DARK,GameClient.Instance.MG.Self); // } // // if(IsSpecialType(data.specialType,(byte)GameMessage.SPECIAL_TYPE.SPECIAL_TYPE_PENGGANG)) // { // UIGameComboController.Instance.OpenCombo(TileDef.ComboType.KONG_TURN,GameClient.Instance.MG.Self); // } // // if(IsSpecialType(data.specialType,(byte)GameMessage.SPECIAL_TYPE.WIN)) // { // UIGameComboController.Instance.OpenCombo(TileDef.ComboType.WIN,GameClient.Instance.MG.Self); // } UIGameComboController.Instance.OpenAllCombos(data.specialType); }, delegate() { return(GameClient.Instance.MG != null); } ); #endif }); //服务器给玩家发送换的牌 _gsProxy.on(GameMessage.s2c_Notice_HuanPaiDef, delegate(Message obj) { OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.HuanPaiResDef>(); var data = serializer.UnpackSingleObject(msg.data); MahjongTile.TotalClickCount = 1; for (int i = 0; i < GameMessage.MAXHUANPAINUM; i++) { if (i < data.cCards.Count) { TileDef def = TileDef.Create(data.cCards[i]); UIOperation.Instance._HuanPaiNewDef[i] = def; Debug.Log("***********************换的牌:" + def.ToString()); Debug.Log("***********************删除的牌:" + UIOperation.Instance._HuanPaiOldDef[i].ToString()); } } List <TileDef> newPocketList = new List <TileDef>(); int[] removeIndex = new int[GameMessage.MAXHUANPAINUM] { 0, 0, 0 }; for (int i = 0; i < PocketList.Count; i++) { bool canAdd = true; for (int j = 0; j < GameMessage.MAXHUANPAINUM; j++) { if (PocketList[i].Value == UIOperation.Instance._HuanPaiOldDef[j].Value && removeIndex[j] == 0) { Debug.Log("**********************删除手牌:" + UIOperation.Instance._HuanPaiOldDef[j].ToString()); canAdd = false; removeIndex[j] = 1; break; } } if (canAdd) { newPocketList.Add(PocketList[i]); } } for (int i = 0; i < GameMessage.MAXHUANPAINUM; i++) { newPocketList.Add(UIOperation.Instance._HuanPaiNewDef[i]); } string oldStr = "*********************换牌前手牌" + PocketList.Count + ":"; foreach (var def in PocketList) { oldStr += def.ToString() + ", "; } PocketList = newPocketList; string newStr = "*********************换牌后手牌" + PocketList.Count + ":"; foreach (var def in PocketList) { newStr += def.ToString() + ", "; } Debug.Log(oldStr); Debug.Log(newStr); UIOperation.Instance._HuanPaiType = (GameMessage.HUANPAI_TYPE)data.iChangeType; Loom.QueueOnMainThread(delegate() { GameClient.Instance.MG.Self.ResetPocketList(PocketList.Count == GameMessage.HANDLE_MJ_NUM); UIGameSetingController.Instance.CloseHuanpaiTips(); }, delegate() { return(GameClient.Instance.MG != null); }); }); //通知客户端玩家的定缺牌 _gsProxy.on(GameMessage.s2c_Notice_DingQueResDef, delegate(Message obj) { int dataCount = 0; #if USE_MSGPACK2 OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.DingQueResDef>(); var data = serializer.UnpackSingleObject(msg.data); dataCount = data.cques.Count; #else OdaoMessage msg = (OdaoMessage)obj; GameMessage.DingQueResDef data = XConvert.ConvertToObject <GameMessage.DingQueResDef>(msg.data); dataCount = data.cques.Length; #endif #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN for (int i = 0; i < dataCount; ++i) { TileDef.Kind k = (TileDef.Kind)data.cques[i]; if (k != TileDef.Kind.NONE) { GameClient.Instance.MG.SetLackTile(i, k); UIOperation.Instance._headDatas[i].dingque = k; UIOperation.Instance._headDatas[i].gameState = UIOperation.gameState.NONE; } } Loom.QueueOnMainThread(delegate() { GameClient.Instance.MG.UpdateLackState(); UIGameSetingController.Instance.OnRefreshHeadAll(); UIDQSettingController.Instance.Close(); }); #endif }); //通知客户端玩家没钱了 _gsProxy.on(GameMessage.SEND_NO_MONEY_MSG, delegate(Message obj) { Debug.Log("NotImplementedException : SEND_NO_MONEY_MSG"); }); //通知客户端 认输 _gsProxy.on(GameMessage.SUB_S_QUEDINGRENSHU, delegate(Message obj) { Debug.Log("NotImplementedException : SUB_S_QUEDINGRENSHU"); }); //3:Server 发起客户端消息(服务器端发起,告诉桌上所有玩家) //服务器给所有玩家发牌 _gsProxy.on(GameMessage.s2c_DealMjServerDef, delegate(Message obj) { #if USE_MSGPACK2 OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.DealMjServerDef>(); GameMessage.DealMjServerDef data = serializer.UnpackSingleObject(msg.data); PocketList.Clear(); for (int i = 0; i < data.cCards.Count; i++) { var valueTemp = data.cCards[i]; Debug.Log(((valueTemp >> 4) & 0x0f) + ":" + (valueTemp & 0x0f) + "value:" + valueTemp); if (TileDef.IsValid(valueTemp)) { TileDef def = TileDef.Create(valueTemp); PocketList.Add(def); } } #else Debug.Log("s2c_DealMjServerDef***************************"); OdaoMessage msg = (OdaoMessage)obj; GameMessage.DealMjServerDef data = XConvert.ConvertToObject <GameMessage.DealMjServerDef>(msg.data); PocketList.Clear(); for (int i = 0; i < GameMessage.HANDLE_MJ_NUM; ++i) { Debug.Log(((data.cCards[i] >> 4) & 0x0f) + ":" + (data.cCards[i] & 0x0f)); if (TileDef.IsValid(data.cCards[i])) { TileDef def = TileDef.Create(data.cCards[i]); PocketList.Add(def); } } #endif #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN //BUG UnityEngine.Debug.Log("DEAL_CARD_SERVER_MSG---->>>>" + ToString()); SortPocketList(TileDef.Comparison); UnityEngine.Debug.Log("DEAL_CARD_SERVER_MSG---->>>> SORTED " + ToString()); Loom.QueueOnMainThread(delegate() { GameClient.Instance.MG.DealerIndex = data.cZhuang; GameClient.Instance.MG.StartRun(); UIGameSetingController.Instance.OnRefreshHeadZhuangState(); }, delegate() { return(GameClient.Instance.MG != null); } ); #endif }); //match 返回,换桌也会返回 _gsProxy.on(GameMessage.s2c_MatchGameRes, delegate(Message obj) { Debug.Log("MatchGameRes"); OdaoMessage msg = (OdaoMessage)obj; GameMessage.MatchGameRes data = XConvert.ConvertToObject <GameMessage.MatchGameRes>(msg.data); #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN if (data.errorCode < 0) { Debug.Log("ErrorCode " + data.errorCode); } Loom.QueueOnMainThread(() => { UIOperation.Instance.Matching = false; for (int i = 0; i < data.playerIndex.Length; ++i) { if (data.playerIndex[i] == Info.UserId) { if (!GameClient.Instance.IsInMahjongGame()) { Index = i; UIOperation.Instance.SelfIndex = Index; GameLoading.SwitchScene(3); } else { GameClient.Instance.MG.ArrangePlayer(i, 4); } break; } } }); #endif }); _gsProxy.on(GameMessage.s2c_GameResultServerDef, delegate(Message obj) { #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN UnityEngine.Debug.Log("NotImplementedException : s2c_GameResultServerDef "); OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.GameResultServerDef>(); GameMessage.GameResultServerDef data = serializer.UnpackSingleObject(msg.data); UIOperation.Instance._gameResultDatas = data.GameResult; UIOperation.Instance.Reset(); Loom.QueueOnMainThread(delegate() { UIGameResultController.Instance.Open(); UIGameHuPromptController.Instance.Close(); for (int i = 0; i < GameMessage.TABLE_PLAYER_NUM; i++) { GameClient.Instance.MG.ShowPocketList(i); } UIGameEffectController.Instance.DespawnAllEffect(); }, delegate() { return(GameClient.Instance.MG != null); } ); #endif }); //离开游戏,换桌返回(换桌还会返回0x22;)其他玩家离开也会收到此消息 _gsProxy.on(GameMessage.s2c_Notice_LeaveTableDef, delegate(Message obj) { #if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN UnityEngine.Debug.Log("======================= NotImplementedException : s2c_Notice_LeaveTableDef ======================= "); OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.NoticeLeaveTableDef>(); GameMessage.NoticeLeaveTableDef data = serializer.UnpackSingleObject(msg.data); Loom.QueueOnMainThread(delegate() { if ((int)data.cLeaveType == (int)GameMessage.LEAVETABLE_TYPE.LEAVETABLE_LEAVE) { if (data.iUserID == Info.UserId && GameClient.Instance.IsInMahjongGame()) { UIGameSetingController.Instance.Close(); UIGameResultController.Instance.Close(); GameLoading.SwitchScene(2); } } }, delegate() { return(true); } ); #endif }); //胡牌提示返回,每次发手牌会收到此消息 _gsProxy.on(GameMessage.s2c_HuTipsResDef, delegate(Message obj) { //#if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN UnityEngine.Debug.Log("======================= NotImplementedException : s2c_HuTipsResDef ======================= "); OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.AllOutCard>(); GameMessage.AllOutCard data = serializer.UnpackSingleObject(msg.data); UIOperation.Instance._huTipsCards = data.v_OutCards; if (UIOperation.Instance._huTipsCards.Count > 0) { foreach (var card in data.v_OutCards) { TileDef def = TileDef.Create(card.cOutCard); string ss = "******************************打出:" + def.ToString() + "胡:"; foreach (var tips in card.v_Tips) { TileDef def1 = TileDef.Create(tips.cCard); ss += def1.ToString() + ",倍数" + tips.cTimes + ",张数:" + tips.cLeftNum + "------"; } Debug.Log(ss); } } Loom.QueueOnMainThread(delegate() { }, delegate() { return(GameClient.Instance.MG != null); } ); //#endif }); //通知客户端显示按钮(血战到底会收到此消息) _gsProxy.on(GameMessage.s2c_LeaveTableDef, delegate(Message obj) { //#if UNITY_EDITOR || UNITY_IOS || UNITY_ANDROID || UNITY_STANDALONE_OSX || UNITY_STANDALONE_WIN UnityEngine.Debug.Log("======================= NotImplementedException : s2c_LeaveTableDef ======================= "); OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.LeaveTableDef>(); GameMessage.LeaveTableDef data = serializer.UnpackSingleObject(msg.data); Loom.QueueOnMainThread(delegate() { }, delegate() { return(GameClient.Instance.MG != null); } ); //#endif }); _gsProxy.on(0x57, delegate(Message obj) { List <GameMessage.TEST_MSGPACK_PlayerCard> cardList = new List <GameMessage.TEST_MSGPACK_PlayerCard>(); List <byte> m_vCType = new List <byte>(); List <int> m_viType = new List <int>(); List <long> m_vLLType = new List <long>(); List <GameMessage.TEST_MSGPACK_TableNum> m_vPosition = new List <GameMessage.TEST_MSGPACK_TableNum>(); GameMessage.TEST_MSGPACK testMsgPack = new GameMessage.TEST_MSGPACK(); testMsgPack.cType = 0; testMsgPack.iType = 1; testMsgPack.llType = 2; testMsgPack.m_allPlayerCard = cardList; testMsgPack.m_string = "ok"; testMsgPack.m_vCType = m_vCType; testMsgPack.m_viType = m_viType; testMsgPack.m_vLLType = m_vLLType; testMsgPack.m_vPosition = m_vPosition; testMsgPack.m_vusType = new List <ushort> { 1, 2, 3, 4 }; testMsgPack.usType = 3; OdaoMessage msg = (OdaoMessage)obj; var serializer = MsgPack.Serialization.MessagePackSerializer.Get <GameMessage.TEST_MSGPACK> (); var recvbuffer = new System.IO.MemoryStream(msg.data); var test = serializer.Unpack(recvbuffer); var test2 = serializer.UnpackSingleObject(msg.data); Debug.Log(test); Debug.Log("****************MessagePack StringTest:" + test2.m_string + ", len:" + test2.m_string.Length); // byte[] strByte = Encoding.Unicode.GetBytes(test2.m_string); // foreach(var temp in strByte) // { // Debug.Log("****:"+temp); // } var sendbuffer = new System.IO.MemoryStream(); serializer.Pack(sendbuffer, testMsgPack); byte[] t = serializer.PackSingleObject(testMsgPack); byte[] a = sendbuffer.GetBuffer(); sendbuffer.Position = 0; byte[] b = sendbuffer.GetBuffer(); /* * for(int i=0;i<107;++i) * { * if(t[i]!=msg.data[i]) * { * UnityEngine.Debug.LogError("byte match error " + i); * } * * if(a[i]!=msg.data[i]) * { * UnityEngine.Debug.LogError("AAA byte match error " + i); * } * * if(b[i]!=msg.data[i]) * { * UnityEngine.Debug.LogError("BBB byte match error " + i); * } * } */ _gsProxy.notifyMP(0x57, t); /* * GameMessage.TEST_RAW data= XConvert.ConvertToObject<GameMessage.TEST_RAW>(msg.data); * * for(int i=0;i<msg.data.Length;++i) * { * //Debug.Log(string.Format("{0:x}", msg.data[i])); * UnityEngine.Debug.Log(msg.data[i]); * } * UnityEngine.Debug.Log("========================================="); * * byte[] list = XConvert.ConvertToByte(data); * for(int i=0;i<list.Length;++i) * { * UnityEngine.Debug.Log(list[i]); * } * _gsProxy.notify(0x57, list); */ }); }