From fd46c6afd9024b1739a449786c284461d0394d0b Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期一, 01 十二月 2025 15:05:47 +0800
Subject: [PATCH] 358 【内政】红颜系统-服务端(白骨盈野特殊效果改为固定奖励)

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Skill/TurnPassive.py |   15 ++++++++-------
 1 files changed, 8 insertions(+), 7 deletions(-)

diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Skill/TurnPassive.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Skill/TurnPassive.py
index 91f9b07..a53d5a4 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Skill/TurnPassive.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Skill/TurnPassive.py
@@ -34,21 +34,23 @@
 def OnTriggerPassiveEffect(turnFight, batObj, triggerWay, tagObj=None, connSkill=None, connSkillTypeID=0, connBuff=None, **kwargs):
     ''' 触发被动效果,可能触发技能、buff,需根据优先级触发
     '''
+    if not batObj.IsAlive():
+        if triggerWay not in ChConfig.DeadCanTriggerWayList:
+            return
     passiveEffMgr = batObj.GetPassiveEffManager()
     effInfoList = passiveEffMgr.GetPassiveEffByTrigger(triggerWay, connSkill, connSkillTypeID, connBuff)
     if not effInfoList:
         return
-    # [["skill/buff", skillID/buffID, effIDList], ...]
+    # [["skill/buff", skillID, buffID, effIDList], ...]
     tagID = tagObj.GetID() if tagObj else 0
     GameWorld.DebugLog("触发被动: triggerWay=%s,objID=%s,tagID=%s,%s" % (triggerWay, batObj.GetID(), tagID, effInfoList))
     for effInfo in effInfoList:
         sign = effInfo[0]
+        skillID, buffID, effIDList = effInfo[1:]
         if sign == "skill":
-            skillID, effIDList = effInfo[1:]
             __doTriggerPassiveEffectBySkill(turnFight, batObj, tagObj, triggerWay, skillID, effIDList, connSkill, connBuff, **kwargs)
             
         elif sign == "buff":
-            buffID, effIDList = effInfo[1:]
             __doTriggerPassiveEffectByBuff(turnFight, batObj, tagObj, triggerWay, buffID, effIDList, connSkill, connBuff, **kwargs)
             
     return
@@ -125,18 +127,17 @@
     curValue = 0
     skillMgr = atkObj.GetSkillManager()
     buffMgr = atkObj.GetBuffManager()
-    # [["skill/buff", skillID/buffID, effIDList], ...]
+    # [["skill/buff", skillID, buffID, effIDList], ...]
     tagID = defObj.GetID() if defObj else 0
     for effInfo in effInfoList:
         sign = effInfo[0]
+        skillID, buffID, effIDList = effInfo[1:]
         if sign == "skill":
-            skillID, effIDList = effInfo[1:]
             effSkill = skillMgr.FindSkillByID(skillID)
             if not effSkill and connSkill and connSkill.GetSkillID() == skillID:
                 effSkill = connSkill
             effBuff = None
         elif sign == "buff":
-            buffID, effIDList = effInfo[1:]
             effBuff = buffMgr.GetBuff(buffID)
             if not effBuff:
                 continue
@@ -163,7 +164,7 @@
             callFunc = GameWorld.GetExecFunc(PassiveTrigger, "%s.%s" % (pyName, "GetHappenValue"))
             if not callFunc:
                 continue
-            value = callFunc(atkObj, defObj, effect, effSkill, effBuff, **kwargs)
+            value = callFunc(atkObj, defObj, effect, effSkill, effBuff, connSkill, **kwargs)
             if value is None:
                 continue
             

--
Gitblit v1.8.0