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