diff options
author | chai <chaifix@163.com> | 2021-01-25 14:28:30 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2021-01-25 14:28:30 +0800 |
commit | 6eb915c129fc90c6f4c82ae097dd6ffad5239efc (patch) | |
tree | 7dd2be50edf41f36b60fac84696e731c13afe617 /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.cs | 63 |
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);
+ }
+ }
+ }
+}
|