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 | 40 +++++++++++++++++++++++++++++++++++++--- 1 files changed, 37 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 861ba0c..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":( @@ -2565,6 +2567,11 @@ ("BYTE", "WorkerMax", 0), ("BYTE", "NeedSeconds", 0), ), + + "Robot":( + ("DWORD", "ID", 1), + ("char", "ViewCache", 0), + ), } @@ -2637,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(): @@ -2731,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(): @@ -6388,6 +6397,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 +6721,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 +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 @@ -6907,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) @@ -8718,6 +8745,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