Implemented leaderboard updates
This commit is contained in:
parent
c7011efc30
commit
316325b98d
|
@ -143,6 +143,7 @@ endif (NOT MSVC)
|
||||||
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DDEBUG")
|
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DDEBUG")
|
||||||
if (STEAM)
|
if (STEAM)
|
||||||
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DSTEAM_BUILD")
|
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DSTEAM_BUILD")
|
||||||
|
set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -DSTEAM_BUILD")
|
||||||
endif ()
|
endif ()
|
||||||
if (NOT MSVC)
|
if (NOT MSVC)
|
||||||
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -D__FNAME__='\"$(subst ${CMAKE_SOURCE_DIR}/,,$(abspath $<))\"'")
|
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -D__FNAME__='\"$(subst ${CMAKE_SOURCE_DIR}/,,$(abspath $<))\"'")
|
||||||
|
|
|
@ -632,6 +632,7 @@ end_game_details(void)
|
||||||
{
|
{
|
||||||
gui_log("You earned %.2f gold", gPlayer->gold);
|
gui_log("You earned %.2f gold", gPlayer->gold);
|
||||||
gui_event_message("You earned %.2f gold", gPlayer->gold);
|
gui_event_message("You earned %.2f gold", gPlayer->gold);
|
||||||
|
|
||||||
if (hiscore_get_top_gold() < gPlayer->gold) {
|
if (hiscore_get_top_gold() < gPlayer->gold) {
|
||||||
gui_event_message("NEW HIGHSCORE");
|
gui_event_message("NEW HIGHSCORE");
|
||||||
gui_log("NEW HIGHSCORE");
|
gui_log("NEW HIGHSCORE");
|
||||||
|
@ -854,6 +855,9 @@ run_game(void)
|
||||||
gGameState = GAME_OVER;
|
gGameState = GAME_OVER;
|
||||||
createInGameGameOverMenu();
|
createInGameGameOverMenu();
|
||||||
hiscore_register(gPlayer, cLevel);
|
hiscore_register(gPlayer, cLevel);
|
||||||
|
#ifdef STEAM_BUILD
|
||||||
|
steam_register_score((int)hiscore_get_top_gold());
|
||||||
|
#endif // STEAM_BUILD
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
check_next_level();
|
check_next_level();
|
||||||
|
|
|
@ -16,6 +16,7 @@ static Uint8 numAchievements = 5;
|
||||||
|
|
||||||
static bool m_Initiated = false;
|
static bool m_Initiated = false;
|
||||||
static Sint64 m_AppID = 0;
|
static Sint64 m_AppID = 0;
|
||||||
|
static Sint64 m_hLeaderboard = 0;
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
steam_request_stats()
|
steam_request_stats()
|
||||||
|
@ -37,14 +38,21 @@ stats_stored(void)
|
||||||
debug("Steam stats stored");
|
debug("Steam stats stored");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
leaderboard_received(Sint64 hLeaderboard)
|
||||||
|
{
|
||||||
|
m_hLeaderboard = hLeaderboard;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
steam_init()
|
steam_init()
|
||||||
{
|
{
|
||||||
|
c_SteamAPI_SetCallbacks(stats_received, stats_stored, leaderboard_received);
|
||||||
m_AppID = c_SteamAPI_Init();
|
m_AppID = c_SteamAPI_Init();
|
||||||
m_Initiated = m_AppID != 0;
|
m_Initiated = m_AppID != 0;
|
||||||
if (m_Initiated) {
|
if (m_Initiated) {
|
||||||
c_SteamAPI_SetCallbacks(stats_received, stats_stored);
|
|
||||||
steam_request_stats();
|
steam_request_stats();
|
||||||
|
c_SteamUserStats_FindLeaderboard("Highscore");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,3 +77,10 @@ void steam_set_achievement(EAchievement eAch)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void steam_register_score(Sint32 nScore)
|
||||||
|
{
|
||||||
|
if (!m_hLeaderboard)
|
||||||
|
return;
|
||||||
|
c_SteamUserStats_UploadLeaderboardScore(m_hLeaderboard, nScore);
|
||||||
|
}
|
||||||
|
|
|
@ -29,4 +29,6 @@ void steam_shutdown(void);
|
||||||
|
|
||||||
void steam_run_callbacks(void);
|
void steam_run_callbacks(void);
|
||||||
|
|
||||||
void steam_set_achievement(EAchievement eAch);
|
void steam_set_achievement(EAchievement eAch);
|
||||||
|
|
||||||
|
void steam_register_score(Sint32 nScore);
|
|
@ -11,9 +11,11 @@ static bool m_RecvCB = false;
|
||||||
|
|
||||||
static void(*statsReceivedCb)(void) = NULL;
|
static void(*statsReceivedCb)(void) = NULL;
|
||||||
static void(*statsStoredCb)(void) = NULL;
|
static void(*statsStoredCb)(void) = NULL;
|
||||||
|
static void(*leaderBoardReceived)(int64) = NULL;
|
||||||
|
|
||||||
|
|
||||||
extern "C" int64 c_SteamAPI_Init()
|
extern "C" int64
|
||||||
|
c_SteamAPI_Init()
|
||||||
{
|
{
|
||||||
if (SteamAPI_Init()) {
|
if (SteamAPI_Init()) {
|
||||||
m_AppId = SteamUtils()->GetAppID();
|
m_AppId = SteamUtils()->GetAppID();
|
||||||
|
@ -24,13 +26,8 @@ extern "C" int64 c_SteamAPI_Init()
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" void c_SteamAPI_SetCallbacks(void(*recvCB)(void), void(*storCB)(void))
|
extern "C" int64
|
||||||
{
|
c_SteamAPI_GetAppID()
|
||||||
statsReceivedCb = recvCB;
|
|
||||||
statsStoredCb = storCB;
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" int64 c_SteamAPI_GetAppID()
|
|
||||||
{
|
{
|
||||||
if (!m_Initiated)
|
if (!m_Initiated)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -38,19 +35,29 @@ extern "C" int64 c_SteamAPI_GetAppID()
|
||||||
return m_AppId;
|
return m_AppId;
|
||||||
}
|
}
|
||||||
|
|
||||||
void c_SteamAPI_RunCallbacks(void)
|
void
|
||||||
|
c_SteamAPI_RunCallbacks(void)
|
||||||
{
|
{
|
||||||
if (m_Initiated)
|
if (m_Initiated)
|
||||||
SteamAPI_RunCallbacks();
|
SteamAPI_RunCallbacks();
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" void c_SteamAPI_Shutdown()
|
extern "C" void c_SteamAPI_SetCallbacks(void(*recvCB)(void), void(*storCB)(void), void(*recvLB)(int64_t))
|
||||||
|
{
|
||||||
|
statsReceivedCb = recvCB;
|
||||||
|
statsStoredCb = storCB;
|
||||||
|
leaderBoardReceived = recvLB;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" void
|
||||||
|
c_SteamAPI_Shutdown()
|
||||||
{
|
{
|
||||||
delete m_CallbackHandler;
|
delete m_CallbackHandler;
|
||||||
SteamAPI_Shutdown();
|
SteamAPI_Shutdown();
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" bool c_SteamUserStats_RequestCurrentStats()
|
extern "C" bool
|
||||||
|
c_SteamUserStats_RequestCurrentStats()
|
||||||
{
|
{
|
||||||
if (NULL == SteamUserStats() || NULL == SteamUser())
|
if (NULL == SteamUserStats() || NULL == SteamUser())
|
||||||
return false;
|
return false;
|
||||||
|
@ -60,7 +67,8 @@ extern "C" bool c_SteamUserStats_RequestCurrentStats()
|
||||||
return SteamUserStats()->RequestCurrentStats();
|
return SteamUserStats()->RequestCurrentStats();
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" bool c_SteamUserStats_SetAchievement(const char *pchName)
|
extern "C" bool
|
||||||
|
c_SteamUserStats_SetAchievement(const char *pchName)
|
||||||
{
|
{
|
||||||
if (!m_RecvCB)
|
if (!m_RecvCB)
|
||||||
return false;
|
return false;
|
||||||
|
@ -71,20 +79,44 @@ extern "C" bool c_SteamUserStats_SetAchievement(const char *pchName)
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" void c_SteamUserStats_GetAchievement(const char *achId, bool *achieved)
|
extern "C" void
|
||||||
|
c_SteamUserStats_GetAchievement(const char *achId, bool *achieved)
|
||||||
{
|
{
|
||||||
|
if (!m_Initiated)
|
||||||
|
return;
|
||||||
|
|
||||||
SteamUserStats()->GetAchievement(achId, achieved);
|
SteamUserStats()->GetAchievement(achId, achieved);
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" const char* c_SteamUserStats_GetAchievementDisplayAttribute(const char *achId, const char *attrName)
|
extern "C" const char*
|
||||||
|
c_SteamUserStats_GetAchievementDisplayAttribute(const char *achId, const char *attrName)
|
||||||
{
|
{
|
||||||
return SteamUserStats()->GetAchievementDisplayAttribute(achId, attrName);
|
return SteamUserStats()->GetAchievementDisplayAttribute(achId, attrName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern "C" void
|
||||||
|
c_SteamUserStats_FindLeaderboard(const char * name)
|
||||||
|
{
|
||||||
|
if (!m_Initiated)
|
||||||
|
return;
|
||||||
|
|
||||||
|
SteamAPICall_t hSteamAPICall = SteamUserStats()->FindLeaderboard(name);
|
||||||
|
m_CallbackHandler->m_FindLeaderboardCallResult.Set(hSteamAPICall, m_CallbackHandler, &CallbackHandler::OnFindLeaderboard);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" void c_SteamUserStats_UploadLeaderboardScore(int64_t hLeaderboard, int32 nScore)
|
||||||
|
{
|
||||||
|
if (!hLeaderboard || !m_Initiated)
|
||||||
|
return;
|
||||||
|
|
||||||
|
SteamUserStats()->UploadLeaderboardScore(hLeaderboard, k_ELeaderboardUploadScoreMethodKeepBest, nScore, nullptr, 0);
|
||||||
|
}
|
||||||
|
|
||||||
CallbackHandler::CallbackHandler() :
|
CallbackHandler::CallbackHandler() :
|
||||||
m_CallbackUserStatsReceived(this, &CallbackHandler::OnUserStatsReceived),
|
m_CallbackUserStatsReceived(this, &CallbackHandler::OnUserStatsReceived),
|
||||||
m_CallbackUserStatsStored(this, &CallbackHandler::OnUserStatsStored)
|
m_CallbackUserStatsStored(this, &CallbackHandler::OnUserStatsStored)
|
||||||
{
|
{
|
||||||
|
// Nothing
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -106,3 +138,12 @@ CallbackHandler::OnUserStatsStored(UserStatsStored_t *pCallback)
|
||||||
if (statsStoredCb && k_EResultOK == pCallback->m_eResult)
|
if (statsStoredCb && k_EResultOK == pCallback->m_eResult)
|
||||||
statsStoredCb();
|
statsStoredCb();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CallbackHandler::OnFindLeaderboard(LeaderboardFindResult_t * pCallback, bool bIOFailiure)
|
||||||
|
{
|
||||||
|
if (bIOFailiure || !pCallback->m_bLeaderboardFound)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (leaderBoardReceived)
|
||||||
|
leaderBoardReceived(pCallback->m_hSteamLeaderboard);
|
||||||
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ void
|
||||||
c_SteamAPI_RunCallbacks(void);
|
c_SteamAPI_RunCallbacks(void);
|
||||||
|
|
||||||
void
|
void
|
||||||
c_SteamAPI_SetCallbacks(void(*)(void), void(*)(void));
|
c_SteamAPI_SetCallbacks(void(*)(void), void(*)(void), void(*)(int64_t));
|
||||||
|
|
||||||
bool
|
bool
|
||||||
c_SteamUserStats_RequestCurrentStats();
|
c_SteamUserStats_RequestCurrentStats();
|
||||||
|
@ -26,6 +26,12 @@ c_SteamUserStats_GetAchievement(const char *achId, bool *achieved);
|
||||||
const char *
|
const char *
|
||||||
c_SteamUserStats_GetAchievementDisplayAttribute(const char *achId, const char *attrName);
|
c_SteamUserStats_GetAchievementDisplayAttribute(const char *achId, const char *attrName);
|
||||||
|
|
||||||
|
void
|
||||||
|
c_SteamUserStats_FindLeaderboard(const char *name);
|
||||||
|
|
||||||
|
void
|
||||||
|
c_SteamUserStats_UploadLeaderboardScore(int64_t hLeaderboard, int32_t nScore);
|
||||||
|
|
||||||
void
|
void
|
||||||
c_SteamAPI_Shutdown();
|
c_SteamAPI_Shutdown();
|
||||||
|
|
||||||
|
@ -36,5 +42,8 @@ public:
|
||||||
CallbackHandler();
|
CallbackHandler();
|
||||||
STEAM_CALLBACK(CallbackHandler, OnUserStatsReceived, UserStatsReceived_t, m_CallbackUserStatsReceived);
|
STEAM_CALLBACK(CallbackHandler, OnUserStatsReceived, UserStatsReceived_t, m_CallbackUserStatsReceived);
|
||||||
STEAM_CALLBACK(CallbackHandler, OnUserStatsStored, UserStatsStored_t, m_CallbackUserStatsStored);
|
STEAM_CALLBACK(CallbackHandler, OnUserStatsStored, UserStatsStored_t, m_CallbackUserStatsStored);
|
||||||
|
CCallResult<CallbackHandler, LeaderboardFindResult_t> m_FindLeaderboardCallResult;
|
||||||
|
|
||||||
|
void OnFindLeaderboard(LeaderboardFindResult_t *pCallback, bool bIOFailiure);
|
||||||
};
|
};
|
||||||
#endif // __cplusplus
|
#endif // __cplusplus
|
Loading…
Reference in New Issue