From 0d24ae9f78e7a6314fe79e285566e6ad82dd1622 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期三, 04 九月 2024 11:38:23 +0800 Subject: [PATCH] 10258 【越南】【砍树】新增古宝特殊效果(增加法器每X阶+xx属性) --- ServerPython/CoreServerGroup/GameServer/Script/PyDataManager.py | 234 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 228 insertions(+), 6 deletions(-) diff --git a/ServerPython/CoreServerGroup/GameServer/Script/PyDataManager.py b/ServerPython/CoreServerGroup/GameServer/Script/PyDataManager.py index 0772738..063395f 100644 --- a/ServerPython/CoreServerGroup/GameServer/Script/PyDataManager.py +++ b/ServerPython/CoreServerGroup/GameServer/Script/PyDataManager.py @@ -14,7 +14,9 @@ import GameWorld import PlayerSocial +import CrossBillboard import PlayerFamilyStore +import PlayerCompensation import PlayerBourse import GameWorldBoss import PlayerSealDemon @@ -23,13 +25,21 @@ import PyGameData import CrossRealmPK import AuctionHouse +import PlayerAssist +import PlayerRecData +import GameWorldMineArea import PyGameDataStruct +import PlayerFuncTeam +import IpyGameDataPY +import PlayerCharm +import PlayerLove import CommFunc +import time def GetSavePyData(): pyGameDataMgr = GetPyGameDataManager() result = pyGameDataMgr.GetSaveData() - GameWorld.DebugLog("GetSavePyData!! id = %s-%s"%(id(pyGameDataMgr), len(result))) + GameWorld.Log("GetSavePyData!! id = %s-%s"%(id(pyGameDataMgr), len(result))) result = binascii.b2a_hex(result) #GameWorld.DebugLog("GetSavePyData!! result = %s-%s"%(result, len(result))) # 字节码在C++转化会发生错误must be string without null bytes, not str,但是可以正常保存,错误会在下次调用便宜接口才会触发 @@ -42,6 +52,89 @@ GameWorld.Log("LoadPyGameData!!id = %s %s"%(id(pyGameDataMgr), len(gameBuffer))) return pyGameDataMgr.LoadGameData(gameBuffer, pos) +#协助感谢表 +class PlayerAssistThanksPyManager(object): + + def __init__(self): + self.allAssistThanksList = [] # 所有感谢 [tagDBAssistThanks, ...] + self.playerThanksDict = {} # 玩家未感谢的 {playerID:[tagDBAssistThanks, ...], ...} + self.assistPlayerThanksDict = {} # 协助玩家未接受感谢的协助 {assistPlayerID:[tagDBAssistThanks, ...], ...} + return + + # 保存数据 存数据库和realtimebackup + def GetSaveData(self): + PlayerAssist.RemoveOutofdateAssistThanks() + savaData = "" + cntData = "" + cnt = 0 + + for dbData in self.allAssistThanksList: + cnt += 1 + PlayerAssist.OnSaveAssistThanksData(dbData) + savaData += dbData.getBuffer() + + GameWorld.Log("Save DBAssistThanks count :%s len=%s" % (cnt, len(savaData))) + return CommFunc.WriteDWORD(cntData, cnt) + savaData + + # 从数据库载入数据 + def LoadPyGameData(self, datas, pos, dataslen): + cnt, pos = CommFunc.ReadDWORD(datas, pos) + GameWorld.Log("Load DBAssistThanks count :%s" % cnt) + + for _ in xrange(cnt): + dbData = PyGameDataStruct.tagDBAssistThanks() + dbData.clear() + pos += dbData.readData(datas, pos, dataslen) + PlayerAssist.OnInitAssistThanksData(self, dbData) + + return pos + +#协助表 +class PlayerAssistPyManager(object): + + def __init__(self): + self.allAssistDict = {} # 所有协助 {GUID:tagDBAssist, ...} + + self.playerAssistDict = {} # 玩家发布的协助 {playerID:[tagDBAssist, ...], ...} + self.playerAssistingDict = {} # 玩家正在协助中的协助,只能存在一条 {playerID:tagDBAssist, ...} + return + + # 保存数据 存数据库和realtimebackup + def GetSaveData(self): + savaData = "" + cntData = "" + cnt = 0 + + for dbData in self.allAssistDict.values(): + if not dbData.IsSaveDB: + continue + cnt += 1 + savaData += dbData.getBuffer() + + GameWorld.Log("Save DBAssist count :%s len=%s" % (cnt, len(savaData))) + return CommFunc.WriteDWORD(cntData, cnt) + savaData + + # 从数据库载入数据 + def LoadPyGameData(self, datas, pos, dataslen): + cnt, pos = CommFunc.ReadDWORD(datas, pos) + GameWorld.Log("Load DBAssist count :%s" % cnt) + + for _ in xrange(cnt): + dbData = PyGameDataStruct.tagDBAssist() + dbData.clear() + pos += dbData.readData(datas, pos, dataslen) + + PlayerAssist.OnInitAssistData(dbData, 1) + + self.allAssistDict[dbData.GUID] = dbData + PlayerID = dbData.PlayerID + if PlayerID not in self.playerAssistDict: + self.playerAssistDict[PlayerID] = [] + playerAssistList = self.playerAssistDict[PlayerID] + playerAssistList.append(dbData) + + return pos + #玩家缓存管理,该类只做数据缓存存取,不写功能逻辑,防止重读脚本时功能逻辑脚本不生效 class PlayerViewCachePyManager(object): @@ -56,10 +149,13 @@ cnt = 0 for dbData in self.playerViewCachePyDict.values(): + if dbData.PlayerID < 10000: + # 假人玩家不存储 + continue cnt += 1 savaData += dbData.getBuffer() - GameWorld.Log("Save PlayerViewCachePy count :%s" % cnt) + GameWorld.Log("Save PlayerViewCachePy count :%s len=%s" % (cnt, len(savaData))) return CommFunc.WriteDWORD(cntData, cnt) + savaData # 从数据库载入数据 @@ -91,13 +187,21 @@ cntData = "" cnt = 0 + unSaveCnt = 0 + curTime = int(time.time()) + vaildSeconds = IpyGameDataPY.GetFuncCfg("AuctionHouse", 1) * 3600 * 24 for recordDict in [self.myAuctionItemRecordDict, self.myBidItemRecordDict, self.familyAuctionItemRecordDict]: for recordList in recordDict.values(): for dbData in recordList: + if vaildSeconds: + recordTime = GameWorld.ChangeTimeStrToNum(dbData.RecordTime) + if curTime - recordTime > vaildSeconds: + unSaveCnt += 1 + continue cnt += 1 savaData += dbData.getBuffer() - GameWorld.Log("Save AuctionRecord count :%s" % cnt) + GameWorld.Log("Save AuctionRecord count :%s len=%s unSaveCnt=%s" % (cnt, len(savaData), unSaveCnt)) return CommFunc.WriteDWORD(cntData, cnt) + savaData # 从数据库载入数据 @@ -131,7 +235,7 @@ cnt += 1 savaData += dbData.getBuffer() - GameWorld.Log("Save AuctionAttention count :%s" % cnt) + GameWorld.Log("Save AuctionAttention count :%s len=%s" % (cnt, len(savaData))) return CommFunc.WriteDWORD(cntData, cnt) + savaData # 从数据库载入数据 @@ -151,7 +255,9 @@ def __InitAuctionAttentionAttrEx(self, attentionData): ## 初始化拍卖关注实例附加属性 - setattr(attentionData, "AttentionItemIDList", [] if not attentionData.AttentionInfo else eval(attentionData.AttentionInfo)) + setattr(attentionData, "AttentionItemIDList", []) + if attentionData.AttentionInfo.startswith("[") and attentionData.AttentionInfo.endswith("]"): + attentionData.AttentionItemIDList = eval(attentionData.AttentionInfo) return #拍卖物品数据缓存,该类只做数据缓存存取,不写功能逻辑,防止重读脚本时功能逻辑脚本不生效 @@ -169,6 +275,10 @@ self.hisBiddingAuctionItemDict = {} # 玩家曾经参与过竞价的拍品,含所有拍品 {playerID:[tagDBAuctionItem, ...], ...} self.myAuctionItemDict = {} # 玩家拍卖中的物品 ,不包含仙盟拍品,由前端界面自行整合数据 {playerID:[tagDBAuctionItem, ...], ...} self.myAttentionItemDict = {} # 玩家关注中的物品 ,不包含仙盟拍品,由前端界面自行整合数据,只保存在线的玩家,离线清除,上线不同步,由前端查询 {playerID:[tagDBAuctionItem, ...], ...} + + self.worldAuctionItemCountDict = {} # 全服拍品物品ID对应件数统计 {itemID:件数, ...} + self.worldAuctionJobEquipCountDict = {} # 全服拍品职业装备对应件数统计 {(职业,阶,颜色,是否套装):件数, ...} + self.worldAuctionReplenishTimeDict = {} # 全服拍品动态上架历史处理时间 {cfgID:time, ...} return # 保存数据 存数据库和realtimebackup @@ -181,7 +291,7 @@ cnt += 1 savaData += dbData.getBuffer() - GameWorld.Log("Save AuctionItem count :%s" % cnt) + GameWorld.Log("Save AuctionItem count :%s len=%s" % (cnt, len(savaData))) return CommFunc.WriteDWORD(cntData, cnt) + savaData # 从数据库载入数据 @@ -205,6 +315,20 @@ class PyGameDataManager(object): def __init__(self): + self.DBPyFuncTeamManager = PlayerFuncTeam.DBPyFuncTeamManager() + self.DBPyFuncTeamMemManager = PlayerFuncTeam.DBPyFuncTeamMemManager() + self.DBPlayerRecDataManager = PlayerRecData.DBPlayerRecDataManager() + self.DBPyMineAreaAwardManager = GameWorldMineArea.DBPyMineAreaAwardManager() + self.DBPyMineAreaRecordManager = GameWorldMineArea.DBPyMineAreaRecordManager() + self.DBPyMineAreaItemManager = GameWorldMineArea.DBPyMineAreaItemManager() + self.DBPyCoupleManager = PlayerLove.DBPyCoupleManager() + self.DBPyUnNotifyLoveGiftRecManager = PlayerLove.DBPyUnNotifyLoveGiftRecManager() + self.DBPyCharmValueRecManager = PlayerCharm.DBPyCharmValueRecManager() + self.IntimacyManager = PlayerSocial.IntimacyManager() + self.CrossPersonalCompensationManager = PlayerCompensation.CrossPersonalCompensationManager() + self.CrossBillboardManager = CrossBillboard.CrossBillboardManager() + self.PlayerAssistThanksPyManager = PlayerAssistThanksPyManager() + self.PlayerAssistPyManager = PlayerAssistPyManager() self.PlayerViewCachePyManager = PlayerViewCachePyManager() self.AuctionAttentionManager = AuctionAttentionManager() self.AuctionRecordManager = AuctionRecordManager() @@ -226,6 +350,20 @@ def GetSaveData(self): buff = "" + buff += self.DBPyFuncTeamManager.GetSaveData() + buff += self.DBPyFuncTeamMemManager.GetSaveData() + buff += self.DBPlayerRecDataManager.GetSaveData() + buff += self.DBPyMineAreaAwardManager.GetSaveData() + buff += self.DBPyMineAreaRecordManager.GetSaveData() + buff += self.DBPyMineAreaItemManager.GetSaveData() + buff += self.DBPyCoupleManager.GetSaveData() + buff += self.DBPyUnNotifyLoveGiftRecManager.GetSaveData() + buff += self.DBPyCharmValueRecManager.GetSaveData() + buff += self.IntimacyManager.GetSaveData() + buff += self.CrossPersonalCompensationManager.GetSaveData() + buff += self.CrossBillboardManager.GetSaveData() + buff += self.PlayerAssistThanksPyManager.GetSaveData() + buff += self.PlayerAssistPyManager.GetSaveData() buff += self.PlayerViewCachePyManager.GetSaveData() buff += self.AuctionAttentionManager.GetSaveData() buff += self.AuctionRecordManager.GetSaveData() @@ -246,6 +384,20 @@ return buff def LoadGameData(self, gameBuffer, pos): + pos = self.DBPyFuncTeamManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.DBPyFuncTeamMemManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.DBPlayerRecDataManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.DBPyMineAreaAwardManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.DBPyMineAreaRecordManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.DBPyMineAreaItemManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.DBPyCoupleManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.DBPyUnNotifyLoveGiftRecManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.DBPyCharmValueRecManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.IntimacyManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.CrossPersonalCompensationManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.CrossBillboardManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.PlayerAssistThanksPyManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) + pos = self.PlayerAssistPyManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) pos = self.PlayerViewCachePyManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) pos = self.AuctionAttentionManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) pos = self.AuctionRecordManager.LoadPyGameData(gameBuffer, pos, len(gameBuffer)) @@ -272,6 +424,26 @@ pyGameDataMgr = PyGameDataManager() PyGameData.g_pyGameDataManager = pyGameDataMgr return pyGameDataMgr + +def GetCrossPersonalCompensationManager(): + # 跨服个人补偿邮件管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.CrossPersonalCompensationManager + +def GetCrossBillboardManager(): + # 跨服排行榜管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.CrossBillboardManager + +def GetPlayerAssistThanksPyManager(): + # 协助感谢表 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.PlayerAssistThanksPyManager + +def GetPlayerAssistPyManager(): + # 协助表 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.PlayerAssistPyManager def GetPlayerViewCachePyManager(): # 拍卖记录表 @@ -333,6 +505,56 @@ pyGameDataMgr = GetPyGameDataManager() return pyGameDataMgr.familyStoreItemManager +def GetDBPyFuncTeamManager(): + # 功能队伍管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.DBPyFuncTeamManager + +#def GetDBPyFuncTeamMemManager(): +# # 功能队伍成员管理 +# pyGameDataMgr = GetPyGameDataManager() +# return pyGameDataMgr.DBPyFuncTeamMemManager + +def GetDBPlayerRecDataManager(): + # 玩家记录管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.DBPlayerRecDataManager + +def GetDBPyMineAreaAwardManager(): + # 福地奖励结算管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.DBPyMineAreaAwardManager + +def GetDBPyMineAreaRecordManager(): + # 福地矿物记录管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.DBPyMineAreaRecordManager + +def GetDBPyMineAreaItemManager(): + # 福地矿物管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.DBPyMineAreaItemManager + +def GetDBPyCoupleManager(): + # 伴侣管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.DBPyCoupleManager + +def GetDBPyUnNotifyLoveGiftRecManager(): + # 未通知的赠送礼物记录 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.DBPyUnNotifyLoveGiftRecManager + +def GetDBPyCharmValueRecManager(): + # 魅力管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.DBPyCharmValueRecManager + +def GetIntimacyManager(): + # 亲密管理 + pyGameDataMgr = GetPyGameDataManager() + return pyGameDataMgr.IntimacyManager + # 好友系统 def GetFriendManager(): pyGameDataMgr = GetPyGameDataManager() -- Gitblit v1.8.0