aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/Common/Leaderboards/LeaderboardInterface.cpp
diff options
context:
space:
mode:
authordaoge <3523206925@qq.com>2026-03-03 03:04:10 +0800
committerGitHub <noreply@github.com>2026-03-03 03:04:10 +0800
commitb3feddfef372618c8a9d7a0abcaf18cfad866c18 (patch)
tree267761c3bb39241ba5c347bfbe2254d06686e287 /Minecraft.Client/Common/Leaderboards/LeaderboardInterface.cpp
parent84c31a2331f7a0ec85b9d438992e244f60e5020f (diff)
feat: TU19 (Dec 2014) Features & Content (#155)
* try to resolve merge conflict * feat: TU19 (Dec 2014) Features & Content (#32) * December 2014 files * Working release build * Fix compilation issues * Add sound to Windows64Media * Add DLC content and force Tutorial DLC * Revert "Add DLC content and force Tutorial DLC" This reverts commit 97a43994725008e35fceb984d5549df9c8cea470. * Disable broken light packing * Disable breakpoint during DLC texture map load Allows DLC loading but the DLC textures are still broken * Fix post build not working * ... * fix vs2022 build * fix cmake build --------- Co-authored-by: Loki <lokirautio@gmail.com>
Diffstat (limited to 'Minecraft.Client/Common/Leaderboards/LeaderboardInterface.cpp')
-rw-r--r--Minecraft.Client/Common/Leaderboards/LeaderboardInterface.cpp88
1 files changed, 88 insertions, 0 deletions
diff --git a/Minecraft.Client/Common/Leaderboards/LeaderboardInterface.cpp b/Minecraft.Client/Common/Leaderboards/LeaderboardInterface.cpp
new file mode 100644
index 00000000..07463517
--- /dev/null
+++ b/Minecraft.Client/Common/Leaderboards/LeaderboardInterface.cpp
@@ -0,0 +1,88 @@
+#include "stdafx.h"
+#include "LeaderboardInterface.h"
+
+LeaderboardInterface::LeaderboardInterface(LeaderboardManager *man)
+{
+ m_manager = man;
+ m_pending = false;
+
+ m_filter = (LeaderboardManager::EFilterMode) -1;
+ m_callback = NULL;
+ m_difficulty = 0;
+ m_type = LeaderboardManager::eStatsType_UNDEFINED;
+ m_startIndex = 0;
+ m_readCount = 0;
+
+ m_manager->OpenSession();
+}
+
+LeaderboardInterface::~LeaderboardInterface()
+{
+ m_manager->CancelOperation();
+ m_manager->CloseSession();
+}
+
+void LeaderboardInterface::ReadStats_Friends(LeaderboardReadListener *callback, int difficulty, LeaderboardManager::EStatsType type, PlayerUID myUID, unsigned int startIndex, unsigned int readCount)
+{
+ m_filter = LeaderboardManager::eFM_Friends;
+ m_pending = true;
+
+ m_callback = callback;
+ m_difficulty = difficulty;
+ m_type = type;
+ m_myUID = myUID;
+ m_startIndex = startIndex;
+ m_readCount = readCount;
+
+ tick();
+}
+
+void LeaderboardInterface::ReadStats_MyScore(LeaderboardReadListener *callback, int difficulty, LeaderboardManager::EStatsType type, PlayerUID myUID, unsigned int readCount)
+{
+ m_filter = LeaderboardManager::eFM_MyScore;
+ m_pending = true;
+
+ m_callback = callback;
+ m_difficulty = difficulty;
+ m_type = type;
+ m_myUID = myUID;
+ m_readCount = readCount;
+
+ tick();
+}
+
+void LeaderboardInterface::ReadStats_TopRank(LeaderboardReadListener *callback, int difficulty, LeaderboardManager::EStatsType type, unsigned int startIndex, unsigned int readCount)
+{
+ m_filter = LeaderboardManager::eFM_TopRank;
+ m_pending = true;
+
+ m_callback = callback;
+ m_difficulty = difficulty;
+ m_type = type;
+ m_startIndex = startIndex;
+ m_readCount = readCount;
+
+ tick();
+}
+
+void LeaderboardInterface::CancelOperation()
+{
+ m_manager->CancelOperation();
+ m_pending = false;
+}
+
+void LeaderboardInterface::tick()
+{
+ if (m_pending) m_pending = !callManager();
+}
+
+bool LeaderboardInterface::callManager()
+{
+ switch (m_filter)
+ {
+ case LeaderboardManager::eFM_Friends: return m_manager->ReadStats_Friends(m_callback, m_difficulty, m_type, m_myUID, m_startIndex, m_readCount);
+ case LeaderboardManager::eFM_MyScore: return m_manager->ReadStats_MyScore(m_callback, m_difficulty, m_type, m_myUID, m_readCount);
+ case LeaderboardManager::eFM_TopRank: return m_manager->ReadStats_TopRank(m_callback, m_difficulty, m_type, m_startIndex, m_readCount);
+ default: assert(false); return true;
+ }
+} \ No newline at end of file