From 0dcd7650a642a7b26fe65e14cc5f5b3947757e30 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期二, 16 九月 2025 16:59:10 +0800 Subject: [PATCH] 129 【战斗】战斗系统-服务端(王异技能;支持被动增加暴击率;支持被动变更伤害类型;) --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py | 31 +++++++++++++++++++++++++++++-- 1 files changed, 29 insertions(+), 2 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py index 861ba0c..f345268 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py @@ -163,6 +163,7 @@ ("dict", "BatAttrDict", 0), ("list", "FetterIDList", 0), ("BYTE", "RecruitBySelf", 0), + ("BYTE", "Specialty", 0), ), "HeroTalent":( @@ -2565,6 +2566,11 @@ ("BYTE", "WorkerMax", 0), ("BYTE", "NeedSeconds", 0), ), + + "Robot":( + ("DWORD", "ID", 1), + ("char", "ViewCache", 0), + ), } @@ -2731,7 +2737,8 @@ def GetHPInheritPer(self): return self.attrTuple[11] # 生命继承 WORD def GetBatAttrDict(self): return self.attrTuple[12] # 其他战斗属性字典 {"属性ID":值, ...} dict def GetFetterIDList(self): return self.attrTuple[13] # 羁绊ID列表 list - def GetRecruitBySelf(self): return self.attrTuple[14] # 招募需要本体 BYTE + def GetRecruitBySelf(self): return self.attrTuple[14] # 招募需要本体 BYTE + def GetSpecialty(self): return self.attrTuple[15] # 武将特长 BYTE # 武将星级天赋表 class IPY_HeroTalent(): @@ -6388,6 +6395,16 @@ def GetRefreshWeight(self): return self.attrTuple[4] # 常规刷新权重 DWORD def GetWorkerMax(self): return self.attrTuple[5] # 监工上限 BYTE def GetNeedSeconds(self): return self.attrTuple[6] # 耗时秒 BYTE + +# 机器人 +class IPY_Robot(): + + def __init__(self): + self.attrTuple = None + return + + def GetID(self): return self.attrTuple[0] # 机器人ID,同玩家ID DWORD + def GetViewCache(self): return self.attrTuple[1] # 机器人缓存 char def Log(msg, playerID=0, par=0): @@ -6702,6 +6719,7 @@ self.__LoadFileData("GoldRushCamp", onlyCheck) self.__LoadFileData("GoldRushWorker", onlyCheck) self.__LoadFileData("GoldRushItem", onlyCheck) + self.__LoadFileData("Robot", onlyCheck) Log("IPY_DataMgr ReloadOK! onlyCheck=%s" % onlyCheck) return @@ -6897,7 +6915,7 @@ def __StrToList(self, strValue): setList = [] - if ("[" in strValue and "]" in strValue) or ("(" in strValue and ")" in strValue): + if (strValue.startswith("[") and strValue.endswith("]")) or (strValue.startswith("(") and strValue.endswith(")")): setList = eval(strValue) elif strValue in ["0", "-", ""]: pass @@ -6907,6 +6925,8 @@ for value in strValue.split(ChConfig.Def_Str_Montant): if value.isdigit(): value = int(value) + elif (value.startswith("[") and value.endswith("]")) or (value.startswith("(") and value.endswith(")")): + value = eval(value) setList.append(value) if setList: setList = tuple(setList) @@ -8718,6 +8738,13 @@ def GetGoldRushItemByIndex(self, index): self.CheckLoadData("GoldRushItem") return self.ipyGoldRushItemCache[index] + + def GetRobotCount(self): + self.CheckLoadData("Robot") + return self.ipyRobotLen + def GetRobotByIndex(self, index): + self.CheckLoadData("Robot") + return self.ipyRobotCache[index] IPYData = IPY_DataMgr() def IPY_Data(): return IPYData -- Gitblit v1.8.0