summaryrefslogtreecommitdiff
path: root/Client/Assets/Scripts/XMainClient/Buff/XBuffKill.cs
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2021-01-25 14:28:30 +0800
committerchai <chaifix@163.com>2021-01-25 14:28:30 +0800
commit6eb915c129fc90c6f4c82ae097dd6ffad5239efc (patch)
tree7dd2be50edf41f36b60fac84696e731c13afe617 /Client/Assets/Scripts/XMainClient/Buff/XBuffKill.cs
+scripts
Diffstat (limited to 'Client/Assets/Scripts/XMainClient/Buff/XBuffKill.cs')
-rw-r--r--Client/Assets/Scripts/XMainClient/Buff/XBuffKill.cs45
1 files changed, 45 insertions, 0 deletions
diff --git a/Client/Assets/Scripts/XMainClient/Buff/XBuffKill.cs b/Client/Assets/Scripts/XMainClient/Buff/XBuffKill.cs
new file mode 100644
index 00000000..39338059
--- /dev/null
+++ b/Client/Assets/Scripts/XMainClient/Buff/XBuffKill.cs
@@ -0,0 +1,45 @@
+using System;
+using XUtliPoolLib;
+
+namespace XMainClient
+{
+ internal class XBuffKill : BuffEffect
+ {
+ public override XBuffEffectPrioriy Priority
+ {
+ get
+ {
+ return XBuffEffectPrioriy.BEP_Kill;
+ }
+ }
+
+ public static bool TryCreate(BuffTable.RowData rowData, XBuff buff)
+ {
+ bool flag = rowData.Kill == 0;
+ bool result;
+ if (flag)
+ {
+ result = false;
+ }
+ else
+ {
+ buff.AddEffect(new XBuffKill());
+ result = true;
+ }
+ return result;
+ }
+
+ public override void OnAdd(XEntity entity, CombatEffectHelper pEffectHelper)
+ {
+ }
+
+ public override void OnRemove(XEntity entity, bool IsReplaced)
+ {
+ bool flag = !IsReplaced && !entity.IsDead && !entity.Buffs.bLeavingScene && !entity.Buffs.bDestroying;
+ if (flag)
+ {
+ XSingleton<XDeath>.singleton.DeathDetect(entity, null, true);
+ }
+ }
+ }
+}