summaryrefslogtreecommitdiff
path: root/Client/Assets/Scripts/XMainClient/XSubSysRedPointMgr.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/XSubSysRedPointMgr.cs
+scripts
Diffstat (limited to 'Client/Assets/Scripts/XMainClient/XSubSysRedPointMgr.cs')
-rw-r--r--Client/Assets/Scripts/XMainClient/XSubSysRedPointMgr.cs70
1 files changed, 70 insertions, 0 deletions
diff --git a/Client/Assets/Scripts/XMainClient/XSubSysRedPointMgr.cs b/Client/Assets/Scripts/XMainClient/XSubSysRedPointMgr.cs
new file mode 100644
index 00000000..3d7d8d15
--- /dev/null
+++ b/Client/Assets/Scripts/XMainClient/XSubSysRedPointMgr.cs
@@ -0,0 +1,70 @@
+using System;
+using System.Collections.Generic;
+using UILib;
+using UnityEngine;
+using XUtliPoolLib;
+
+namespace XMainClient
+{
+ internal class XSubSysRedPointMgr
+ {
+ public List<XSubSysRedPointMgr.RedPointInfo> _btns = new List<XSubSysRedPointMgr.RedPointInfo>();
+
+ public class RedPointInfo
+ {
+ public IXUIObject _btn = null;
+
+ public Transform redPoint = null;
+ }
+
+ public void SetupRedPoints(IXUIObject[] btns)
+ {
+ this._btns.Clear();
+ this.Append(btns);
+ this.UpdateRedPointUI();
+ }
+
+ public void Append(IXUIObject[] btns)
+ {
+ bool flag = btns != null;
+ if (flag)
+ {
+ foreach (IXUIObject btn in btns)
+ {
+ this.Append(btn);
+ }
+ }
+ }
+
+ public void Append(IXUIObject btn)
+ {
+ bool flag = btn != null;
+ if (flag)
+ {
+ XSubSysRedPointMgr.RedPointInfo redPointInfo = new XSubSysRedPointMgr.RedPointInfo();
+ redPointInfo._btn = btn;
+ redPointInfo.redPoint = btn.gameObject.transform.Find("RedPoint");
+ this._btns.Add(redPointInfo);
+ }
+ }
+
+ public void UpdateRedPointUI()
+ {
+ bool flag = this._btns == null;
+ if (!flag)
+ {
+ XGameSysMgr singleton = XSingleton<XGameSysMgr>.singleton;
+ for (int i = 0; i < this._btns.Count; i++)
+ {
+ XSubSysRedPointMgr.RedPointInfo redPointInfo = this._btns[i];
+ bool flag2 = redPointInfo._btn == null || redPointInfo.redPoint == null;
+ if (!flag2)
+ {
+ XSysDefine sys = (XSysDefine)redPointInfo._btn.ID;
+ redPointInfo.redPoint.gameObject.SetActive(singleton.GetSysRedPointState(sys));
+ }
+ }
+ }
+ }
+ }
+}