From e718ef8d79b1d1a7f546ec686b70e752cb60e3fa Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期一, 08 七月 2024 18:50:47 +0800
Subject: [PATCH] 10196 【越南】【香港】【主干】【砍树】增加地图数量开启警告

---
 ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/GameWorldActionControl.py |  225 +++++++++++++++++++++++++++++++-------------------------
 1 files changed, 125 insertions(+), 100 deletions(-)

diff --git a/ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/GameWorldActionControl.py b/ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/GameWorldActionControl.py
index 277b74b..c89e50d 100644
--- a/ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/GameWorldActionControl.py
+++ b/ServerPython/CoreServerGroup/GameServer/Script/GameWorldLogic/GameWorldActionControl.py
@@ -33,7 +33,9 @@
 import PlayerFamilyRedPacket
 import PlayerFairyCeremony
 import PlayerNewFairyCeremony
+import PlayerActFamilyCTGAssist
 import PlayerActGarbageSorting
+import PlayerActBossTrial
 import PlayerUniversalGameRec
 import GameWorldAverageLv
 import PlayerFamilyBoss
@@ -65,7 +67,10 @@
         # 跨服不处理运营活动
         return
     
-    isReload, OperationActionInfo = __GetOperationActionInfo()
+    # 玩家登录的不触发重载活动,不然刚好在0点服务器处理OnDay之前登录的时候会有问题
+    isReload, OperationActionInfo = __GetOperationActionInfo(needReload=False)
+    if not OperationActionInfo:
+        return
     operationActionDict = OperationActionInfo[OperationAction_TodayInfo]
     
     if isReload:
@@ -105,10 +110,11 @@
 def SendMapServerOperationActionState():
     # 地图启动成功时通知本日运行活动相关状态
     
+    CrossActionControl.SendMapServerCrossActionState()
+    
     if GameWorld.IsCrossServer():
         # 跨服不处理运营活动
         return
-    CrossActionControl.SendMapServerCrossActionState()
     
     isReload, OperationActionInfo = __GetOperationActionInfo()
     mapServerInfoDict = OperationActionInfo[OperationAction_MapServerInfo]
