타이틀 관리 순위표 가져오기
목차
이 항목에서는 타이틀 관리 순위표의 값을 가져오는 방법을 설명합니다.
전체 순위표 가져오기
XblLeaderboardGetLeaderboardAsync를 사용하여 지정된 순위표에 대한 순위표 값을 반환합니다. 결과는 순위표의 맨 위에서 시작하여 순위가 내림차순으로 반환됩니다. 타이틀 관리 통계에서 지원하는 순위표를 쿼리할 때는 queryType
필드를 XblLeaderboardQueryType::TitleManagedStatBackedGlobal
또는 XblLeaderboardQueryType::TitleManagedStatBackedSocial
으로 설정해야 합니다.
C API
auto asyncBlock = std::make_unique<XAsyncBlock>();
asyncBlock->queue = queue;
asyncBlock->context = nullptr;
asyncBlock->callback = [](XAsyncBlock* asyncBlock)
{
std::unique_ptr<XAsyncBlock> asyncBlockPtr{ asyncBlock }; // Take over ownership of the XAsyncBlock*
size_t resultSize;
HRESULT hr = XblLeaderboardGetLeaderboardResultSize(asyncBlock, &resultSize);
if (SUCCEEDED(hr))
{
leaderboardBuffer.resize(resultSize);
XblLeaderboardResult* leaderboard{};
hr = XblLeaderboardGetLeaderboardResult(asyncBlock, resultSize, leaderboardBuffer.data(), &leaderboard, nullptr);
if (SUCCEEDED(hr))
{
// Use XblLeaderboardResult in result
for (auto row = 0u; row < leaderboard->rowsCount; ++row)
{
std::stringstream rowText;
rowText << leaderboard->rows[row].xboxUserId << "\t";
for (auto column = 0u; column < leaderboard->rows[row].columnValuesCount; ++column)
{
rowText << leaderboard->rows[row].columnValues[column] << "\t";
}
}
}
}
};
// XblLeaderboardQuery is set up to query for all leaderboard items here
// see example code in sections below showing how to run other queries
XblLeaderboardQuery leaderboardQuery = {};
pal::strcpy(leaderboardQuery.scid, sizeof(leaderboardQuery.scid), scid.c_str())
leaderboardQuery.statName = statName.c_str();
leaderboardQuery.queryType = XblLeaderboardQueryType::TitleManagedStatBackedGlobal;
HRESULT hr = XblLeaderboardGetLeaderboardAsync(
xboxLiveContext,
leaderboardQuery,
asyncBlock.get());
if (SUCCEEDED(hr))
{
// The call succeeded, so release the std::unique_ptr ownership of XAsyncBlock* since the callback will take over ownership.
// If the call fails, the std::unique_ptr will keep ownership and delete the XAsyncBlock*
asyncBlock.release();
}
참조
- XAsyncBlock
- XblLeaderboardGetLeaderboardAsync
- XblLeaderboardGetLeaderboardResult
- XblLeaderboardGetLeaderboardResultSize
- XblLeaderboardQuery
- XblLeaderboardResult
- XblLeaderboardQueryType
지정된 순위 관련 순위표 가져오기
XblLeaderboardQuery를 만들 때 쿼리 기준을 지정하여 순위표 쿼리에서 필터링된 결과를 가져올 수 있습니다. 지정된 순위에 대한 순위표 값을 가져오려면 위의 예제에서 코드를 사용하되 XblLeaderboardQuery를 만드는 행을 다음 코드로 대체합니다.
C API
XblLeaderboardQuery leaderboardQuery = {};
pal::strcpy(leaderboardQuery.scid, sizeof(leaderboardQuery.scid), scid.c_str());
leaderboardQuery.statName = statName.c_str();
leaderboardQuery.skipResultToRank = 100;
leaderboardQuery.maxItems = 100;
leaderboardQuery.queryType = XblLeaderboardQueryType::TitleManagedStatBackedGlobal;
참조
지정된 플레이어 관련 순위표 가져오기
지정된 플레이어의 관련 순위표 값을 가져오려면 위의 예제에서 코드를 사용하지만 XblLeaderboardQuery를 만드는 줄을 다음 코드로 대체합니다.
C API
XblLeaderboardQuery leaderboardQuery = {};
pal::strcpy(leaderboardQuery.scid, sizeof(leaderboardQuery.scid), scid.c_str());
leaderboardQuery.statName = statName.c_str();
leaderboardQuery.skipToXboxUserId = xboxUserId;
leaderboardQuery.maxItems = 100;
leaderboardQuery.queryType = XblLeaderboardQueryType::TitleManagedStatBackedGlobal;
참조