summaryrefslogtreecommitdiff
path: root/Client/Assets/Scripts/XMainClient/Monster_broo_black_teleport_back.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/Monster_broo_black_teleport_back.cs
+scripts
Diffstat (limited to 'Client/Assets/Scripts/XMainClient/Monster_broo_black_teleport_back.cs')
-rw-r--r--Client/Assets/Scripts/XMainClient/Monster_broo_black_teleport_back.cs63
1 files changed, 63 insertions, 0 deletions
diff --git a/Client/Assets/Scripts/XMainClient/Monster_broo_black_teleport_back.cs b/Client/Assets/Scripts/XMainClient/Monster_broo_black_teleport_back.cs
new file mode 100644
index 00000000..75f38d70
--- /dev/null
+++ b/Client/Assets/Scripts/XMainClient/Monster_broo_black_teleport_back.cs
@@ -0,0 +1,63 @@
+using System;
+using XUtliPoolLib;
+
+namespace XMainClient
+{
+ internal class Monster_broo_black_teleport_back
+ {
+ private static uint _token = 0u;
+
+ private static bool _veiled = false;
+
+ private static float _startVeil = 0.267f;
+
+ private static float _fadeOutTime = 0.1f;
+
+ private static float _veilDuration = 0.3f;
+
+ private static float _fadeInTime = 0.2f;
+
+ public static bool Disappear(XSkill skill)
+ {
+ bool casting = skill.Casting;
+ if (casting)
+ {
+ bool flag = !Monster_broo_black_teleport_back._veiled;
+ if (flag)
+ {
+ Monster_broo_black_teleport_back._veiled = true;
+ Monster_broo_black_teleport_back._token = XSingleton<XTimerMgr>.singleton.SetTimer(Monster_broo_black_teleport_back._startVeil, new XTimerMgr.ElapsedEventHandler(Monster_broo_black_teleport_back.Veil), skill.Firer);
+ }
+ }
+ else
+ {
+ XSingleton<XTimerMgr>.singleton.KillTimer(Monster_broo_black_teleport_back._token);
+ Monster_broo_black_teleport_back.Unveil(skill.Firer);
+ Monster_broo_black_teleport_back._veiled = false;
+ }
+ return true;
+ }
+
+ private static void Veil(object o)
+ {
+ XFadeOutEventArgs @event = XEventPool<XFadeOutEventArgs>.GetEvent();
+ @event.Out = Monster_broo_black_teleport_back._fadeOutTime;
+ @event.Firer = (o as XEntity);
+ XSingleton<XEventMgr>.singleton.FireEvent(@event);
+ Monster_broo_black_teleport_back._token = XSingleton<XTimerMgr>.singleton.SetTimer(Monster_broo_black_teleport_back._veilDuration, new XTimerMgr.ElapsedEventHandler(Monster_broo_black_teleport_back.Unveil), o);
+ }
+
+ private static void Unveil(object o)
+ {
+ bool flag = Monster_broo_black_teleport_back._token > 0u;
+ if (flag)
+ {
+ Monster_broo_black_teleport_back._token = 0u;
+ XFadeInEventArgs @event = XEventPool<XFadeInEventArgs>.GetEvent();
+ @event.In = Monster_broo_black_teleport_back._fadeInTime;
+ @event.Firer = (o as XEntity);
+ XSingleton<XEventMgr>.singleton.FireEvent(@event);
+ }
+ }
+ }
+}