From c423a6c497c74ad9983e0800c9b5d7903c9f0399 Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期四, 16 十一月 2023 14:30:40 +0800
Subject: [PATCH] 5502 【BT0.1】线下活动配置(修复邮件参数充值额度数值bug及领奖广播参数;包含累计充值活动,单笔累充活动,多日连充,跨服充值排行活动)

---
 ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/CrossBattlefield.py |  273 ++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 210 insertions(+), 63 deletions(-)

diff --git a/ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/CrossBattlefield.py b/ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/CrossBattlefield.py
index 0521929..262c804 100644
--- a/ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/CrossBattlefield.py
+++ b/ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/CrossBattlefield.py
@@ -4,12 +4,12 @@
 #
 ##@package CrossBattlefield
 #
-# @todo:跨服战场
+# @todo:跨服战场/古神战场
 # @author hxp
 # @date 2022-01-06
 # @version 1.0
 #
-# 详细描述: 跨服战场
+# 详细描述: 跨服战场/古神战场
 #
 #-------------------------------------------------------------------------------
 #"""Version = 2022-01-06 20:30"""
@@ -54,6 +54,7 @@
 value2:hmNum            时分场次编号
 value3:playerID        购买的玩家ID
 value4:factionID        所选择的阵营ID
+value5:serverOnly        是否仅本服玩家可加入,0-否,1-是
 
 StrValue3:[callPlayerID,...]    召集来的玩家ID,包含自己
 '''
@@ -71,6 +72,7 @@
         self.zoneID = 0
         self.playerID = 0
         self.factionID = 0
+        self.serverOnly = 0
         self.callPlayerIDList = []
         
         # 子服用,跨服服务器同步数据时负值; 不存库,玩家属性缓存信息,本服玩家取自己服务器最新缓存
@@ -88,7 +90,7 @@
                                              "RealmLV":cacheDict["RealmLV"], "FightPower":cacheDict["FightPower"]}
             
         return {"buyTime":self.buyTime, "hmNum":self.hmNum, "zoneID":self.zoneID, "playerID":self.playerID, "factionID":self.factionID,
-                "callPlayerIDList":self.callPlayerIDList, "callPlayerDict":self.callPlayerDict}
+                "serverOnly":self.serverOnly, "callPlayerIDList":self.callPlayerIDList, "callPlayerDict":self.callPlayerDict}
         
     def SetAttr(self, attrDict):
         for k, v in attrDict.items():
@@ -112,6 +114,7 @@
         hmNum = recData.GetValue2()
         playerID = recData.GetValue3()
         factionID = recData.GetValue4()
+        serverOnly = recData.GetValue5()
         
         strValue3 = recData.GetStrValue3()
             
@@ -121,6 +124,7 @@
         buyRec.hmNum = hmNum
         buyRec.playerID = playerID
         buyRec.factionID = factionID
+        buyRec.serverOnly = serverOnly
         buyRec.callPlayerIDList = eval(strValue3) if strValue3 else []
         
         buyPlayerInfo = GetBuyPlayerInfo(zoneID, hmNum)
@@ -152,6 +156,7 @@
                 recData.SetValue2(buyRec.hmNum)
                 recData.SetValue3(buyRec.playerID)
                 recData.SetValue4(buyRec.factionID)
+                recData.SetValue5(buyRec.serverOnly)
                 
                 recData.SetStrValue3(str(buyRec.callPlayerIDList).replace(" ", ""))
                 
@@ -166,7 +171,7 @@
     if not zoneIpyData:
         return
     zoneID = zoneIpyData.GetZoneID()
-    SyncCrossBattlefieldBuyInfo(None, zoneID)
+    SyncCrossBattlefieldBuyInfo(curPlayer, zoneID)
     return
 
 def DoOnDayEx():
@@ -180,10 +185,13 @@
     if not GameWorld.IsCrossServer():
         return
     
-    enterWeekOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldBillboard", 3, {}) # 周参与榜名次对应奖励物品列表 {"名次":[[物品ID,个数,是否拍品], ...], ...} , 名次配置支持段配置
-    callWeekOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldBillboard", 4, {}) # 周召集榜名次对应奖励物品列表 {"名次":[[物品ID,个数,是否拍品], ...], ...} , 名次配置支持段配置
-    scoreWeekOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldBillboard", 5, {}) # 周参与榜名次对应奖励物品列表 {"名次":[[物品ID,个数,是否拍品], ...], ...} , 名次配置支持段配置
+    enterWeekMoneyItemID = IpyGameDataPY.GetFuncCfg("CrossBattlefieldBillboardJoin", 3) # 周参与榜额外奖励货币物品ID
+    enterWeekMoneyMultiDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldBillboardJoin", 4, {}) # 周参与榜额外奖励货币名次对应倍值
+    enterWeekOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldBillboardJoin", 2, {}) # 周参与榜名次对应奖励物品列表 {"名次":[[物品ID,个数,是否拍品], ...], ...} , 名次配置支持段配置
+    callWeekOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldBillboard", 2, {}) # 周召集榜名次对应奖励物品列表 {"名次":[[物品ID,个数,是否拍品], ...], ...} , 名次配置支持段配置
+    scoreWeekOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldBillboard", 3, {}) # 周积分榜名次对应奖励物品列表 {"名次":[[物品ID,个数,是否拍品], ...], ...} , 名次配置支持段配置
     
+    enterWeekMoneyMultiIntDict = {int(k):v for k, v in enterWeekMoneyMultiDict.items()}
     enterWeekOrderIntAwardDict = {int(k):v for k, v in enterWeekOrderAwardDict.items()}
     callWeekOrderIntAwardDict = {int(k):v for k, v in callWeekOrderAwardDict.items()}
     scoreWeekOrderIntAwardDict = {int(k):v for k, v in scoreWeekOrderAwardDict.items()}
@@ -209,11 +217,23 @@
                 if not billboardData:
                     continue
                 playerID = billboardData.ID
+                cmpValue = billboardData.CmpValue
                 rank = i + 1
-                awardItemList = GameWorld.GetOrderValueByDict(awardDict, rank)
+                awardItemList = []
+                rankAwardItemList = GameWorld.GetOrderValueByDict(awardDict, rank, False, [])
+                if rankAwardItemList:
+                    awardItemList.extend(rankAwardItemList)
                 paramList = [rank]
-                PlayerCompensation.SendMailByKey(mailKey, [playerID], awardItemList, paramList, crossMail=True)
-                    
+                if billboardType == ShareDefine.Def_CBT_BattlefieldWJoin and enterWeekMoneyItemID:
+                    moneyBaseCount, multiValue = GameWorld.GetOrderValueByDict(enterWeekMoneyMultiIntDict, rank, False, [0, 0]) # 奖励货币倍值
+                    #基础保底值(不同名次可能不一样) + 名次倍率*次数
+                    awardMoneyCount = int(moneyBaseCount + multiValue * cmpValue)
+                    awardItemList.append([enterWeekMoneyItemID, awardMoneyCount, 0])
+                GameWorld.Log("    billboardType=%s,rank=%s,playerID=%s,cmpValue=%s,awardItemList=%s" 
+                              % (billboardType, rank, playerID, cmpValue, awardItemList))
+                if awardItemList:
+                    PlayerCompensation.SendMailByKey(mailKey, [playerID], awardItemList, paramList, crossMail=True)
+                
             billboardObj.ClearData()
             
     return
@@ -387,6 +407,7 @@
             
         if openDateTime <= curDateTime < closeDateTime:
             battlefieldState = openHour * 100 + openMinute
+            PyGameData.g_openDateTime = openDateTime
             
     stateKey = ShareDefine.Def_Notify_WorldKey_DailyActionState % ShareDefine.DailyActionID_CrossBattlefield
     gameWorld = GameWorld.GetGameWorld()
@@ -404,6 +425,8 @@
     if battlefieldState and beforeState != battlefieldState:
         # 移除已经存在的副本线路
         PyGameData.g_crossDynamicLineInfo.pop(ChConfig.Def_FBMapID_CrossBattlefield, None)
+        
+        PyGameData.g_overPlayerIDList = []
         
         crossZoneName = GameWorld.GetCrossZoneName()
         crossZoneList = IpyGameDataPY.GetIpyGameDataByCondition("CrossZonePK", {"CrossZoneName":crossZoneName}, True)
@@ -469,13 +492,8 @@
                 GameWorld.DebugLog("跨服PK赛季未开启中,跨服战场系统开启广播不处理!")
                 continue
             
-            notifyKey = "CrossBattlefieldOpenSys"
-            paramList = [notifyOpenMinute]
-            country = 0
-            serverGroupIDList = []
-            crossNotifyList = []
-            crossNotifyList.append([ShareDefine.CrossNotify_World, [country, notifyKey, paramList]])
-            PlayerControl.CrossNotifyEx(serverGroupIDList, crossNotifyList)
+            serverGroupIDList = zoneIpyData.GetServerGroupIDList()
+            PlayerControl.WorldNotifyCross(serverGroupIDList, 0, "CrossBattlefieldOpenSys", [notifyOpenMinute])
             
         return
     
@@ -489,41 +507,38 @@
             continue
         
         zoneIpyData = CrossRealmPlayer.GetCrossZoneIpyDataByZoneID(ChConfig.Def_FBMapID_CrossBattlefield, zoneID)
-        if zoneIpyData:
+        if not zoneIpyData:
             continue
         serverGroupIDList = zoneIpyData.GetServerGroupIDList()
         
         if curHMNum not in buyHMInfo:
             continue
         
-        buyPlayerInfo = buyHMInfo[curHMNum]
-        if not buyPlayerInfo:
-            continue
-        
-        matchTickSortList = sorted(buyPlayerInfo.values(), key=operator.attrgetter("buyTime"))
-        buyRec = matchTickSortList[0]
-        
-        notifyKey = "CrossBattlefieldOpenPlayer"
-        paramList = [buyRec.playerName, notifyOpenMinute]
-        country = 0
-        crossNotifyList = []
-        crossNotifyList.append([ShareDefine.CrossNotify_World, [country, notifyKey, paramList]])
-        PlayerControl.CrossNotifyEx(serverGroupIDList, crossNotifyList)
+        PlayerControl.WorldNotifyCross(serverGroupIDList, 0, "CrossBattlefieldOpenSys", [notifyOpenMinute])
         
     return
 
-def GetCrossBattlefieldOpenTime(zoneID):
+def GetCrossBattlefieldOpenTime(serverGroupID, zoneID, playerID):
     ## 获取跨服战场副本当前是否开放的时间点
     #  @return: None-当前未开放;
-    #  @return: hour, minute  -  当前开放中的时间时分,可进入
+    #  @return: isCallBattle, openHour, openMinute  -  当前开放中的时间时分,可进入
     
     gameWorld = GameWorld.GetGameWorld()
     hmNum = GetCrossBattlefieldState()
     if not hmNum:
+        GameWorld.Log("当前时间战场未开启!", playerID)
+        PlayerControl.NotifyCodeCross(serverGroupID, playerID, "FBIsNotOpen")
         return
     
     seasonState = gameWorld.GetDictByKey(ChConfig.Def_WorldKey_CrossPKZoneSeasonState % zoneID)
     if seasonState != 1:
+        GameWorld.Log("赛季未开启!", playerID)
+        PlayerControl.NotifyCodeCross(serverGroupID, playerID, "NotifySeasonOver")
+        return
+    
+    if playerID in PyGameData.g_overPlayerIDList:
+        # 您已经参加过该场次,无法再进入!
+        PlayerControl.NotifyCodeCross(serverGroupID, playerID, "CrossBattlefieldAlreadyJoin")
         return
     
     openHour, openMinute = GetHMByNum(hmNum)
@@ -531,12 +546,48 @@
     isCallBattle = [openHour, openMinute] not in sysOpenHMList
     if isCallBattle:
         if zoneID not in PyGameData.g_crossBattlefieldBuyInfo:
-            GameWorld.DebugLog("该分区没有使用召集令! zoneID=%s" % zoneID)
+            GameWorld.Log("该分区没有使用召集令! zoneID=%s" % zoneID, playerID)
+            PlayerControl.NotifyCodeCross(serverGroupID, playerID, "FBIsNotOpen")
             return
         buyHMInfo = PyGameData.g_crossBattlefieldBuyInfo[zoneID]
         if hmNum not in buyHMInfo:
-            GameWorld.DebugLog("该时段还未使用召集令! zoneID=%s,hmNum=%s" % (zoneID, hmNum))
+            GameWorld.Log("该时段还未使用召集令! zoneID=%s,hmNum=%s" % (zoneID, hmNum), playerID)
+            PlayerControl.NotifyCodeCross(serverGroupID, playerID, "FBIsNotOpen")
             return
+        
+        # 召集场只有一条线,如果有人结算则代表已经结束了
+        if PyGameData.g_overPlayerIDList:
+            # 该召集场次已结算,无法进入!
+            PlayerControl.NotifyCodeCross(serverGroupID, playerID, "CrossBattlefieldCallOver")
+            return
+        
+    if PyGameData.g_openDateTime:
+        serverTime = GameWorld.GetServerTime()
+        passSeconds = (serverTime - PyGameData.g_openDateTime).seconds
+        closeEnterMinutes = IpyGameDataPY.GetFuncCfg("CrossBattlefieldOpen", 5) # 开启X分钟后不可进入,不包含已进入玩家及召集队伍中的玩家
+        closeSeconds = closeEnterMinutes * 60
+        if passSeconds > closeSeconds:
+            GameWorld.DebugLog("迟到了! passSeconds=%s > %s" % (passSeconds, closeSeconds), playerID)
+            isBelate = True
+            for _, copyMapObj in PyGameData.g_crossDynamicLineCopyMapInfo.items():
+                if copyMapObj.IsMustCopyMapPlayer(playerID):
+                    isBelate = False
+                    GameWorld.DebugLog("已进入的重复进入不限制时间!  playerID=%s" % playerID)
+                    break
+                
+            if isCallBattle:
+                buyPlayerInfo = buyHMInfo[hmNum]
+                for buyRec in buyPlayerInfo.values():
+                    if playerID in buyRec.callPlayerIDList:
+                        isBelate = False
+                        GameWorld.DebugLog("召集令成员不受人时间限制!  playerID=%s" % playerID)
+                        break
+                    
+            if isBelate:
+                PlayerControl.NotifyCodeCross(serverGroupID, playerID, "CrossBattlefieldBelate", [closeEnterMinutes])
+                return
+        #else:
+        #    GameWorld.DebugLog("没有迟到!passSeconds=%s <= %s" % (passSeconds, closeSeconds), playerID)
         
     return isCallBattle, openHour, openMinute
 
@@ -614,6 +665,7 @@
     openHour = msgData["openHour"]
     openMinute = msgData["openMinute"]
     faction = msgData["faction"]
+    serverOnly = msgData.get("serverOnly", 0)
     
     hmNum = GetHMNum(openHour, openMinute)
     
@@ -629,16 +681,16 @@
         return
     
     curFactionCount, othFactionCount = 0, 0
-    for callPlayerID, buyRec in buyPlayerInfo.items():
+    for _, buyRec in buyPlayerInfo.items():
         if buyRec.factionID == faction:
             curFactionCount += 1
         else:
             othFactionCount += 1
             
-        if playerID in buyRec.callPlayerIDList:
-            GameWorld.Log("玩家已经在该召集场次阵营里! zoneID=%s,openHour=%s,openMinute=%s,callPlayerID=%s,callPlayerIDList=%s" 
-                          % (zoneID, openHour, openMinute, callPlayerID, buyRec.callPlayerIDList), playerID)
-            return
+#        if playerID in buyRec.callPlayerIDList:
+#            GameWorld.Log("玩家已经在该召集场次阵营里! zoneID=%s,openHour=%s,openMinute=%s,callPlayerID=%s,callPlayerIDList=%s" 
+#                          % (zoneID, openHour, openMinute, callPlayerID, buyRec.callPlayerIDList), playerID)
+#            return
         
     if curFactionCount > othFactionCount:
         GameWorld.Log("阵营平衡限制,不可再购买该跨服战场阵营! zoneID=%s,openHour=%s,openMinute=%s,faction=%s,curFactionCount(%s) > othFactionCount(%s)" 
@@ -666,16 +718,27 @@
     buyRec.playerID = playerID
     buyRec.factionID = faction
     buyRec.callPlayerIDList = [playerID]
+    buyRec.serverOnly = serverOnly
     buyPlayerInfo[playerID] = buyRec
     
+    GameWorld.DebugLog("玩家购买开启召集场次! zoneID=%s,openHour=%s,openMinute=%s,faction=%s,serverOnly=%s" 
+                       % (zoneID, openHour, openMinute, faction, serverOnly), playerID)
+    
     # 上榜
-    billboardCallCountLimit = IpyGameDataPY.GetFuncCfg("CrossBattlefieldBillboard", 2) # 周召集榜上榜至少次数
+    billboardCallCountLimit = IpyGameDataPY.GetFuncCfg("CrossBattlefieldBillboard", 1) # 周召集榜上榜至少次数
     groupValue1, dataID, name1, name2 = zoneID, playerID, playerName, ""
     type2, value1, value2 = job, realmLV, 0
     cmpValue = buyOpenCountWeek + 1
     if cmpValue >= billboardCallCountLimit:
         CrossBillboard.UpdCrossBillboard(ShareDefine.Def_CBT_BattlefieldWCall, groupValue1, dataID, name1, name2, type2, value1, value2, cmpValue)
         
+    for otherBuyPlayerID, otherRec in buyPlayerInfo.items():
+        if otherBuyPlayerID == playerID:
+            continue
+        if playerID in otherRec.callPlayerIDList:
+            otherRec.callPlayerIDList.remove(playerID)
+            GameWorld.DebugLog("    从已加入的其他召集队伍移除: otherBuyPlayerID=%s,playerID=%s" % (otherBuyPlayerID, playerID), playerID)
+            
     SyncMapServerCrossBattlefieldBuyInfo()
     
     # 通知子服
@@ -700,6 +763,9 @@
     
     hmNum = GetHMNum(openHour, openMinute)
     buyPlayerInfo = GetBuyPlayerInfo(zoneID, hmNum)
+    if tagPlayerID in buyPlayerInfo:
+        GameWorld.ErrLog("玩家已购买该场次召集队伍,无法加入其他召集队伍! hmNum=%s,tagPlayerID=%s in %s" % (hmNum, tagPlayerID, buyPlayerInfo.keys()), playerID)
+        return
     if buyPlayerID not in buyPlayerInfo:
         GameWorld.ErrLog("跨服战场不存在该玩家的召集队伍! hmNum=%s,buyPlayerID=%s" % (hmNum, buyPlayerID), playerID)
         return
@@ -710,9 +776,19 @@
         GameWorld.ErrLog("跨服战场召集人数已满! hmNum=%s,buyPlayerID=%s,callPlayerIDList=%s" % (hmNum, buyPlayerID, buyRec.callPlayerIDList), playerID)
         return
     
+    GameWorld.DebugLog("玩家加入召集队伍! zoneID=%s,openHour=%s,openMinute=%s,buyPlayerID=%s,tagPlayerID=%s" 
+                       % (zoneID, openHour, openMinute, buyPlayerID, tagPlayerID), playerID)
+    
     if tagPlayerID not in buyRec.callPlayerIDList:
         buyRec.callPlayerIDList.append(tagPlayerID)
         
+    for otherBuyPlayerID, otherRec in buyPlayerInfo.items():
+        if otherBuyPlayerID == buyPlayerID:
+            continue
+        if tagPlayerID in otherRec.callPlayerIDList:
+            otherRec.callPlayerIDList.remove(tagPlayerID)
+            GameWorld.DebugLog("    从已加入的其他召集队伍移除: otherBuyPlayerID=%s,tagPlayerID=%s" % (otherBuyPlayerID, tagPlayerID), playerID)
+            
     SyncMapServerCrossBattlefieldBuyInfo()
     
     serverGroupIDList = zoneIpyData.GetServerGroupIDList()
@@ -747,6 +823,9 @@
         return
     buyRec.callPlayerIDList.remove(tagPlayerID)
     
+    GameWorld.DebugLog("玩家召集队伍踢人! zoneID=%s,openHour=%s,openMinute=%s,buyPlayerID=%s,tagPlayerID=%s" 
+                       % (zoneID, openHour, openMinute, buyPlayerID, tagPlayerID), playerID)
+    
     SyncMapServerCrossBattlefieldBuyInfo()
     
     serverGroupIDList = zoneIpyData.GetServerGroupIDList()
@@ -754,13 +833,42 @@
     Send_CrossServerMsg_BattlefieldBuy(zoneID, serverGroupIDList, msgData)
     return
 
+def ClientServerMsg_BattlefieldCallChange(serverGroupID, msgData):
+    
+    openHour = msgData["openHour"]
+    openMinute = msgData["openMinute"]
+    serverOnly = msgData["serverOnly"]
+    playerID = msgData["playerID"]
+    
+    zoneIpyData = CrossRealmPK.GetCrossPKServerGroupZone(serverGroupID)
+    if not zoneIpyData:
+        return
+    zoneID = zoneIpyData.GetZoneID()
+    
+    hmNum = GetHMNum(openHour, openMinute)
+    buyPlayerInfo = GetBuyPlayerInfo(zoneID, hmNum)
+    if playerID not in buyPlayerInfo:
+        GameWorld.ErrLog("跨服战场不存在该玩家的召集队伍! hmNum=%s,playerID=%s" % (hmNum, playerID), playerID)
+        return
+    buyRec = buyPlayerInfo[playerID]
+    buyRec.serverOnly = 1 if serverOnly else 0
+    
+    GameWorld.DebugLog("玩家召集队伍修改! zoneID=%s,openHour=%s,openMinute=%s,serverOnly=%s" 
+                       % (zoneID, openHour, openMinute, serverOnly), playerID)
+    
+    #SyncMapServerCrossBattlefieldBuyInfo()
+    
+    serverGroupIDList = zoneIpyData.GetServerGroupIDList()
+    msgData.update({"opType":"CallChange"})
+    Send_CrossServerMsg_BattlefieldBuy(zoneID, serverGroupIDList, msgData)
+    return
+
 def MapServer_CrossBattlefieldOver(msgList):
     ## 跨服战场地图结算
     overTime = int(time.time())
-    hmNum = GetCrossBattlefieldState()
-    fbPropertyID, zoneID, funcLineID, winnerFaction, superItemInfo, superItemPlayerID, superItemPlayerName, scoreKingID, scoreKingName, battlePlayerList = msgList
-    GameWorld.Log("跨服战场地图同步结果: hmNum=%s,zoneID=%s,funcLineID=%s,winnerFaction=%s,superItemInfo=%s,superItemPlayerID=%s,scoreKingID=%s,battlePlayerCount=%s" 
-                  % (hmNum, zoneID, funcLineID, winnerFaction, superItemInfo, superItemPlayerID, scoreKingID, len(battlePlayerList)), fbPropertyID)
+    hmNum, fbPropertyID, zoneID, funcLineID, winnerFaction, superItemInfo, finalSuperItemPlayerID, finalSuperItemPlayerName, superItemPlayerIDList, scoreKingID, scoreKingName, battlePlayerList = msgList
+    GameWorld.Log("跨服战场地图同步结果: hmNum=%s,zoneID=%s,funcLineID=%s,winnerFaction=%s,superItemInfo=%s,finalSuperItemPlayerID=%s,superItemPlayerIDList=%s,scoreKingID=%s,battlePlayerCount=%s" 
+                  % (hmNum, zoneID, funcLineID, winnerFaction, superItemInfo, finalSuperItemPlayerID, superItemPlayerIDList, scoreKingID, len(battlePlayerList)), fbPropertyID)
     
     winnerOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldAward", 2, {}) # 胜利方名次对应奖励物品列表 {"名次":[[物品ID,个数,是否拍品], ...], ...} , 名次配置支持段配置
     loserOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossBattlefieldAward", 3, {}) # 失败方名次对应奖励物品列表 {"名次":[[物品ID,个数,是否拍品], ...], ...} , 名次配置支持段配置
@@ -770,29 +878,34 @@
     winnerOrderIntAwardDict = {int(k):v for k, v in winnerOrderAwardDict.items()}
     loserOrderIntAwardDict = {int(k):v for k, v in loserOrderAwardDict.items()}
     
-    billboardEnterCountLimit = IpyGameDataPY.GetFuncCfg("CrossBattlefieldBillboard", 1) # 周参与榜上榜至少次数
+    billboardEnterCountLimit = IpyGameDataPY.GetFuncCfg("CrossBattlefieldBillboardJoin", 1) # 周参与榜上榜至少次数
     
     syncPlayerDataInfo = {}
     winnerPlayerIDList, loserPlayerIDList = [], []
     for playerInfo in battlePlayerList:
-        faction, rank, playerID, job, realmLV, name, score, highScoreToday, highScoreWeekTotal, enterCountWeek, isCallEnter = playerInfo
+        playerID, job, realmLV, name, \
+            isWinner, faction, rank, score, highScoreToday, highScoreWeekTotal, enterCountWeek, \
+            isCallOpen, isCalled, killCnt, ckillCntInfo, killBossCnt, killScoreKing, killGuardCnt, auraScore, superItemAwardCnt, \
+            factionBuffCollCnt, personBuffCollCnt, crystalCollCnt, wallCollCnt \
+                = playerInfo
+            
+        PyGameData.g_overPlayerIDList.append(playerID)
         
-        isWinner = 0
         paramList = [rank]
         if faction == winnerFaction:
-            isWinner = 1
             winnerPlayerIDList.append(playerID)
             orderAwardMailKey = "CrossBattlefieldOrderWin"
-            orderAwardItemList = GameWorld.GetOrderValueByDict(winnerOrderIntAwardDict, rank)
+            orderAwardItemList = GameWorld.GetOrderValueByDict(winnerOrderIntAwardDict, rank, False)
             GameWorld.Log("    获胜阵营玩家: faction=%s,rank=%s,playerID=%s" % (faction, rank, playerID), fbPropertyID)
         else:
             loserPlayerIDList.append(playerID)
             orderAwardMailKey = "CrossBattlefieldOrderLose"
-            orderAwardItemList = GameWorld.GetOrderValueByDict(loserOrderIntAwardDict, rank)
+            orderAwardItemList = GameWorld.GetOrderValueByDict(loserOrderIntAwardDict, rank, False)
             GameWorld.Log("    失败阵营玩家: faction=%s,rank=%s,playerID=%s" % (faction, rank, playerID), fbPropertyID)
             
         # 排名奖励邮件
-        PlayerCompensation.SendMailByKey(orderAwardMailKey, [playerID], orderAwardItemList, paramList, crossMail=True)
+        if orderAwardItemList:
+            PlayerCompensation.SendMailByKey(orderAwardMailKey, [playerID], orderAwardItemList, paramList, crossMail=True)
         
         # 更新周参与榜单
         groupValue1, dataID, name1, name2 = zoneID, playerID, name, ""
@@ -809,10 +922,12 @@
             cmpValue = highScoreWeekTotal
             CrossBillboard.UpdCrossBillboard(ShareDefine.Def_CBT_BattlefieldWScore, groupValue1, dataID, name1, name2, type2, value1, value2, cmpValue)
             
-        GameWorld.Log("    战场阵营玩家: faction=%s,isWinner=%s,rank=%s,playerID=%s,score=%s,highScoreToday=%s,highScoreWeekTotal=%s,enterCountWeek=%s,isCallEnter=%s" 
-                      % (faction, isWinner, rank, playerID, score, highScoreToday, highScoreWeekTotal, enterCountWeek, isCallEnter), fbPropertyID)
+        GameWorld.Log("    战场阵营玩家: faction=%s,isWinner=%s,rank=%s,playerID=%s,score=%s,highScoreToday=%s,highScoreWeekTotal=%s,enterCountWeek=%s,isCallOpen=%s,isCalled=%s" 
+                      % (faction, isWinner, rank, playerID, score, highScoreToday, highScoreWeekTotal, enterCountWeek, isCallOpen, isCalled), fbPropertyID)
         
-        syncPlayerDataInfo[playerID] = [highScoreToday, highScoreWeekTotal, enterCountWeek, isCallEnter]
+        syncPlayerDataInfo[playerID] = [isWinner, faction, rank, score, highScoreToday, highScoreWeekTotal, enterCountWeek,
+                                        isCallOpen, isCalled, killCnt, ckillCntInfo, killBossCnt, killScoreKing, killGuardCnt, auraScore, superItemAwardCnt, 
+                                        factionBuffCollCnt, personBuffCollCnt, crystalCollCnt, wallCollCnt]
         
     # 参与奖励邮件
     if winnerPlayerIDList:
@@ -822,9 +937,10 @@
     
     # 大奖获得者邮件
     superItemID, superItemCount = 0, 0
-    if superItemPlayerID and superItemInfo and len(superItemInfo) == 3:
+    if superItemPlayerIDList and superItemInfo and len(superItemInfo) == 3:
         superItemID, superItemCount = superItemInfo[0], superItemInfo[1]
-        PlayerCompensation.SendMailByKey("CrossBattlefieldSuperAward", [superItemPlayerID], [superItemInfo], crossMail=True)
+        for superItemPlayerID in superItemPlayerIDList:
+            PlayerCompensation.SendMailByKey("CrossBattlefieldSuperAward", [superItemPlayerID], [superItemInfo], crossMail=True)
         
     crossZoneName = GameWorld.GetCrossZoneName()
     zoneIpyData = IpyGameDataPY.GetIpyGameData("CrossZonePK", crossZoneName, zoneID)
@@ -847,8 +963,8 @@
         nextBattleTimeStr = "%02d:%02d" % (nextOpenHour, nextOpenMinute)
         
     # 本分区全服:XX阵营胜利,xxx为本场积分王,xxx获得了古神大奖XXX,下个场次预计将在XX点开放。
-    if battlePlayerList:
-        msgParamList = [winnerFaction, scoreKingName, superItemPlayerName, superItemID, superItemCount, nextBattleTimeStr]
+    if finalSuperItemPlayerName:
+        msgParamList = [winnerFaction, scoreKingName, finalSuperItemPlayerName, superItemID, superItemCount, nextBattleTimeStr]
         PlayerControl.WorldNotifyCross(serverGroupIDList, 0, "CrossBattlefieldOver", msgParamList)
     return
 
@@ -887,10 +1003,9 @@
         return
     
     for playerID, playerData in syncPlayerDataInfo.items():
-        highScoreToday, highScoreWeekTotal, enterCountWeek, isCallEnter = playerData
         if PlayerControl.GetDBPlayerAccIDByID(playerID):
-            msgInfo = ["BattlefieldOver", [overTime, highScoreToday, highScoreWeekTotal, enterCountWeek, isCallEnter]]
-            CrossRealmPlayer.MapServer_QueryCrossPlayerResult(playerID, "CrossBattlefield", msgInfo)
+            msgInfo = ["BattlefieldOver", [overTime] + playerData]
+            CrossRealmPlayer.MapServer_QueryCrossPlayerResult(playerID, "CrossBattlefield", msgInfo, True)
             
     return
 
@@ -947,6 +1062,9 @@
     elif opType == "CallKick":
         pass
     
+    elif opType == "CallChange":
+        pass
+    
     return
 
 def SyncCrossBattlefieldBuyInfo(curPlayer, zoneID, hmNum=None):
@@ -969,6 +1087,7 @@
             buyPlayerPack = ChPyNetSendPack.tagGCCrossBattlefieldBuyPlayer()
             buyPlayerPack.BuyPlayerID = buyPlayerID
             buyPlayerPack.Faction = buyRec.factionID
+            buyPlayerPack.ServerOnly = buyRec.serverOnly
             buyPlayerPack.FactionPlayerList = []
             
             for callPlayerID in buyRec.callPlayerIDList:
@@ -1054,6 +1173,11 @@
         GameWorld.DebugLog("召集人数已满! hmNum=%s,buyPlayerID=%s,callPlayerIDList=%s" % (hmNum, buyPlayerID, buyRec.callPlayerIDList), playerID)
         return
     
+    if buyRec.serverOnly and not PlayerControl.GetDBPlayerAccIDByID(buyPlayerID):
+        PlayerControl.NotifyCode(curPlayer, "CrossBattlefieldCallServerOnly")
+        #GameWorld.DebugLog("非本服玩家,无法加入其购买的召集队伍! hmNum=%s,buyPlayerID=%s,serverOnly=%s" % (hmNum, buyPlayerID, buyRec.serverOnly), playerID)
+        return
+    
     # 请求查询跨服服务器
     dataMsg = {"openHour":openHour, "openMinute":openMinute, "buyPlayerID":buyPlayerID, "tagPlayerID":tagPlayerID, "playerID":playerID}
     CrossRealmMsg.SendMsgToCrossServer(ShareDefine.ClientServerMsg_BattlefieldCallJoin, dataMsg)
@@ -1079,7 +1203,7 @@
     openMinute = clientData.Minute
     tagPlayerID = clientData.TagPlayerID
     buyPlayerID = playerID
-    
+    GameWorld.DebugLog("召集场次踢人: tagPlayerID=%s,openHour=%s,openMinute=%s" % (tagPlayerID, openHour, openMinute), playerID)
     if buyPlayerID == tagPlayerID:
         return
     
@@ -1118,3 +1242,26 @@
     CrossRealmMsg.SendMsgToCrossServer(ShareDefine.ClientServerMsg_BattlefieldCallKick, dataMsg)
     return
 
+#// C0 09 跨服战场召集场次修改 #tagCGCrossBattlefieldCallChange
+#
+#struct    tagCGCrossBattlefieldCallChange
+#{
+#    tagHead        Head;
+#    BYTE    Hour;        //战场开启时
+#    BYTE    Minute;        //战场开启分
+#    BYTE    ServerOnly;    //是否仅本服玩家可加入,0-否,1-是
+#};
+def OnCrossBattlefieldCallChange(index, clientData, tick):
+    if GameWorld.IsCrossServer():
+        return
+    
+    curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index)
+    playerID = curPlayer.GetPlayerID()
+    openHour = clientData.Hour
+    openMinute = clientData.Minute
+    serverOnly = clientData.ServerOnly
+    
+    # 请求查询跨服服务器
+    dataMsg = {"openHour":openHour, "openMinute":openMinute, "serverOnly":serverOnly, "playerID":playerID}
+    CrossRealmMsg.SendMsgToCrossServer(ShareDefine.ClientServerMsg_BattlefieldCallChange, dataMsg)
+    return

--
Gitblit v1.8.0