From c880e89aec10d4b98575830cc2f81253082a9574 Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期三, 14 一月 2026 19:45:01 +0800
Subject: [PATCH] 302 【公会】BOSS讨伐-服务端(玩家过天额外刷新最新可领取宝箱数;启动服务器加载物品数据异常时补运营邮件通知;)
---
ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/GameWorldEvent.py | 38 ++++++++++++++++++++++++++++++++++----
1 files changed, 34 insertions(+), 4 deletions(-)
diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/GameWorldEvent.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/GameWorldEvent.py
index f157b02..cc14de1 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/GameWorldEvent.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorldLogic/GameWorldEvent.py
@@ -21,6 +21,7 @@
import PlayerFamily
import IpyGameDataPY
import IPY_GameWorld
+import DataRecordPack
import PlayerEventCounter
import PlayerViewCache
import PlayerControl
@@ -111,8 +112,13 @@
pass
else:
serverGroupID = GameWorld.GetServerGroupID()
- GameWorld.Log("服务器启动成功: ServerGroupID=%s,serverID=%s" % (serverGroupID, serverID))
+ serverDay = DBDataMgr.GetEventTrigMgr().GetValue(ShareDefine.Def_ServerDay) + 1
+ isMixServer = DBDataMgr.GetEventTrigMgr().GetValue(ShareDefine.Def_IsMixServer)
+ mixServerDay = DBDataMgr.GetEventTrigMgr().GetValue(ShareDefine.Def_MixServerDay) + 1
+ GameWorld.Log("服务器启动成功: ServerGroupID=%s,serverID=%s,serverDay=%s,isMixServer=%s,mixServerDay=%s"
+ % (serverGroupID, serverID, serverDay, isMixServer, mixServerDay))
PyGameData.g_serverInitOK = True
+ DataRecordPack.DR_Reload("restart")
return
def AllMapServerInitOK(tick):
@@ -299,10 +305,15 @@
DBDataMgr.OnMinute(curTime)
DoLogic_GameWorldEvenByTime(tick)
+ #每5分钟
+ if curMinute % 5 == 0:
+ OnMinute_5(curTime, tick)
+
#其他功能逻辑
#GameWorldActionControl.Dispose_OperationActionState()
#GameWorldActionControl.Dispose_DailyActionState()
#GameWorldActionControl.Dispose_FBStateTime()
+ PlayerControl.OnMinute(curTime)
PlayerFamily.OnMinute()
PlayerOnline.OnMinute()
BattleObj.OnMinute()
@@ -311,6 +322,23 @@
__CheckIpyDataRecycle(curTime)
return
+def OnMinute_5(curTime, tick):
+ ## 每5分钟
+ DisposeGameActivePlayer(curTime, tick)
+ return
+
+def DisposeGameActivePlayer(curTime, tick):
+ curMinute = curTime.minute
+ gameWorld = GameWorld.GetGameWorld()
+ noteData = gameWorld.GetGameWorldDictByKey("OnlineCntM")
+ if noteData == curMinute:
+ # 同一分钟只处理1次
+ return
+ gameWorld.SetGameWorldDict("OnlineCntM", curMinute)
+ activePlayerCount = GameWorld.GetPlayerManager().OnlineCount()
+ DataRecordPack.DR_OnLinePlayerCount(activePlayerCount) # 总在线
+ return
+
def DoLogic_GameWorldEvenByTime(tick):
#-----------服务器当前时间
curTime = datetime.datetime.today()
@@ -361,11 +389,13 @@
GameWorld.Log("Server -> OnDay!")
#设定服务器当前天事件
eventMgr = DBDataMgr.GetEventTrigMgr()
- eventMgr.SetValueIncrement(ShareDefine.Def_ServerDay)
+ serverDay = eventMgr.SetValueIncrement(ShareDefine.Def_ServerDay)
isMixServer = eventMgr.GetValue(ShareDefine.Def_IsMixServer)
+ mixServerDay = 0
if isMixServer:
- eventMgr.SetValueIncrement(ShareDefine.Def_MixServerDay)
-
+ mixServerDay = eventMgr.SetValueIncrement(ShareDefine.Def_MixServerDay)
+ GameWorld.Log("OnDay -> serverDay=%s,isMixServer=%s,mixServerDay=%s" % (serverDay + 1, isMixServer, mixServerDay + 1))
+
PlayerEventCounter.DoLogic_OnDay(tick)
return
--
Gitblit v1.8.0