From c5f145786f4c6d2fe4bea831dfc16e52228920a5 Mon Sep 17 00:00:00 2001 From: chai <215380520@qq.com> Date: Sun, 19 May 2024 16:05:01 +0800 Subject: * move --- Thronefall_1_0/GameCode/HighscorePreviewUI.cs | 66 +++++++++++++++++++++++++++ 1 file changed, 66 insertions(+) create mode 100644 Thronefall_1_0/GameCode/HighscorePreviewUI.cs (limited to 'Thronefall_1_0/GameCode/HighscorePreviewUI.cs') diff --git a/Thronefall_1_0/GameCode/HighscorePreviewUI.cs b/Thronefall_1_0/GameCode/HighscorePreviewUI.cs new file mode 100644 index 0000000..d8983f9 --- /dev/null +++ b/Thronefall_1_0/GameCode/HighscorePreviewUI.cs @@ -0,0 +1,66 @@ +using System.Collections.Generic; +using I2.Loc; +using Steamworks; +using TMPro; +using UnityEngine; + +public class HighscorePreviewUI : MonoBehaviour +{ + public TMP_Text highscore; + + public TMP_Text friendsRank; + + private bool subscribedToSteamManager; + + private readonly string lightTextCue = ""; + + private void OnEnable() + { + int highscoreBest = LevelProgressManager.instance.GetLevelDataForScene(LevelInteractor.lastActivatedLevelInteractor.sceneName).highscoreBest; + string text = ((highscoreBest != 0) ? highscoreBest.ToString() : "-"); + highscore.text = LocalizationManager.GetTranslation("Menu/Highscore") + ": " + lightTextCue + text; + friendsRank.text = LocalizationManager.GetTranslation("Menu/Friends Rank") + ": " + lightTextCue + "-"; + SubscribeToSteamManger(); + SteamManager.Instance.DownloadFriendsHighscores(LevelInteractor.lastActivatedLevelInteractor.sceneName); + } + + private void SubscribeToSteamManger() + { + if (!subscribedToSteamManager) + { + SteamManager.Instance.OnLeaderboardDownloadCallbackComplete.AddListener(RefreshUI); + subscribedToSteamManager = true; + } + } + + public void RefreshUI() + { + friendsRank.text = LocalizationManager.GetTranslation("Menu/Friends Rank") + ": " + lightTextCue; + List lastDownloadedLeaderboardEntires = SteamManager.Instance.lastDownloadedLeaderboardEntires; + if (lastDownloadedLeaderboardEntires.Count > 0) + { + int num = 0; + int num2 = 1; + foreach (SteamManager.LeaderboardEntry item in lastDownloadedLeaderboardEntires) + { + if (item.username == SteamFriends.GetPersonaName()) + { + num = num2; + break; + } + num2++; + } + if (num == 0) + { + friendsRank.text += "-"; + return; + } + TMP_Text tMP_Text = friendsRank; + tMP_Text.text = tMP_Text.text + "#" + num; + } + else + { + friendsRank.text += "-"; + } + } +} -- cgit v1.1-26-g67d0