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/HeroBattleRankDlg.cs |
+scripts
Diffstat (limited to 'Client/Assets/Scripts/XMainClient/HeroBattleRankDlg.cs')
-rw-r--r-- | Client/Assets/Scripts/XMainClient/HeroBattleRankDlg.cs | 144 |
1 files changed, 144 insertions, 0 deletions
diff --git a/Client/Assets/Scripts/XMainClient/HeroBattleRankDlg.cs b/Client/Assets/Scripts/XMainClient/HeroBattleRankDlg.cs new file mode 100644 index 00000000..375b963b --- /dev/null +++ b/Client/Assets/Scripts/XMainClient/HeroBattleRankDlg.cs @@ -0,0 +1,144 @@ +using System;
+using UILib;
+using UnityEngine;
+using XMainClient.UI.UICommon;
+
+namespace XMainClient
+{
+ internal class HeroBattleRankDlg : DlgBase<HeroBattleRankDlg, HeroBattleRankBehavior>
+ {
+ public override string fileName
+ {
+ get
+ {
+ return "GameSystem/HeroBattleRankDlg";
+ }
+ }
+
+ public override bool autoload
+ {
+ get
+ {
+ return true;
+ }
+ }
+
+ private XHeroBattleDocument _doc = null;
+
+ protected override void OnLoad()
+ {
+ base.OnLoad();
+ }
+
+ public override void RegisterEvent()
+ {
+ base.RegisterEvent();
+ }
+
+ protected override void OnUnload()
+ {
+ base.OnUnload();
+ }
+
+ protected override void Init()
+ {
+ base.Init();
+ base.uiBehaviour.m_RankWrapContent.RegisterItemUpdateEventHandler(new WrapItemUpdateEventHandler(this.WrapListUpdated));
+ this._doc = XDocuments.GetSpecificDocument<XHeroBattleDocument>(XHeroBattleDocument.uuID);
+ base.uiBehaviour.m_CloseBtn.RegisterClickEventHandler(new ButtonClickEventHandler(this.OnCloseDlg));
+ }
+
+ private bool OnCloseDlg(IXUIButton button)
+ {
+ this.SetVisible(false, true);
+ return true;
+ }
+
+ protected override void OnHide()
+ {
+ base.OnHide();
+ }
+
+ protected override void OnShow()
+ {
+ base.OnShow();
+ }
+
+ public void SetupRankFrame()
+ {
+ this.SetRankTpl(base.uiBehaviour.m_MyRankTs, 0, true);
+ base.uiBehaviour.m_RankWrapContent.SetContentCount(this._doc.LastWeek_MainRankList.Count, false);
+ base.uiBehaviour.m_RankScrollView.ResetPosition();
+ }
+
+ public void WrapListUpdated(Transform t, int index)
+ {
+ bool flag = index < 0 || index >= this._doc.LastWeek_MainRankList.Count;
+ if (!flag)
+ {
+ this.SetRankTpl(t, index, false);
+ }
+ }
+
+ public void SetRankTpl(Transform t, int index, bool isMy)
+ {
+ HeroBattleRankData heroBattleRankData = isMy ? this._doc.LastWeek_MyRankData : this._doc.LastWeek_MainRankList[index];
+ IXUILabel ixuilabel = t.Find("Rank").GetComponent("XUILabel") as IXUILabel;
+ IXUISprite ixuisprite = t.Find("RankImage").GetComponent("XUISprite") as IXUISprite;
+ IXUILabel ixuilabel2 = t.Find("Name").GetComponent("XUILabel") as IXUILabel;
+ IXUILabel ixuilabel3 = t.Find("Value1").GetComponent("XUILabel") as IXUILabel;
+ IXUILabel ixuilabel4 = t.Find("Value2").GetComponent("XUILabel") as IXUILabel;
+ bool flag = heroBattleRankData.rank < 3u;
+ if (flag)
+ {
+ ixuisprite.SetVisible(true);
+ ixuilabel.SetVisible(false);
+ ixuisprite.spriteName = string.Format("N{0}", heroBattleRankData.rank + 1u);
+ }
+ else
+ {
+ ixuisprite.SetVisible(false);
+ ixuilabel.SetVisible(true);
+ ixuilabel.SetText(string.Format("No.{0}", heroBattleRankData.rank + 1u));
+ }
+ if (isMy)
+ {
+ bool flag2 = heroBattleRankData.rank == uint.MaxValue;
+ if (flag2)
+ {
+ base.uiBehaviour.m_OutOfRank.SetActive(true);
+ ixuisprite.SetVisible(false);
+ ixuilabel.SetVisible(false);
+ }
+ else
+ {
+ base.uiBehaviour.m_OutOfRank.SetActive(false);
+ }
+ }
+ bool flag3 = heroBattleRankData.fightTotal == 0u;
+ int num;
+ if (flag3)
+ {
+ num = 0;
+ }
+ else
+ {
+ num = (int)Mathf.Floor(heroBattleRankData.winTotal * 100u / heroBattleRankData.fightTotal);
+ }
+ ixuilabel2.SetText(heroBattleRankData.name);
+ ixuilabel3.SetText(string.Format("{0}%", num));
+ ixuilabel4.SetText(heroBattleRankData.fightTotal.ToString());
+ ixuilabel2.ID = heroBattleRankData.roleID;
+ ixuilabel2.RegisterLabelClickEventHandler(new LabelClickEventHandler(this.OnPlayerInfoClick));
+ }
+
+ private void OnPlayerInfoClick(IXUILabel label)
+ {
+ bool flag = label.ID == 0UL;
+ if (!flag)
+ {
+ XCharacterCommonMenuDocument.ReqCharacterMenuInfo(label.ID, false);
+ }
+ }
+ }
+}
|