diff options
| author | chai <215380520@qq.com> | 2024-05-19 16:05:01 +0800 |
|---|---|---|
| committer | chai <215380520@qq.com> | 2024-05-19 16:05:01 +0800 |
| commit | c5f145786f4c6d2fe4bea831dfc16e52228920a5 (patch) | |
| tree | a6ead7ea8266c767d58ed0f816dcd7a1dd75bd65 /Thronefall_1_0/GameCode/HighscorePreviewUI.cs | |
| parent | 48b64e573a1709dc923cb9162b55be0246b3ff63 (diff) | |
* move
Diffstat (limited to 'Thronefall_1_0/GameCode/HighscorePreviewUI.cs')
| -rw-r--r-- | Thronefall_1_0/GameCode/HighscorePreviewUI.cs | 66 |
1 files changed, 66 insertions, 0 deletions
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 = "<style=Body Light>"; + + 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<SteamManager.LeaderboardEntry> 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 += "-"; + } + } +} |
