From ba42a47ca88381ef4762e56a8c39fa167aaad3b0 Mon Sep 17 00:00:00 2001
From: hch <305670599@qq.com>
Date: 星期二, 15 一月 2019 21:47:09 +0800
Subject: [PATCH] 5512 子 【开发】【1.4】跨服竞技场 / 【后端】【1.4】跨服竞技场开发 -- 玩家数据 buff即时通知

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/RemoteQuery/GY_Query_CrossRealmReg.py |   62 ++++++++++++++++++++++++-------
 1 files changed, 48 insertions(+), 14 deletions(-)

diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/RemoteQuery/GY_Query_CrossRealmReg.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/RemoteQuery/GY_Query_CrossRealmReg.py
index eae5dde..38697a6 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/RemoteQuery/GY_Query_CrossRealmReg.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/RemoteQuery/GY_Query_CrossRealmReg.py
@@ -16,9 +16,12 @@
 #-------------------------------------------------------------------------------
 
 import GameWorld
+import PlayerControl
 import CrossRealmPlayer
 import IPY_GameWorld
-import ChPlayer
+import ChPyNetSendPack
+import NetPackCommon
+import ChConfig
 
 
 #------------------------------------------------------------------------------ 
@@ -43,29 +46,51 @@
 #  @remarks 函数详细说明.
 def DoResult(curPlayer, callFunName, funResult, tick):
     resultInfo = eval(funResult)
-    actionType = resultInfo[0]
-    mapPosInfo = resultInfo[1:]
-    if not curPlayer:
+    GameWorld.Log("GY_Query_CrossRealmReg DoResult %s" % funResult, curPlayer.GetPlayerID())
+    if not resultInfo:
         return
-    
-    playerID = curPlayer.GetPlayerID()
-    GameWorld.Log("GY_Query_CrossRealmReg DoResult %s" % funResult, playerID)
+    registerMap, mapID, dataMapID, copyMapID, posX, posY = resultInfo
+    RegisterEnterCrossServer(curPlayer, registerMap, mapID, dataMapID, copyMapID, posX, posY)
+    return
 
+def RegisterEnterCrossServer(curPlayer, registerMap, mapID=0, dataMapID=0, copyMapID=0, posX=0, posY=0):
+    '''
+    @param registerMap: 一般是dataMapID
+    '''
+    playerID = curPlayer.GetPlayerID()
     if GameWorld.IsCrossServer():
         GameWorld.Log("    跨服服务器不允许上传报名数据!", playerID)
         return
     
-    if not mapPosInfo:
+    playerRegisterMap = curPlayer.NomalDictGetProperty(ChConfig.Def_PlayerKey_CrossRegisterMap)
+    if playerRegisterMap in ChConfig.RegisterEnter_CrossServerMapIDList:
+        GameWorld.ErrLog("跨服已经在上传数据,不重复提交!playerRegisterMap=%s,registerMap=%s" % (playerRegisterMap, registerMap), curPlayer.GetPlayerID())
+        return
+    
+    zoneID = 0
+    if not mapID:
+        zoneIpyData = CrossRealmPlayer.GetServerCrossZoneIpyData(registerMap)
+        if not zoneIpyData:
+            GameWorld.ErrLog("找不到该服务器对应跨服分区: registerMap=%s" % (registerMap))
+            return
+        zoneID, mapID, dataMapID, copyMapID, posX, posY = zoneIpyData.GetZoneID(), zoneIpyData.GetMapID(), \
+            zoneIpyData.GetDataMapID(), zoneIpyData.GetCopyMapID(), zoneIpyData.GetPosX(), zoneIpyData.GetPosY()
+            
+    if not mapID:
         return
     
     #跨服前更新自己所属服务器组ID
-    ChPlayer.UpdatePlayerServerGroupID(curPlayer)
+    PlayerControl.UpdPlayerServerGroupID(curPlayer)
     
-    mapID, dataMapID, copyMapID, posX, posY = mapPosInfo
+    if registerMap in ChConfig.RegisterEnter_CrossServerMapIDList:
+        prepareEnterCrossServer = ChPyNetSendPack.tagMCPrepareEnterCrossServer()
+        prepareEnterCrossServer.DataMapID = registerMap
+        NetPackCommon.SendFakePack(curPlayer, prepareEnterCrossServer)
+    PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PlayerKey_CrossRegisterMap, registerMap)
     #curPlayer.SendMergeRegisterPlayer(mapID, dataMapID, copyMapID, posX, posY)
     curPlayer.SendMergeRegisterPlayerAfterChange(CrossRealmPlayer.GetCrossPlayerName(curPlayer), mapID, dataMapID, copyMapID, posX, posY)
-    GameWorld.Log("    发送跨服玩家数据注册: actionType=%s,mapID=%s,dataMapID=%s,copyMapID=%s,posX=%s,posY=%s,GetVsRoomId=%s" 
-                  % (actionType, mapID, dataMapID, copyMapID, posX, posY, curPlayer.GetVsRoomId()), playerID)
+    GameWorld.Log("    发送跨服玩家数据注册: registerMap=%s,zoneID=%s,mapID=%s,dataMapID=%s,copyMapID=%s,posX=%s,posY=%s,GetVsRoomId=%s" 
+                  % (registerMap, zoneID, mapID, dataMapID, copyMapID, posX, posY, curPlayer.GetVsRoomId()), playerID)
     return
 
 ## 跨服赛报名结果(上传数据)
@@ -75,19 +100,28 @@
 def GameServer_MergeRegisterResult(index, tick):
     registerResult = IPY_GameWorld.IPY_GMMergeRegisterPlayerResult()
     curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index)
+    registerMap = curPlayer.NomalDictGetProperty(ChConfig.Def_PlayerKey_CrossRegisterMap)
+    PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PlayerKey_CrossRegisterMap, 0)
     playerID = curPlayer.GetPlayerID()
     result = registerResult.GetResult()
+    GameWorld.Log("GameServer_MergeRegisterResult registerMap=%s,result=%s" % (registerMap, result), playerID)
     if not result:
         errorMsg = registerResult.GetErrorMsg()
         GameWorld.Log("CrossRealmReg result Error:%s" % errorMsg, playerID)
+        NetPackCommon.SendFakePack(curPlayer, ChPyNetSendPack.tagMCEnterCrossServerError())
+        return
+    
+    if registerMap in ChConfig.RegisterEnter_CrossServerMapIDList:
+        CrossRealmPlayer.DoEnterCrossRealm(curPlayer)
+        PlayerControl.SetCrossMapID(curPlayer, registerMap)
+        NetPackCommon.SendFakePack(curPlayer, ChPyNetSendPack.tagMCStartEnterCrossServer())
         return
     
     #newAccount = registerResult.GetAccount()
     #newName = registerResult.GetPwd()
     
-    msgList = str([]) 
+    msgList = str([registerMap]) 
     GameWorld.GetPlayerManager().GameServer_QueryPlayerResult(curPlayer.GetID(), 0, 0, "CrossRealmReg", msgList, len(msgList))    
-    GameWorld.Log("GameServer_MergeRegisterResult msgList=%s" % msgList, playerID)
     return
     
     

--
Gitblit v1.8.0