From 6eb915c129fc90c6f4c82ae097dd6ffad5239efc Mon Sep 17 00:00:00 2001 From: chai Date: Mon, 25 Jan 2021 14:28:30 +0800 Subject: +scripts --- .../Scripts/XMainClient/Buff/XBuffTriggerByLife.cs | 35 ++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerByLife.cs (limited to 'Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerByLife.cs') diff --git a/Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerByLife.cs b/Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerByLife.cs new file mode 100644 index 00000000..f54a6aa6 --- /dev/null +++ b/Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerByLife.cs @@ -0,0 +1,35 @@ +using System; + +namespace XMainClient +{ + internal class XBuffTriggerByLife : XBuffTrigger + { + private float _hpTriggerPercent = 0f; + + public XBuffTriggerByLife(XBuff buff) : base(buff) + { + this._hpTriggerPercent = base._GetTriggerParam(buff.BuffInfo, 0); + } + + public override bool CheckTriggerCondition() + { + bool isDummy = base.Entity.IsDummy; + return !isDummy && base.Entity.Attributes.HPPercent <= (double)this._hpTriggerPercent; + } + + public override void OnAdd(XEntity entity, CombatEffectHelper pEffectHelper) + { + base.OnAdd(entity, pEffectHelper); + base.Trigger(); + } + + public override void OnAttributeChanged(XAttrChangeEventArgs e) + { + bool flag = e.AttrKey == XAttributeDefine.XAttr_CurrentHP_Basic; + if (flag) + { + base.Trigger(); + } + } + } +} -- cgit v1.1-26-g67d0