@@ -138,7 +144,7 @@
         
         活动分组编号 = 活动类型 * 10 + 不同界面编号
     '''
-    if ipyData and hasattr(ipyData, "ActNum"):
+    if ipyData and hasattr(ipyData, "GetActNum"):
         return ipyData.GetActNum()
     
     # 原节日活动的还是默认节日活动
@@ -189,7 +195,7 @@
                       % (actName, cfgID, recStartDateStr, recEndDateStr, recLimitWorldLV, recWorldLV))
     return actWorldLVLimitInfo
 
-def __GetOperationActionInfo(isRefreshState=True):
+def __GetOperationActionInfo(isRefreshState=True, needReload=True):
     # @return: isReload, OperationActionInfo
     
     key = "OperationActionInfo"
@@ -203,6 +209,9 @@
     reloadSign = [openServerDay, isMixServer, mixServerDay, reloadSignHour]
     if OperationActionInfo and OperationActionInfo[OperationAction_ReloadSign] == reloadSign:
         #GameWorld.DebugLog("已经加载过本日运营活动处理信息!openServerDay=%s" % openServerDay)
+        return False, OperationActionInfo
+    
+    if not needReload:
         return False, OperationActionInfo
     
     # 因为后面的时间判断都是精确到分的,而处理此逻辑的时候可能不是0秒,所以这里的datetime取当前时间精确到分的
@@ -239,9 +248,9 @@
         
         for ipyData in curServerActIpyDataList:
             
-            platformList = [] if not hasattr(ipyData, "PlatformList") else ipyData.GetPlatformList()
-            serverGroupIDList = [] if not hasattr(ipyData, "ServerGroupIDList") else ipyData.GetServerGroupIDList()
-            serverGroupIDListExcept = [] if not hasattr(ipyData, "ServerGroupIDListExcept") else ipyData.GetServerGroupIDListExcept()
+            platformList = [] if not hasattr(ipyData, "GetPlatformList") else ipyData.GetPlatformList()
+            serverGroupIDList = [] if not hasattr(ipyData, "GetServerGroupIDList") else ipyData.GetServerGroupIDList()
+            serverGroupIDListExcept = [] if not hasattr(ipyData, "GetServerGroupIDListExcept") else ipyData.GetServerGroupIDListExcept()
             cfgID = ipyData.GetCfgID()
             startDateStr = ipyData.GetStartDate()
             endDateStr = ipyData.GetEndDate()
@@ -250,6 +259,8 @@
             GameWorld.Log("    cfgID=%s,actNum=%s,startDateStr=%s,endDateStr=%s,openServerDay=%s,isMixServer=%s,mixServerDay=%s,curDateTime=%s,platformList=%s,serverGroupIDList=%s,Except=%s" 
                           % (cfgID, actNum, startDateStr, endDateStr, openServerDay, isMixServer, mixServerDay, curDateTime, platformList, serverGroupIDList, serverGroupIDListExcept))
             
+            actIDDateTimeSpec = None # 特殊指定的活动ID日期
+            startDateSync = None # 特殊同步前端显示用的开始日期,一般用于与开服前X天交叉的活动
             if actName in ShareDefine.MultiActNumOperationActNameList:
                 # 多活动分组编号的需要把所有配置的 actNum 都登记进来,以确保地图能正确进行逻辑
                 if actNum not in mapServerOperationActionDict[actName]:
@@ -316,6 +327,22 @@
                         if not isDayRest and actName not in startDateInCustomCanOpenList:
                             GameWorld.Log("        按日期/周开的开始日期在开服定制限制天内,不处理! cfgID=%s,curServerOpenDateTime=%s<=curStartDateTime=%s<=customMaxServerDateTime=%s" % (cfgID, curServerOpenDateTime, curStartDateTime, customMaxServerDateTime))
                             continue
+                        
+                        # 非每日重置的 且 开始天在定制天内在定制天结束后可继续开启的活动
+                        # 注: 为防止开始日期与开服天内的活动开始天对应日期刚好同一天导致活动ID一样,所以这里默认将开始日期改为定制天后一天
+                        if not isDayRest and actName in startDateInCustomCanOpenList:
+                            actIDDateTimeSpec = datetime.datetime.strptime("%d-%d-%d 00:00:00" 
+                                                                           % (customMaxServerDateTime.year, customMaxServerDateTime.month, customMaxServerDateTime.day), 
+                                                                           ChConfig.TYPE_Time_Format) + datetime.timedelta(days=1)
+                            GameWorld.Log("        开服天后可开启的非每日重置活动! 活动ID日期特殊设置为开服定制天结束后一天! cfgID=%s,actIDDateTimeSpec=%s" % (cfgID, actIDDateTimeSpec))
+                            
+                        # 特殊同步的开始日期,无视是否每日重置
+                        if actName in startDateInCustomCanOpenList:
+                            startDateSync = datetime.datetime.strptime("%d-%d-%d 00:00:00" 
+                                                                       % (customMaxServerDateTime.year, customMaxServerDateTime.month, customMaxServerDateTime.day), 
+                                                                       ChConfig.TYPE_Time_Format) + datetime.timedelta(days=1)
+                            startDateSync = "%d-%d-%d" % (startDateSync.year, startDateSync.month, startDateSync.day)
+                            
                 else:
                     GameWorld.Log("        开服常规活动,配置时间格式不支持,不处理! cfgID=%s,startDateStr=%s,endDateStr=%s" % (cfgID, startDateStr, endDateStr))
                     continue
@@ -349,6 +376,13 @@
                 GameWorld.Log("        非法配置,未知活动类型,不处理! cfgID=%s,actNum=%s" % (cfgID, actNum))
                 continue
             
+            if hasattr(ipyData, "GetJoinStartTime") and hasattr(ipyData, "GetJoinEndTime"):
+                joinStartTimeStr = ipyData.GetJoinStartTime()
+                joinEndTimeStr = ipyData.GetJoinEndTime()
+            else:
+                joinStartTimeStr = ""
+                joinEndTimeStr = ""
+                
             if hasattr(ipyData, "GetStartTimeList") and hasattr(ipyData, "GetEndTimeList"):
                 startHMStrList = ipyData.GetStartTimeList()
                 endHMStrList = ipyData.GetEndTimeList()
@@ -365,6 +399,7 @@
                                  % (actName, cfgID, startHMStrList, endHMStrList))
                 continue
             
+            isDayRest = 0 if not hasattr(ipyData, "GetIsDayReset") else ipyData.GetIsDayReset()
             resetType = 0 if not hasattr(ipyData, "GetResetType") else ipyData.GetResetType() # 重置类型,0-0点重置;1-5点重置
             if resetType == 1:
                 startDayDate = datetime.datetime.strptime("%s 05:00:00" % (startDateStr), ChConfig.TYPE_Time_Format)
@@ -472,6 +507,17 @@
             GameWorld.Log("        startList=%s" % (startList))
             GameWorld.Log("        end  List=%s" % (endList))
             
+            joinStartTimeList, joinEndTimeList = [], [] # 可指定活动可参与的时间点,不影响活动状态,只影响活动某些功能的参与时机,如上榜类
+            if joinStartTimeStr:
+                if isDayRest:
+                    joinStartTimeList.append(datetime.datetime.strptime("%d-%d-%d %s:00" % (curDateTime.year, curDateTime.month, curDateTime.day, joinStartTimeStr), ChConfig.TYPE_Time_Format))
+                    joinEndTimeList.append(datetime.datetime.strptime("%d-%d-%d %s:00" % (curDateTime.year, curDateTime.month, curDateTime.day, joinEndTimeStr), ChConfig.TYPE_Time_Format))
+                else:
+                    joinStartTimeList.append(datetime.datetime.strptime("%s %s:00" % (startDateStr, joinStartTimeStr), ChConfig.TYPE_Time_Format))
+                    joinEndTimeList.append(datetime.datetime.strptime("%s %s:00" % (endDateStr, joinEndTimeStr), ChConfig.TYPE_Time_Format))                    
+            GameWorld.Log("        joinStartTimeList=%s" % (joinStartTimeList))
+            GameWorld.Log("        joinEndTime  List=%s" % (joinEndTimeList))
+            
             for dtIndex, startDateTime in enumerate(startList):
                 endDateTime = endList[dtIndex]
                 # 广播 - 相对实际开始时间
@@ -517,9 +563,9 @@
             if actName in ShareDefine.MultiActNumOperationActNameList:
                 if actName not in operationTodayActionDict:
                     operationTodayActionDict[actName] = {} # 今日有需要处理的才初始化
-                operationTodayActionDict[actName][actNum] = [ipyData, startList, endList, notifyDict]
+                operationTodayActionDict[actName][actNum] = [ipyData, startList, endList, notifyDict, joinStartTimeList, joinEndTimeList]
             else:
-                operationTodayActionDict[actName] = [ipyData, startList, endList, notifyDict]
+                operationTodayActionDict[actName] = [ipyData, startList, endList, notifyDict, joinStartTimeList, joinEndTimeList]
                 
             if isActTime:
                 activityInfoDict = {ShareDefine.ActKey_CfgID:cfgID, ShareDefine.ActKey_ActNum:actNum}
@@ -527,12 +573,17 @@
                     #活动每天的世界等级
                     activityInfoDict[ShareDefine.ActKey_WorldLVList] = GameWorldAverageLv.GetWorldLVListByTime(startDayDate, (endDayDate - startDayDate).days)
                     
+                if startDateSync:
+                    activityInfoDict[ShareDefine.ActKey_StartDateSync] = startDateSync
+                    GameWorld.Log("        startDateSync=%s" % (startDateSync))
+                    
                 dayIndex = (curDateTime - startDayDate).days
                 actIDDateTime = startDayDate
-                isDayRest = 0 if not hasattr(ipyData, "GetIsDayReset") else ipyData.GetIsDayReset()
                 # 按时段开的默认每天重置
                 if isDayRest or (startHMStrList and endHMStrList):
                     actIDDateTime += datetime.timedelta(days=dayIndex)
+                if actIDDateTimeSpec:
+                    actIDDateTime = actIDDateTimeSpec
                 actID = int(time.mktime(actIDDateTime.timetuple())) # 默认取开始时间点的time值作为活动ID
                 activityInfoDict[ShareDefine.ActKey_DayIndex] = dayIndex
                 activityInfoDict[ShareDefine.ActKey_ID] = actID
@@ -568,9 +619,9 @@
     actCfgCount = getattr(ipyDataMgr, "Get%sCount" % actName)()
     for cfgIndex in xrange(actCfgCount):
         ipyData = getattr(ipyDataMgr, "Get%sByIndex" % actName)(cfgIndex)            
-        platformList = [] if not hasattr(ipyData, "PlatformList") else ipyData.GetPlatformList()
-        serverGroupIDList = [] if not hasattr(ipyData, "ServerGroupIDList") else ipyData.GetServerGroupIDList()
-        serverGroupIDListExcept = [] if not hasattr(ipyData, "ServerGroupIDListExcept") else ipyData.GetServerGroupIDListExcept()
+        platformList = [] if not hasattr(ipyData, "GetPlatformList") else ipyData.GetPlatformList()
+        serverGroupIDList = [] if not hasattr(ipyData, "GetServerGroupIDList") else ipyData.GetServerGroupIDList()
+        serverGroupIDListExcept = [] if not hasattr(ipyData, "GetServerGroupIDListExcept") else ipyData.GetServerGroupIDListExcept()
         
         if platformList and platform not in platformList:
             continue
@@ -658,88 +709,6 @@
                     
     return actNumDisableWeekIpyDataInfo, disableWeekCfgIDDict
 
-def TransferOperationActDBKeyValue():
-    '''  服务器启动时调用
-            支持多活动的数据转移,旧版本db活动数据转移到新版本,分两种情况
-    1. 原已支持多活动的:  手动根据原编号规则进行指定转移,这个维护一次后代码可删除
-    2. 原不支持多活动的,自动根据原活动类型进行适配转移即可,由于合服相关的独立出来了,所以只需要处理常规的及节日类型
-                           这个代码可以一直放着,后续增加支持多活动类型的配置到  MultiActNumOperationActNameList 即可
-                           
-           注:不支持多活动的,暂还是用旧的key记录数据
-    '''
-    GameWorld.Log("=== 转移运营活动旧版本数据到新版本 ===")
-    
-    # 1. 原已支持的  - 维护后过一次后可删除或注释掉,目前只有累计充值、集字,线上版本分支 gt_1.100.4
-    transferDict = {
-                    ShareDefine.OperationActionName_TotalRecharge:[
-                            # 原常规每日累充  转移 到 10
-                            [PlayerDBGSEvent.Def_OperationActID % ShareDefine.OperationActionName_TotalRecharge,
-                             PlayerDBGSEvent.Def_OperationActID % ShareDefine.OperationActionName_TotalRecharge + "_%s" % 10,
-                             ],
-                            [PlayerDBGSEvent.Def_OActWorldLV % ShareDefine.OperationActionName_TotalRecharge,
-                             PlayerDBGSEvent.Def_OActWorldLV % ShareDefine.OperationActionName_TotalRecharge + "_%s" % 10,
-                             ],
-                                                                                          
-                            # 原常规多日累充2  转移 到 11
-                            [PlayerDBGSEvent.Def_OperationActID % (ShareDefine.OperationActionName_TotalRecharge + "2"),
-                             PlayerDBGSEvent.Def_OperationActID % ShareDefine.OperationActionName_TotalRecharge + "_%s" % 11,
-                             ],
-                            [PlayerDBGSEvent.Def_OActWorldLV % (ShareDefine.OperationActionName_TotalRecharge + "2"),
-                             PlayerDBGSEvent.Def_OActWorldLV % ShareDefine.OperationActionName_TotalRecharge + "_%s" % 11,
-                             ],
-                                                                                                  
-                            # 原节日多日累充3  转移 到 31
-                            [PlayerDBGSEvent.Def_OperationActID % (ShareDefine.OperationActionName_TotalRecharge + "3"),
-                             PlayerDBGSEvent.Def_OperationActID % ShareDefine.OperationActionName_TotalRecharge + "_%s" % 31,
-                             ],
-                            [PlayerDBGSEvent.Def_OActWorldLV % (ShareDefine.OperationActionName_TotalRecharge + "3"),
-                             PlayerDBGSEvent.Def_OActWorldLV % ShareDefine.OperationActionName_TotalRecharge + "_%s" % 31,
-                             ],
-                                                                   ],
-                    ShareDefine.OperationActionName_CollectWords:[
-                            # 只配置了常规日期的,可不处理
-                                                                  ],
-                    }
-    for actName, transferKeyList in transferDict.items():
-        for oldKey, newKey in transferKeyList:
-            value = PlayerDBGSEvent.GetDBGSTrig_ByKey(oldKey)
-            if not value:
-                continue
-            GameWorld.Log("    转移旧运营活动dbKey值到新key: actName=%s,oldKey=%s,newKey=%s,value=%s" % (actName, oldKey, newKey, value))
-            PlayerDBGSEvent.SetDBGSTrig_ByKey(newKey, value)
-            PlayerDBGSEvent.DelDBGSTrig_ByKey(oldKey)
-            
-    # 2. 新增支持的 - 可当做常规代码一直留着
-    for actName in ShareDefine.MultiActNumOperationActNameList:
-        if actName in transferDict:
-            # 特殊处理转化的活动不进行常规处理
-            continue
-        
-        actIDKeyOld = PlayerDBGSEvent.Def_OperationActID % actName
-        worldLVKeyOld = PlayerDBGSEvent.Def_OActWorldLV % actName
-        
-        actNum = GetOperationActNum(actName)
-        actIDKeyNew = actIDKeyOld + "_%s" % actNum
-        worldLVKeyNew = worldLVKeyOld + "_%s" % actNum
-        
-        dbActID = PlayerDBGSEvent.GetDBGSTrig_ByKey(actIDKeyOld)
-        dbWorldLV = PlayerDBGSEvent.GetDBGSTrig_ByKey(worldLVKeyOld)
-        if not dbActID:
-            continue
-        
-        GameWorld.Log("    转移旧运营活动dbKey值到新key: actName=%s" % actName)
-        PlayerDBGSEvent.SetDBGSTrig_ByKey(actIDKeyNew, dbActID)
-        PlayerDBGSEvent.DelDBGSTrig_ByKey(actIDKeyOld)
-        GameWorld.Log("        actIDKeyOld=%s,actIDKeyNew=%s,dbActID=%s" % (actIDKeyOld, actIDKeyNew, dbActID))
-        
-        if dbWorldLV:
-            PlayerDBGSEvent.SetDBGSTrig_ByKey(worldLVKeyNew, dbWorldLV)
-            PlayerDBGSEvent.DelDBGSTrig_ByKey(worldLVKeyOld)
-            GameWorld.Log("        worldLVKeyOld=%s,worldLVKeyNew=%s,dbWorldLV=%s" % (worldLVKeyOld, worldLVKeyNew, dbWorldLV))
-            
-    GameWorld.Log("===================================")
-    return
-
 def Dispose_OperationActionState(reloadRefresh=False):
     # 运营活动状态处理, 每天0点会强制同步当天的运营活动详情到地图服务器
     
@@ -773,6 +742,7 @@
         for sendMapServerMsgDict in curActMapInfoDictList:
             
             state = 0 # 默认关闭
+            stateJoin = ShareDefine.ActStateJoin_None # 可参与状态,0-参与前;1-可参与;2-参与结束
             ipyData = None
             
             actNum = sendMapServerMsgDict.get(ShareDefine.ActKey_ActNum, 0)
@@ -785,12 +755,12 @@
                 else:
                     todayActInfoList = operationTodayActionDict[actName]
                     
-                if isinstance(todayActInfoList, list) and len(todayActInfoList) == 4:
+                if isinstance(todayActInfoList, list) and len(todayActInfoList) == 6:
                     #startList = [] # [startDateTime, ...]
                     #endList = [] # [endDateTime, ...]
                     #notifyDict = {} # {notifyDateTime:[notifyKey, [参数]], ...}
                     #ipyData 可能为 None
-                    ipyData, startList, endList, notifyDict = todayActInfoList
+                    ipyData, startList, endList, notifyDict, joinStartTimeList, joinEndTimeList = todayActInfoList
                     
                     # 状态
                     for dIndex, startDateTime in enumerate(startList):
@@ -798,6 +768,17 @@
                         if startDateTime <= curDateTime < endDateTime:
                             state = dIndex + 1 # 代表第几个时间段
                             break
+                        
+                    if joinStartTimeList:
+                        for jIndex, joinStartDateTime in enumerate(joinStartTimeList):
+                            endJoinDateTime = joinEndTimeList[jIndex]
+                            if joinStartDateTime <= curDateTime < endJoinDateTime:
+                                stateJoin = ShareDefine.ActStateJoin_Start
+                                break
+                            elif curDateTime >= endJoinDateTime:
+                                stateJoin = ShareDefine.ActStateJoin_End
+                    else:
+                        stateJoin = ShareDefine.ActStateJoin_Start if state else ShareDefine.ActStateJoin_None
                         
                     # 全服广播提示信息
                     if curDateTime in notifyDict:
@@ -808,12 +789,19 @@
             if actName in ShareDefine.MultiActNumOperationActNameList:
                 dictName += "_%s" % actNum
             preState = gameWorld.GetDictByKey(dictName)
-            if not isReload and preState == state:
+            
+            dictNameJoin = ChConfig.Def_WorldKey_OperationActionStateJoin % actName
+            if actName in ShareDefine.MultiActNumOperationActNameList:
+                dictNameJoin += "_%s" % actNum
+            preStateJoin = gameWorld.GetDictByKey(dictNameJoin)
+            
+            if not isReload and preState == state and preStateJoin == stateJoin:
                 #已经是这个状态了
                 continue
-            GameWorld.Log("运营活动变更: actName=%s,actNum=%s,preState=%s,state=%s,dictName=%s" % (actName, actNum, preState, state, dictName))
+            GameWorld.Log("运营活动变更: actName=%s,actNum=%s,preState=%s,state=%s,preStateJoin=%s,stateJoin=%s" % (actName, actNum, preState, state, preStateJoin, stateJoin))
             #更新字典值
             gameWorld.SetDict(dictName, state)
+            gameWorld.SetDict(dictNameJoin, stateJoin)
             
             dbOperationActIDKey = PlayerDBGSEvent.Def_OperationActID % actName
             dbOperationActWorldLVKey = PlayerDBGSEvent.Def_OActWorldLV % actName
@@ -828,6 +816,11 @@
                 GameWorld.Log("    dbActID变更: dbActID=%s,curActID=%s" % (dbActID, curActID))
                 PlayerDBGSEvent.SetDBGSTrig_ByKey(dbOperationActIDKey, curActID)
                 
+                # 结束旧的
+                if dbActID:
+                    if actName == ShareDefine.OperationActionName_BossTrial:
+                        PlayerActBossTrial.OnActEnd(actNum, ipyData, dayIndex)
+                        
                 if curActID:
                     if actName in ShareDefine.NeedWorldLVOperationActNameList:
                         #记录开启时世界等级
@@ -855,6 +848,10 @@
                         PlayerStore.ResetFlashSaleBuyCnt(ipyData)
                     elif actName == ShareDefine.OperationActionName_GarbageSorting:
                         PlayerActGarbageSorting.OnActStart(actNum)
+                    elif actName == ShareDefine.OperationActionName_BossTrial:
+                        PlayerActBossTrial.OnActStart(actNum)
+                    elif actName == ShareDefine.OperationActionName_FamilyCTGAssist:
+                        PlayerActFamilyCTGAssist.OnActStart(actNum)
                 else:
                     if actName == ShareDefine.OperationActionName_GarbageSorting:
                         PlayerActGarbageSorting.OnActEnd(actNum)
@@ -862,6 +859,17 @@
             else:
                 GameWorld.Log("    dbActID不变: dbActID=%s,curActID=%s" % (dbActID, curActID))
                 
+            # 仅活动有配置参与时间段的会触发
+            if curActID and dbActID == curActID and preStateJoin != stateJoin:
+                GameWorld.Log("    参与状态变更: preStateJoin=%s,stateJoin=%s" % (preStateJoin, stateJoin))
+                # 参与开始
+                if stateJoin == ShareDefine.ActStateJoin_Start:
+                    pass
+                # 参与结束
+                elif stateJoin == ShareDefine.ActStateJoin_End:
+                    if actName == ShareDefine.OperationActionName_BossTrial:
+                        PlayerActBossTrial.OnActJoinEnd(actNum, ipyData, dayIndex)
+                        
             if ipyData and actName in ShareDefine.NeedWorldLVOperationActNameList:
                 actWorldLV = PlayerDBGSEvent.GetDBGSTrig_ByKey(dbOperationActWorldLVKey)
                 sendMapServerMsgDict[ShareDefine.ActKey_WorldLV] = actWorldLV
@@ -903,6 +911,7 @@
             #GameWorld.SendMapServerMsgEx(dictName, state) # 运营活动不单独通知活动状态,需与活动信息整合后一起通知
             
             sendMapServerMsgDict[ShareDefine.ActKey_State] = state
+            sendMapServerMsgDict[ShareDefine.ActKey_StateJoin] = stateJoin
             GameWorld.SendMapServerMsgEx(ShareDefine.Def_Notify_WorldKey_OperationActionInfo % actName, sendMapServerMsgDict)
             
             GameWorld.Log("    sendMapServerMsgDict: %s" % (sendMapServerMsgDict))
@@ -1051,6 +1060,10 @@
         dailyIpyData = ipyDataMgr.GetDailyActionByIndex(i)
         dailyID = dailyIpyData.GetDailyID()
         
+        if dailyID in [ShareDefine.DailyActionID_CrossBattlefield]:
+            GameWorld.Log("    不需要处理的日常活动! dailyID=%s" % dailyID)
+            continue
+        
         # 是当天开服天定制活动的不处理常规活动
         if dailyID in customDailyIDList:
             GameWorld.Log("    常规活动ID配置是今天的定制活动ID,不处理!: dailyID=%s" % dailyID)
@@ -1118,6 +1131,9 @@
 def Dispose_DailyActionState():
     # 日常活动状态变更检查处理
     
+    if GameWorld.IsCrossServer():
+        CrossActionControl.Dispose_CrossDailyActionState()
+    
     todayDailyActionInfo = __GetTodayDailyActionInfo()
     if not todayDailyActionInfo:
         return
@@ -1183,11 +1199,20 @@
 def SendMapServerDailyActionState():
     # 地图启动成功时通知本日进行中的日常活动状态
     
+    gameWorld = GameWorld.GetGameWorld()
+    if GameWorld.IsCrossServer():
+        CrossActionControl.SendMapServerCrossDailyActionState()
+    else:
+        for dailyActionID in ShareDefine.CrossDailyActionIDList:
+            dictName = ShareDefine.Def_Notify_WorldKey_CrossDailyActionState % dailyActionID 
+            state = gameWorld.GetDictByKey(dictName)
+            if state:
+                GameWorld.SendMapServerMsgEx(dictName, state)
+            
     todayDailyActionInfo = __GetTodayDailyActionInfo()
     if not todayDailyActionInfo:
         return
     
-    gameWorld = GameWorld.GetGameWorld()
     for actionInfo in todayDailyActionInfo:
         dailyActionID = actionInfo[0]
         dictName = ShareDefine.Def_Notify_WorldKey_DailyActionState % dailyActionID 

--
Gitblit v1.8.0