From 6eb915c129fc90c6f4c82ae097dd6ffad5239efc Mon Sep 17 00:00:00 2001 From: chai Date: Mon, 25 Jan 2021 14:28:30 +0800 Subject: +scripts --- .../XMainClient/Buff/XBuffTargetLifeAddAttack.cs | 57 ++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 Client/Assets/Scripts/XMainClient/Buff/XBuffTargetLifeAddAttack.cs (limited to 'Client/Assets/Scripts/XMainClient/Buff/XBuffTargetLifeAddAttack.cs') diff --git a/Client/Assets/Scripts/XMainClient/Buff/XBuffTargetLifeAddAttack.cs b/Client/Assets/Scripts/XMainClient/Buff/XBuffTargetLifeAddAttack.cs new file mode 100644 index 00000000..28993230 --- /dev/null +++ b/Client/Assets/Scripts/XMainClient/Buff/XBuffTargetLifeAddAttack.cs @@ -0,0 +1,57 @@ +using System; +using XUtliPoolLib; + +namespace XMainClient +{ + internal class XBuffTargetLifeAddAttack : BuffEffect + { + public override XBuffEffectPrioriy Priority + { + get + { + return XBuffEffectPrioriy.BEP_TargetLifeAddAttack; + } + } + + private XPieceWiseDataMgr m_Data = new XPieceWiseDataMgr(); + + private XEntity _entity; + + public static bool TryCreate(BuffTable.RowData rowData, XBuff buff) + { + bool flag = rowData.TargetLifeAddAttack.Count == 0; + bool result; + if (flag) + { + result = false; + } + else + { + buff.AddEffect(new XBuffTargetLifeAddAttack(ref rowData.TargetLifeAddAttack)); + result = true; + } + return result; + } + + public XBuffTargetLifeAddAttack(ref SeqListRef reducePecents) + { + this.m_Data.SetRange(0.0, 0.0, 1.0, 0.0); + this.m_Data.Init(ref reducePecents); + } + + public override void OnAdd(XEntity entity, CombatEffectHelper pEffectHelper) + { + this._entity = entity; + } + + public override void OnRemove(XEntity entity, bool IsReplaced) + { + } + + public override void OnCastDamage(HurtInfo rawInput, ProjectDamageResult result) + { + double hppercent = rawInput.Target.Attributes.HPPercent; + result.Value *= 1.0 + this.m_Data.GetData(hppercent); + } + } +} -- cgit v1.1-26-g67d0