From 2b34924e06c0c36d77d9ccec4c4f10f1ebd16e84 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期二, 16 九月 2025 19:03:17 +0800 Subject: [PATCH] 129 【战斗】战斗系统-服务端(NPC表加特长字段;) --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py | 17 ++++++++++++++--- 1 files changed, 14 insertions(+), 3 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py index a7b8e5e..830f953 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py @@ -84,6 +84,7 @@ ("DWORD", "SuckHPPer", 0), ("DWORD", "SuckHPPerDef", 0), ("dict", "SpecAttrInfo", 0), + ("BYTE", "Specialty", 0), ), "NPCStronger":( @@ -163,6 +164,7 @@ ("dict", "BatAttrDict", 0), ("list", "FetterIDList", 0), ("BYTE", "RecruitBySelf", 0), + ("BYTE", "Specialty", 0), ), "HeroTalent":( @@ -2642,7 +2644,8 @@ def GetParryRateDef(self): return self.attrTuple[23] # 抗格挡概率 DWORD def GetSuckHPPer(self): return self.attrTuple[24] # 吸血比率 DWORD def GetSuckHPPerDef(self): return self.attrTuple[25] # 抗吸血比率 DWORD - def GetSpecAttrInfo(self): return self.attrTuple[26] # 特殊属性信息 {"属性ID":值, ...} dict + def GetSpecAttrInfo(self): return self.attrTuple[26] # 特殊属性信息 {"属性ID":值, ...} dict + def GetSpecialty(self): return self.attrTuple[27] # 特长 BYTE # NPC成长表 class IPY_NPCStronger(): @@ -2736,7 +2739,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(): @@ -6913,7 +6917,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 @@ -6923,6 +6927,13 @@ 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) + else: + try: + value = float(value) + except: + pass setList.append(value) if setList: setList = tuple(setList) -- Gitblit v1.8.0