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/XBuffLifeAddAttack.cs | 61 ++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 Client/Assets/Scripts/XMainClient/Buff/XBuffLifeAddAttack.cs (limited to 'Client/Assets/Scripts/XMainClient/Buff/XBuffLifeAddAttack.cs') diff --git a/Client/Assets/Scripts/XMainClient/Buff/XBuffLifeAddAttack.cs b/Client/Assets/Scripts/XMainClient/Buff/XBuffLifeAddAttack.cs new file mode 100644 index 00000000..83696bfe --- /dev/null +++ b/Client/Assets/Scripts/XMainClient/Buff/XBuffLifeAddAttack.cs @@ -0,0 +1,61 @@ +using System; +using XUtliPoolLib; + +namespace XMainClient +{ + internal class XBuffLifeAddAttack : BuffEffect + { + public override XBuffEffectPrioriy Priority + { + get + { + return XBuffEffectPrioriy.BEP_TargetLifeAddAttack; + } + } + + private XBuff _buff = null; + + private XEntity _entity; + + private XPieceWiseDataMgr m_Data = new XPieceWiseDataMgr(); + + public static bool TryCreate(BuffTable.RowData rowData, XBuff buff) + { + bool flag = rowData.SelfLifeAddAttack.Count == 0; + bool result; + if (flag) + { + result = false; + } + else + { + buff.AddEffect(new XBuffLifeAddAttack(buff)); + result = true; + } + return result; + } + + public XBuffLifeAddAttack(XBuff buff) + { + this._buff = buff; + BuffTable.RowData buffInfo = buff.BuffInfo; + this.m_Data.SetRange(0.0, 0.0, 1.0, 0.0); + this.m_Data.Init(ref buffInfo.SelfLifeAddAttack); + } + + 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 = this._entity.Attributes.HPPercent; + result.Value *= 1.0 + this.m_Data.GetData(hppercent); + } + } +} -- cgit v1.1-26-g67d0