summaryrefslogtreecommitdiff
path: root/Client/Assets/Scripts/XMainClient/DlgHandlerMgr.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/DlgHandlerMgr.cs
+scripts
Diffstat (limited to 'Client/Assets/Scripts/XMainClient/DlgHandlerMgr.cs')
-rw-r--r--Client/Assets/Scripts/XMainClient/DlgHandlerMgr.cs65
1 files changed, 65 insertions, 0 deletions
diff --git a/Client/Assets/Scripts/XMainClient/DlgHandlerMgr.cs b/Client/Assets/Scripts/XMainClient/DlgHandlerMgr.cs
new file mode 100644
index 00000000..fd80d25f
--- /dev/null
+++ b/Client/Assets/Scripts/XMainClient/DlgHandlerMgr.cs
@@ -0,0 +1,65 @@
+using System;
+using System.Collections.Generic;
+
+namespace XMainClient
+{
+ public class DlgHandlerMgr
+ {
+ private List<DlgHandlerBase> m_ListHandler = new List<DlgHandlerBase>();
+
+ public void Add(DlgHandlerBase handler)
+ {
+ this.m_ListHandler.Add(handler);
+ }
+
+ public void Remove(DlgHandlerBase handler)
+ {
+ this.m_ListHandler.Remove(handler);
+ }
+
+ public void Unload()
+ {
+ for (int i = 0; i < this.m_ListHandler.Count; i++)
+ {
+ this.m_ListHandler[i].UnLoad();
+ }
+ this.m_ListHandler.Clear();
+ }
+
+ public void StackRefresh()
+ {
+ for (int i = 0; i < this.m_ListHandler.Count; i++)
+ {
+ bool flag = this.m_ListHandler[i].IsVisible();
+ if (flag)
+ {
+ this.m_ListHandler[i].StackRefresh();
+ }
+ }
+ }
+
+ public void LeaveStackTop()
+ {
+ for (int i = 0; i < this.m_ListHandler.Count; i++)
+ {
+ bool flag = this.m_ListHandler[i].IsVisible();
+ if (flag)
+ {
+ this.m_ListHandler[i].LeaveStackTop();
+ }
+ }
+ }
+
+ public void OnUpdate()
+ {
+ for (int i = 0; i < this.m_ListHandler.Count; i++)
+ {
+ bool flag = this.m_ListHandler[i].IsVisible();
+ if (flag)
+ {
+ this.m_ListHandler[i].OnUpdate();
+ }
+ }
+ }
+ }
+}