refactor(fight): 重构击败触发效果机制,优化代码结构 将 EffectDefeatTrigger 中的回调函数模式改为基于 effectID 的 switch-case 实现, 移除冗余的 defeatTriggerFunc 类型定义。统一通过 triggerByID 方法根据 ID 分发执行具体行为, 提高可维护性和扩展性。 同时更新 AddEffect 方法签名以支持传入主动方输入上下文,增强效果添加时的控制逻辑。 修复部分效果在添加状态时未正确传递施加者信息的问题。 此外,清理了部分注释和无用代码,使逻辑更清晰。 ```
33 lines
654 B
Go
33 lines
654 B
Go
package effect
|
||
|
||
import (
|
||
"blazing/logic/service/fight/info"
|
||
"blazing/logic/service/fight/input"
|
||
"blazing/logic/service/fight/node"
|
||
)
|
||
|
||
/**
|
||
* m%令本方疲惫,n回合无法攻击
|
||
*/
|
||
|
||
func init() {
|
||
input.InitEffect(input.EffectType.Skill, 20, &Effect20{})
|
||
|
||
}
|
||
|
||
type Effect20 struct {
|
||
node.EffectNode
|
||
}
|
||
|
||
// 使用技能时,不可被继承,继承Miss和Hit就行
|
||
func (e *Effect20) OnSkill() bool {
|
||
ok, _, _ := e.Input.Player.Roll(e.SideEffectArgs[0], 100)
|
||
if !ok {
|
||
return true
|
||
}
|
||
t := input.Geteffect(input.EffectType.Status, int(info.PetStatus.Tired))
|
||
t.Duration(e.SideEffectArgs[1])
|
||
e.Ctx().Our.AddEffect(e.Ctx().Our, t)
|
||
return true
|
||
}
|