2023-06-02 21:20:42 -04:00
|
|
|
// Copyright 2023 Dolphin Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
|
|
|
|
#ifdef USE_RETRO_ACHIEVEMENTS
|
|
|
|
#include "DolphinQt/Achievements/AchievementHeaderWidget.h"
|
|
|
|
|
|
|
|
#include <QGroupBox>
|
|
|
|
#include <QLabel>
|
|
|
|
#include <QLineEdit>
|
|
|
|
#include <QProgressBar>
|
|
|
|
#include <QString>
|
|
|
|
#include <QVBoxLayout>
|
|
|
|
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
#include <rcheevos/include/rc_client.h>
|
|
|
|
|
2023-06-02 21:20:42 -04:00
|
|
|
#include "Core/AchievementManager.h"
|
2023-06-17 12:40:07 -04:00
|
|
|
#include "Core/Config/AchievementSettings.h"
|
2023-06-02 21:20:42 -04:00
|
|
|
#include "Core/Core.h"
|
|
|
|
|
2024-03-19 13:33:51 -04:00
|
|
|
#include "DolphinQt/QtUtils/FromStdString.h"
|
2023-06-02 21:20:42 -04:00
|
|
|
#include "DolphinQt/Settings.h"
|
|
|
|
|
|
|
|
AchievementHeaderWidget::AchievementHeaderWidget(QWidget* parent) : QWidget(parent)
|
|
|
|
{
|
2023-06-15 03:57:58 -04:00
|
|
|
m_user_icon = new QLabel();
|
|
|
|
m_game_icon = new QLabel();
|
|
|
|
m_name = new QLabel();
|
|
|
|
m_points = new QLabel();
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
m_game_progress = new QProgressBar();
|
2024-07-10 08:52:12 -04:00
|
|
|
m_progress_label = new QLabel();
|
2023-06-02 21:20:42 -04:00
|
|
|
m_rich_presence = new QLabel();
|
|
|
|
|
2024-06-15 10:22:32 -04:00
|
|
|
m_name->setWordWrap(true);
|
|
|
|
m_points->setWordWrap(true);
|
|
|
|
m_rich_presence->setWordWrap(true);
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
QSizePolicy sp_retain = m_game_progress->sizePolicy();
|
2023-06-15 03:57:58 -04:00
|
|
|
sp_retain.setRetainSizeWhenHidden(true);
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
m_game_progress->setSizePolicy(sp_retain);
|
2024-07-10 08:52:12 -04:00
|
|
|
m_game_progress->setTextVisible(false);
|
|
|
|
m_progress_label->setStyleSheet(QStringLiteral("background-color:transparent;"));
|
|
|
|
m_progress_label->setAlignment(Qt::AlignCenter);
|
2023-06-15 03:57:58 -04:00
|
|
|
|
|
|
|
QVBoxLayout* icon_col = new QVBoxLayout();
|
|
|
|
icon_col->addWidget(m_user_icon);
|
|
|
|
icon_col->addWidget(m_game_icon);
|
|
|
|
QVBoxLayout* text_col = new QVBoxLayout();
|
|
|
|
text_col->addWidget(m_name);
|
|
|
|
text_col->addWidget(m_points);
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
text_col->addWidget(m_game_progress);
|
2023-06-15 03:57:58 -04:00
|
|
|
text_col->addWidget(m_rich_presence);
|
2024-07-10 08:52:12 -04:00
|
|
|
QVBoxLayout* prog_layout = new QVBoxLayout(m_game_progress);
|
|
|
|
prog_layout->setContentsMargins(0, 0, 0, 0);
|
|
|
|
prog_layout->addWidget(m_progress_label);
|
2023-06-15 03:57:58 -04:00
|
|
|
QHBoxLayout* header_layout = new QHBoxLayout();
|
|
|
|
header_layout->addLayout(icon_col);
|
|
|
|
header_layout->addLayout(text_col);
|
|
|
|
m_header_box = new QGroupBox();
|
|
|
|
m_header_box->setLayout(header_layout);
|
2023-06-02 21:20:42 -04:00
|
|
|
|
|
|
|
QVBoxLayout* m_total = new QVBoxLayout();
|
2023-06-15 03:57:58 -04:00
|
|
|
m_total->addWidget(m_header_box);
|
2023-06-02 21:20:42 -04:00
|
|
|
|
|
|
|
m_total->setContentsMargins(0, 0, 0, 0);
|
|
|
|
m_total->setAlignment(Qt::AlignTop);
|
|
|
|
setLayout(m_total);
|
|
|
|
}
|
|
|
|
|
|
|
|
void AchievementHeaderWidget::UpdateData()
|
|
|
|
{
|
2024-03-09 20:18:40 -05:00
|
|
|
std::lock_guard lg{AchievementManager::GetInstance().GetLock()};
|
2023-12-11 13:18:02 -05:00
|
|
|
auto& instance = AchievementManager::GetInstance();
|
2024-05-03 21:35:01 -04:00
|
|
|
if (!Config::Get(Config::RA_ENABLED) || !instance.HasAPIToken())
|
2023-06-02 21:20:42 -04:00
|
|
|
{
|
2023-06-15 03:57:58 -04:00
|
|
|
m_header_box->setVisible(false);
|
2023-06-02 21:20:42 -04:00
|
|
|
return;
|
|
|
|
}
|
2024-05-03 21:35:01 -04:00
|
|
|
m_header_box->setVisible(true);
|
2023-06-02 21:20:42 -04:00
|
|
|
|
2024-03-19 13:33:51 -04:00
|
|
|
QString user_name = QtUtils::FromStdString(instance.GetPlayerDisplayName());
|
2024-03-27 23:22:10 -04:00
|
|
|
QString game_name = QtUtils::FromStdString(instance.GetGameDisplayName());
|
2024-05-13 19:21:55 -04:00
|
|
|
const AchievementManager::Badge& player_badge = instance.GetPlayerBadge();
|
|
|
|
const AchievementManager::Badge& game_badge = instance.GetGameBadge();
|
2023-06-15 03:57:58 -04:00
|
|
|
|
|
|
|
m_user_icon->setVisible(false);
|
|
|
|
m_user_icon->clear();
|
|
|
|
m_user_icon->setText({});
|
2024-07-15 21:47:59 +02:00
|
|
|
if (!player_badge.data.empty())
|
|
|
|
{
|
|
|
|
QImage i_user_icon(player_badge.data.data(), player_badge.width, player_badge.height,
|
|
|
|
QImage::Format_RGBA8888);
|
|
|
|
m_user_icon->setPixmap(QPixmap::fromImage(i_user_icon)
|
|
|
|
.scaled(64, 64, Qt::KeepAspectRatio, Qt::SmoothTransformation));
|
|
|
|
}
|
2024-05-13 19:21:55 -04:00
|
|
|
m_user_icon->adjustSize();
|
|
|
|
m_user_icon->setStyleSheet(QStringLiteral("border: 4px solid transparent"));
|
|
|
|
m_user_icon->setVisible(true);
|
|
|
|
|
2023-06-15 03:57:58 -04:00
|
|
|
m_game_icon->setVisible(false);
|
|
|
|
m_game_icon->clear();
|
|
|
|
m_game_icon->setText({});
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
|
|
|
|
if (instance.IsGameLoaded())
|
2023-06-15 03:57:58 -04:00
|
|
|
{
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
rc_client_user_game_summary_t game_summary;
|
|
|
|
rc_client_get_user_game_summary(instance.GetClient(), &game_summary);
|
2024-08-15 21:48:50 -04:00
|
|
|
if (!game_badge.data.empty())
|
2024-07-15 21:47:59 +02:00
|
|
|
{
|
|
|
|
QImage i_game_icon(game_badge.data.data(), game_badge.width, game_badge.height,
|
|
|
|
QImage::Format_RGBA8888);
|
|
|
|
m_game_icon->setPixmap(QPixmap::fromImage(i_game_icon)
|
|
|
|
.scaled(64, 64, Qt::KeepAspectRatio, Qt::SmoothTransformation));
|
|
|
|
}
|
2024-05-13 19:21:55 -04:00
|
|
|
m_game_icon->adjustSize();
|
|
|
|
std::string_view color = AchievementManager::GRAY;
|
|
|
|
if (game_summary.num_core_achievements == game_summary.num_unlocked_achievements)
|
2023-06-15 03:57:58 -04:00
|
|
|
{
|
2024-05-13 19:21:55 -04:00
|
|
|
color = instance.IsHardcoreModeActive() ? AchievementManager::GOLD : AchievementManager::BLUE;
|
2023-06-15 03:57:58 -04:00
|
|
|
}
|
2024-05-13 19:21:55 -04:00
|
|
|
m_game_icon->setStyleSheet(
|
|
|
|
QStringLiteral("border: 4px solid %1").arg(QtUtils::FromStdString(color)));
|
|
|
|
m_game_icon->setVisible(true);
|
2023-06-02 21:20:42 -04:00
|
|
|
|
2023-06-15 03:57:58 -04:00
|
|
|
m_name->setText(tr("%1 is playing %2").arg(user_name).arg(game_name));
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
m_points->setText(tr("%1 has unlocked %2/%3 achievements worth %4/%5 points")
|
|
|
|
.arg(user_name)
|
|
|
|
.arg(game_summary.num_unlocked_achievements)
|
|
|
|
.arg(game_summary.num_core_achievements)
|
|
|
|
.arg(game_summary.points_unlocked)
|
|
|
|
.arg(game_summary.points_core));
|
|
|
|
|
2024-07-10 08:52:12 -04:00
|
|
|
// This ensures that 0/0 renders as empty instead of full
|
|
|
|
m_game_progress->setRange(
|
|
|
|
0, (game_summary.num_core_achievements == 0) ? 1 : game_summary.num_core_achievements);
|
|
|
|
m_game_progress->setVisible(true);
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
m_game_progress->setValue(game_summary.num_unlocked_achievements);
|
2024-07-10 08:52:12 -04:00
|
|
|
m_progress_label->setVisible(true);
|
|
|
|
m_progress_label->setText(tr("%1/%2")
|
|
|
|
.arg(game_summary.num_unlocked_achievements)
|
|
|
|
.arg(game_summary.num_core_achievements));
|
2023-12-11 13:18:02 -05:00
|
|
|
m_rich_presence->setText(QString::fromUtf8(instance.GetRichPresence().data()));
|
2024-04-03 15:18:27 -04:00
|
|
|
m_rich_presence->setVisible(true);
|
2023-06-02 21:20:42 -04:00
|
|
|
}
|
2023-06-15 03:57:58 -04:00
|
|
|
else
|
|
|
|
{
|
|
|
|
m_name->setText(user_name);
|
2023-12-11 13:18:02 -05:00
|
|
|
m_points->setText(tr("%1 points").arg(instance.GetPlayerScore()));
|
2023-06-02 21:20:42 -04:00
|
|
|
|
Update Achievement Dialog Header to use rc_client
Two portions of this need updating.
Anything related to points and unlock counts and scoring uses game_summary now instead of the TallyScore method. Unfortunately this comes with the drawback that I cannot easily at this time access the number of points/unlocks from the other hardcore mode, so things like the second progress bar have been deleted.
Rich presence, which no longer needs to be stored, but can be calculated at request. As the AchievementHeader can now update just the Rich Presence, DoFrame can now simply call a header update with .rp=true and the current Rich Presence will be calculated immediately.
As the two items above are the last remaining things to use a number of the components in AchievementManager, this also deletes: Request V1 (V2 is renamed accordingly), ResponseType, PointSpread, TallyScore, UnlockStatus, and the RP generation and ping methods.
2024-04-05 22:46:40 -04:00
|
|
|
m_game_progress->setVisible(false);
|
2024-07-10 08:52:12 -04:00
|
|
|
m_progress_label->setVisible(false);
|
2023-06-15 03:57:58 -04:00
|
|
|
m_rich_presence->setVisible(false);
|
|
|
|
}
|
2023-06-02 21:20:42 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif // USE_RETRO_ACHIEVEMENTS
|