| | |
| | | import PlayerFamily
|
| | | import IpyGameDataPY
|
| | | import IPY_GameWorld
|
| | | import DataRecordPack
|
| | | import PlayerEventCounter
|
| | | import PlayerViewCache
|
| | | import PlayerControl
|
| | |
| | | import PlayerOnline
|
| | | import ShareDefine
|
| | | import PyGameData
|
| | | import ItemCommon
|
| | | import BattleObj
|
| | | import ChPlayer
|
| | | import ObjPool
|
| | |
| | | serverID = GameWorld.GetGameWorld().GetServerID()
|
| | | GameWorld.Log("服务器启动初始化InitGameWorld: serverID=%s" % serverID)
|
| | | DBDataMgr.OnServerStart() # 优先加载公共数据
|
| | | ItemCommon.InitPyItem()
|
| | | LoadDBPlayer()
|
| | | PlayerViewCache.LoadRobot()
|
| | | PyGameData.g_initGameTime = int(time.time()) # 放到加载数据之后
|
| | |
| | | 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):
|
| | |
| | | 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()
|
| | |
| | | __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()
|
| | |
| | | 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
|
| | |
|