summaryrefslogtreecommitdiff
path: root/Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerAlways.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/XBuffTriggerAlways.cs
+scripts
Diffstat (limited to 'Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerAlways.cs')
-rw-r--r--Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerAlways.cs35
1 files changed, 35 insertions, 0 deletions
diff --git a/Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerAlways.cs b/Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerAlways.cs
new file mode 100644
index 00000000..8cdb2b6f
--- /dev/null
+++ b/Client/Assets/Scripts/XMainClient/Buff/XBuffTriggerAlways.cs
@@ -0,0 +1,35 @@
+using System;
+using XUtliPoolLib;
+
+namespace XMainClient
+{
+ internal class XBuffTriggerAlways : XBuffTrigger
+ {
+ private uint _TimeToken = 0u;
+
+ private XTimerMgr.ElapsedEventHandler _timeCb = null;
+
+ public XBuffTriggerAlways(XBuff buff) : base(buff)
+ {
+ this._timeCb = new XTimerMgr.ElapsedEventHandler(this.OnTimer);
+ }
+
+ public override void OnAdd(XEntity entity, CombatEffectHelper pEffectHelper)
+ {
+ base.OnAdd(entity, pEffectHelper);
+ this.OnTimer(null);
+ }
+
+ public override void OnRemove(XEntity entity, bool IsReplaced)
+ {
+ base.OnRemove(entity, IsReplaced);
+ XSingleton<XTimerMgr>.singleton.KillTimer(this._TimeToken);
+ }
+
+ public void OnTimer(object o)
+ {
+ base.Trigger();
+ this._TimeToken = XSingleton<XTimerMgr>.singleton.SetTimer(1f, this._timeCb, o);
+ }
+ }
+}