Merge pull request #5984 from spycrab/qt_gecko
Qt/GameList: Implement "Gecko codes" Tab
This commit is contained in:
commit
743568f9d4
|
@ -31,8 +31,10 @@ set(SRCS
|
||||||
Translation.cpp
|
Translation.cpp
|
||||||
WiiUpdate.cpp
|
WiiUpdate.cpp
|
||||||
WiiUpdate.h
|
WiiUpdate.h
|
||||||
|
Config/CheatWarningWidget.cpp
|
||||||
Config/ControllersWindow.cpp
|
Config/ControllersWindow.cpp
|
||||||
Config/FilesystemWidget.cpp
|
Config/FilesystemWidget.cpp
|
||||||
|
Config/GeckoCodeWidget.cpp
|
||||||
Config/Graphics/AdvancedWidget.cpp
|
Config/Graphics/AdvancedWidget.cpp
|
||||||
Config/Graphics/EnhancementsWidget.cpp
|
Config/Graphics/EnhancementsWidget.cpp
|
||||||
Config/Graphics/GeneralWidget.cpp
|
Config/Graphics/GeneralWidget.cpp
|
||||||
|
|
|
@ -0,0 +1,86 @@
|
||||||
|
// Copyright 2017 Dolphin Emulator Project
|
||||||
|
// Licensed under GPLv2+
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#include "DolphinQt2/Config/CheatWarningWidget.h"
|
||||||
|
|
||||||
|
#include <QHBoxLayout>
|
||||||
|
#include <QLabel>
|
||||||
|
#include <QPixmap>
|
||||||
|
#include <QPushButton>
|
||||||
|
#include <QStyle>
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
#include "Core/ConfigManager.h"
|
||||||
|
#include "Core/Core.h"
|
||||||
|
#include "DolphinQt2/Settings.h"
|
||||||
|
|
||||||
|
CheatWarningWidget::CheatWarningWidget(const std::string& game_id) : m_game_id(game_id)
|
||||||
|
{
|
||||||
|
CreateWidgets();
|
||||||
|
ConnectWidgets();
|
||||||
|
|
||||||
|
connect(&Settings::Instance(), &Settings::EnableCheatsChanged,
|
||||||
|
[this] { Update(Core::IsRunning()); });
|
||||||
|
connect(&Settings::Instance(), &Settings::EmulationStateChanged, [this](Core::State state) {
|
||||||
|
std::cout << (state == Core::State::Running) << std::endl;
|
||||||
|
Update(state == Core::State::Running);
|
||||||
|
});
|
||||||
|
|
||||||
|
Update(Core::IsRunning());
|
||||||
|
}
|
||||||
|
|
||||||
|
void CheatWarningWidget::CreateWidgets()
|
||||||
|
{
|
||||||
|
auto* icon = new QLabel;
|
||||||
|
|
||||||
|
const auto size = 1.5 * QFontMetrics(font()).height();
|
||||||
|
|
||||||
|
QPixmap warning_icon = style()->standardIcon(QStyle::SP_MessageBoxWarning).pixmap(size, size);
|
||||||
|
|
||||||
|
icon->setPixmap(warning_icon);
|
||||||
|
|
||||||
|
m_text = new QLabel();
|
||||||
|
m_config_button = new QPushButton(tr("Configure Dolphin"));
|
||||||
|
|
||||||
|
m_config_button->setHidden(true);
|
||||||
|
|
||||||
|
auto* layout = new QHBoxLayout;
|
||||||
|
|
||||||
|
layout->addWidget(icon);
|
||||||
|
layout->addWidget(m_text, 1);
|
||||||
|
layout->addWidget(m_config_button);
|
||||||
|
|
||||||
|
layout->setContentsMargins(0, 0, 0, 0);
|
||||||
|
|
||||||
|
setLayout(layout);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CheatWarningWidget::Update(bool running)
|
||||||
|
{
|
||||||
|
bool hide_widget = true;
|
||||||
|
bool hide_config_button = true;
|
||||||
|
|
||||||
|
if (running && SConfig::GetInstance().GetGameID() == m_game_id)
|
||||||
|
{
|
||||||
|
hide_widget = false;
|
||||||
|
m_text->setText(tr("Changing cheats will only take effect when the game is restarted."));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!Settings::Instance().GetCheatsEnabled())
|
||||||
|
{
|
||||||
|
hide_widget = false;
|
||||||
|
hide_config_button = false;
|
||||||
|
m_text->setText(tr("Dolphin's cheat system is currently disabled."));
|
||||||
|
}
|
||||||
|
|
||||||
|
setHidden(hide_widget);
|
||||||
|
m_config_button->setHidden(hide_config_button);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CheatWarningWidget::ConnectWidgets()
|
||||||
|
{
|
||||||
|
connect(m_config_button, &QPushButton::pressed, this,
|
||||||
|
&CheatWarningWidget::OpenCheatEnableSettings);
|
||||||
|
}
|
|
@ -0,0 +1,32 @@
|
||||||
|
// Copyright 2017 Dolphin Emulator Project
|
||||||
|
// Licensed under GPLv2+
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QWidget>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
class QLabel;
|
||||||
|
class QPushButton;
|
||||||
|
|
||||||
|
class CheatWarningWidget : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit CheatWarningWidget(const std::string& game_id);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void OpenCheatEnableSettings();
|
||||||
|
|
||||||
|
private:
|
||||||
|
void CreateWidgets();
|
||||||
|
void ConnectWidgets();
|
||||||
|
|
||||||
|
void Update(bool running);
|
||||||
|
|
||||||
|
QLabel* m_text;
|
||||||
|
QPushButton* m_config_button;
|
||||||
|
const std::string m_game_id;
|
||||||
|
};
|
|
@ -0,0 +1,207 @@
|
||||||
|
// Copyright 2017 Dolphin Emulator Project
|
||||||
|
// Licensed under GPLv2+
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#include "DolphinQt2/Config/GeckoCodeWidget.h"
|
||||||
|
|
||||||
|
#include <QFontDatabase>
|
||||||
|
#include <QFormLayout>
|
||||||
|
#include <QLabel>
|
||||||
|
#include <QListWidget>
|
||||||
|
#include <QMessageBox>
|
||||||
|
#include <QPushButton>
|
||||||
|
#include <QTextEdit>
|
||||||
|
#include <QVBoxLayout>
|
||||||
|
|
||||||
|
#include "Common/FileUtil.h"
|
||||||
|
#include "Common/IniFile.h"
|
||||||
|
#include "Core/ConfigManager.h"
|
||||||
|
#include "Core/GeckoCodeConfig.h"
|
||||||
|
#include "DolphinQt2/Config/CheatWarningWidget.h"
|
||||||
|
#include "DolphinQt2/GameList/GameFile.h"
|
||||||
|
|
||||||
|
GeckoCodeWidget::GeckoCodeWidget(const GameFile& game)
|
||||||
|
: m_game(game), m_game_id(game.GetGameID().toStdString()), m_game_revision(game.GetRevision())
|
||||||
|
{
|
||||||
|
CreateWidgets();
|
||||||
|
ConnectWidgets();
|
||||||
|
|
||||||
|
IniFile game_ini_local;
|
||||||
|
|
||||||
|
// We don't use LoadLocalGameIni() here because user cheat codes that are installed via the UI
|
||||||
|
// will always be stored in GS/${GAMEID}.ini
|
||||||
|
game_ini_local.Load(File::GetUserPath(D_GAMESETTINGS_IDX) + m_game_id + ".ini");
|
||||||
|
|
||||||
|
IniFile game_ini_default = SConfig::GetInstance().LoadDefaultGameIni(m_game_id, m_game_revision);
|
||||||
|
m_gecko_codes = Gecko::LoadCodes(game_ini_default, game_ini_local);
|
||||||
|
|
||||||
|
UpdateList();
|
||||||
|
}
|
||||||
|
|
||||||
|
void GeckoCodeWidget::CreateWidgets()
|
||||||
|
{
|
||||||
|
m_warning = new CheatWarningWidget(m_game_id);
|
||||||
|
m_code_list = new QListWidget;
|
||||||
|
m_name_label = new QLabel;
|
||||||
|
m_creator_label = new QLabel;
|
||||||
|
|
||||||
|
QFont monospace(QFontDatabase::systemFont(QFontDatabase::FixedFont).family());
|
||||||
|
|
||||||
|
const auto line_height = QFontMetrics(font()).lineSpacing();
|
||||||
|
|
||||||
|
m_code_description = new QTextEdit;
|
||||||
|
m_code_description->setFont(monospace);
|
||||||
|
m_code_description->setReadOnly(true);
|
||||||
|
m_code_description->setFixedHeight(line_height * 5);
|
||||||
|
|
||||||
|
m_code_view = new QTextEdit;
|
||||||
|
m_code_view->setFont(monospace);
|
||||||
|
m_code_view->setReadOnly(true);
|
||||||
|
m_code_view->setFixedHeight(line_height * 10);
|
||||||
|
|
||||||
|
m_download_codes = new QPushButton(tr("Download Codes (WiiRD Database)"));
|
||||||
|
m_download_codes->setEnabled(!m_game_id.empty());
|
||||||
|
m_download_codes->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed);
|
||||||
|
|
||||||
|
auto* layout = new QVBoxLayout;
|
||||||
|
|
||||||
|
layout->addWidget(m_warning);
|
||||||
|
layout->addWidget(m_code_list);
|
||||||
|
|
||||||
|
auto* info_layout = new QFormLayout;
|
||||||
|
|
||||||
|
info_layout->addRow(tr("Name:"), m_name_label);
|
||||||
|
info_layout->addRow(tr("Creator:"), m_creator_label);
|
||||||
|
info_layout->addRow(tr("Description:"), static_cast<QWidget*>(nullptr));
|
||||||
|
|
||||||
|
info_layout->setFormAlignment(Qt::AlignLeft | Qt::AlignTop);
|
||||||
|
|
||||||
|
for (QLabel* label : {m_name_label, m_creator_label})
|
||||||
|
{
|
||||||
|
label->setTextInteractionFlags(Qt::TextSelectableByMouse);
|
||||||
|
label->setCursor(Qt::IBeamCursor);
|
||||||
|
}
|
||||||
|
|
||||||
|
layout->addLayout(info_layout);
|
||||||
|
layout->addWidget(m_code_description);
|
||||||
|
layout->addWidget(m_code_view);
|
||||||
|
layout->addWidget(m_download_codes, 0, Qt::AlignRight);
|
||||||
|
|
||||||
|
setLayout(layout);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GeckoCodeWidget::ConnectWidgets()
|
||||||
|
{
|
||||||
|
connect(m_code_list, &QListWidget::itemSelectionChanged, this,
|
||||||
|
&GeckoCodeWidget::OnSelectionChanged);
|
||||||
|
connect(m_code_list, &QListWidget::itemChanged, this, &GeckoCodeWidget::OnItemChanged);
|
||||||
|
|
||||||
|
connect(m_download_codes, &QPushButton::pressed, this, &GeckoCodeWidget::DownloadCodes);
|
||||||
|
|
||||||
|
connect(m_warning, &CheatWarningWidget::OpenCheatEnableSettings, this,
|
||||||
|
&GeckoCodeWidget::OpenGeneralSettings);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GeckoCodeWidget::OnSelectionChanged()
|
||||||
|
{
|
||||||
|
auto items = m_code_list->selectedItems();
|
||||||
|
|
||||||
|
if (items.empty())
|
||||||
|
return;
|
||||||
|
|
||||||
|
auto selected = items[0];
|
||||||
|
|
||||||
|
const auto& code = m_gecko_codes[m_code_list->row(selected)];
|
||||||
|
|
||||||
|
m_name_label->setText(QString::fromStdString(code.name));
|
||||||
|
m_creator_label->setText(QString::fromStdString(code.creator));
|
||||||
|
|
||||||
|
m_code_description->clear();
|
||||||
|
|
||||||
|
if (code.notes.empty())
|
||||||
|
m_code_description->append(tr("N/A"));
|
||||||
|
|
||||||
|
for (const auto& line : code.notes)
|
||||||
|
m_code_description->append(QString::fromStdString(line));
|
||||||
|
|
||||||
|
m_code_view->clear();
|
||||||
|
|
||||||
|
for (const auto& c : code.codes)
|
||||||
|
m_code_view->append(QStringLiteral("%1 %2")
|
||||||
|
.arg(c.address, 8, 16, QLatin1Char('0'))
|
||||||
|
.arg(c.data, 8, 16, QLatin1Char('0')));
|
||||||
|
}
|
||||||
|
|
||||||
|
void GeckoCodeWidget::OnItemChanged(QListWidgetItem* item)
|
||||||
|
{
|
||||||
|
m_gecko_codes[m_code_list->row(item)].enabled = (item->checkState() == Qt::Checked);
|
||||||
|
|
||||||
|
SaveCodes();
|
||||||
|
}
|
||||||
|
|
||||||
|
void GeckoCodeWidget::SaveCodes()
|
||||||
|
{
|
||||||
|
IniFile game_ini_local;
|
||||||
|
game_ini_local.Load(File::GetUserPath(D_GAMESETTINGS_IDX) + m_game_id + ".ini");
|
||||||
|
Gecko::SaveCodes(game_ini_local, m_gecko_codes);
|
||||||
|
|
||||||
|
game_ini_local.Save(File::GetUserPath(D_GAMESETTINGS_IDX) + m_game_id + ".ini");
|
||||||
|
}
|
||||||
|
|
||||||
|
void GeckoCodeWidget::UpdateList()
|
||||||
|
{
|
||||||
|
m_code_list->clear();
|
||||||
|
|
||||||
|
for (size_t i = 0; i < m_gecko_codes.size(); i++)
|
||||||
|
{
|
||||||
|
const auto& code = m_gecko_codes[i];
|
||||||
|
|
||||||
|
auto* item = new QListWidgetItem(QString::fromStdString(code.name)
|
||||||
|
.replace(QStringLiteral("<"), QStringLiteral("<"))
|
||||||
|
.replace(QStringLiteral(">"), QStringLiteral(">")));
|
||||||
|
|
||||||
|
item->setFlags(Qt::ItemIsEnabled | Qt::ItemIsSelectable | Qt::ItemIsUserCheckable);
|
||||||
|
item->setCheckState(code.enabled ? Qt::Checked : Qt::Unchecked);
|
||||||
|
|
||||||
|
m_code_list->addItem(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void GeckoCodeWidget::DownloadCodes()
|
||||||
|
{
|
||||||
|
bool success;
|
||||||
|
|
||||||
|
std::vector<Gecko::GeckoCode> codes = Gecko::DownloadCodes(m_game_id, &success);
|
||||||
|
|
||||||
|
if (!success)
|
||||||
|
{
|
||||||
|
QMessageBox::critical(this, tr("Error"), tr("Failed to download codes."));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (codes.empty())
|
||||||
|
{
|
||||||
|
QMessageBox::critical(this, tr("Error"), tr("File contained no codes."));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t added_count = 0;
|
||||||
|
|
||||||
|
for (const auto& code : codes)
|
||||||
|
{
|
||||||
|
auto it = std::find(m_gecko_codes.begin(), m_gecko_codes.end(), code);
|
||||||
|
|
||||||
|
if (it == m_gecko_codes.end())
|
||||||
|
{
|
||||||
|
m_gecko_codes.push_back(code);
|
||||||
|
added_count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
UpdateList();
|
||||||
|
SaveCodes();
|
||||||
|
|
||||||
|
QMessageBox::information(this, tr("Download complete"),
|
||||||
|
tr("Downloaded %1 codes. (added %2)")
|
||||||
|
.arg(QString::number(codes.size()), QString::number(added_count)));
|
||||||
|
}
|
|
@ -0,0 +1,54 @@
|
||||||
|
// Copyright 2017 Dolphin Emulator Project
|
||||||
|
// Licensed under GPLv2+
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QWidget>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include "Common/CommonTypes.h"
|
||||||
|
#include "Core/GeckoCode.h"
|
||||||
|
|
||||||
|
class CheatWarningWidget;
|
||||||
|
class GameFile;
|
||||||
|
class QLabel;
|
||||||
|
class QListWidget;
|
||||||
|
class QListWidgetItem;
|
||||||
|
class QTextEdit;
|
||||||
|
class QPushButton;
|
||||||
|
|
||||||
|
class GeckoCodeWidget : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit GeckoCodeWidget(const GameFile& game);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void OpenGeneralSettings();
|
||||||
|
|
||||||
|
private:
|
||||||
|
void OnSelectionChanged();
|
||||||
|
void OnItemChanged(QListWidgetItem* item);
|
||||||
|
|
||||||
|
void CreateWidgets();
|
||||||
|
void ConnectWidgets();
|
||||||
|
void UpdateList();
|
||||||
|
void DownloadCodes();
|
||||||
|
void SaveCodes();
|
||||||
|
|
||||||
|
const GameFile& m_game;
|
||||||
|
std::string m_game_id;
|
||||||
|
u8 m_game_revision;
|
||||||
|
|
||||||
|
CheatWarningWidget* m_warning;
|
||||||
|
QListWidget* m_code_list;
|
||||||
|
QLabel* m_name_label;
|
||||||
|
QLabel* m_creator_label;
|
||||||
|
QTextEdit* m_code_description;
|
||||||
|
QTextEdit* m_code_view;
|
||||||
|
QPushButton* m_download_codes;
|
||||||
|
std::vector<Gecko::GeckoCode> m_gecko_codes;
|
||||||
|
};
|
|
@ -7,6 +7,7 @@
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
|
|
||||||
#include "DolphinQt2/Config/FilesystemWidget.h"
|
#include "DolphinQt2/Config/FilesystemWidget.h"
|
||||||
|
#include "DolphinQt2/Config/GeckoCodeWidget.h"
|
||||||
#include "DolphinQt2/Config/InfoWidget.h"
|
#include "DolphinQt2/Config/InfoWidget.h"
|
||||||
#include "DolphinQt2/Config/PropertiesDialog.h"
|
#include "DolphinQt2/Config/PropertiesDialog.h"
|
||||||
|
|
||||||
|
@ -18,7 +19,14 @@ PropertiesDialog::PropertiesDialog(QWidget* parent, const GameFile& game) : QDia
|
||||||
|
|
||||||
QTabWidget* tab_widget = new QTabWidget(this);
|
QTabWidget* tab_widget = new QTabWidget(this);
|
||||||
InfoWidget* info = new InfoWidget(game);
|
InfoWidget* info = new InfoWidget(game);
|
||||||
|
|
||||||
|
GeckoCodeWidget* gecko = new GeckoCodeWidget(game);
|
||||||
|
|
||||||
|
connect(gecko, &GeckoCodeWidget::OpenGeneralSettings, this,
|
||||||
|
&PropertiesDialog::OpenGeneralSettings);
|
||||||
|
|
||||||
tab_widget->addTab(info, tr("Info"));
|
tab_widget->addTab(info, tr("Info"));
|
||||||
|
tab_widget->addTab(gecko, tr("Gecko Codes"));
|
||||||
|
|
||||||
if (DiscIO::IsDisc(game.GetPlatformID()))
|
if (DiscIO::IsDisc(game.GetPlatformID()))
|
||||||
{
|
{
|
||||||
|
|
|
@ -13,4 +13,7 @@ class PropertiesDialog final : public QDialog
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
explicit PropertiesDialog(QWidget* parent, const GameFile& game);
|
explicit PropertiesDialog(QWidget* parent, const GameFile& game);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void OpenGeneralSettings();
|
||||||
};
|
};
|
||||||
|
|
|
@ -39,7 +39,7 @@ SettingsWindow::SettingsWindow(QWidget* parent) : QDialog(parent)
|
||||||
m_tabs = new ListTabWidget();
|
m_tabs = new ListTabWidget();
|
||||||
layout->addWidget(m_tabs);
|
layout->addWidget(m_tabs);
|
||||||
|
|
||||||
AddTab(m_tabs, tr("General"), new GeneralPane(), "config");
|
m_general_pane_index = AddTab(m_tabs, tr("General"), new GeneralPane(), "config");
|
||||||
AddTab(m_tabs, tr("Interface"), new InterfacePane(), "browse");
|
AddTab(m_tabs, tr("Interface"), new InterfacePane(), "browse");
|
||||||
m_audio_pane_index = AddTab(m_tabs, tr("Audio"), new AudioPane(), "play");
|
m_audio_pane_index = AddTab(m_tabs, tr("Audio"), new AudioPane(), "play");
|
||||||
AddTab(m_tabs, tr("Paths"), new PathPane(), "browse");
|
AddTab(m_tabs, tr("Paths"), new PathPane(), "browse");
|
||||||
|
@ -57,3 +57,8 @@ void SettingsWindow::SelectAudioPane()
|
||||||
{
|
{
|
||||||
m_tabs->setCurrentIndex(m_audio_pane_index);
|
m_tabs->setCurrentIndex(m_audio_pane_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SettingsWindow::SelectGeneralPane()
|
||||||
|
{
|
||||||
|
m_tabs->setCurrentIndex(m_general_pane_index);
|
||||||
|
}
|
||||||
|
|
|
@ -13,9 +13,11 @@ class SettingsWindow final : public QDialog
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
explicit SettingsWindow(QWidget* parent = nullptr);
|
explicit SettingsWindow(QWidget* parent = nullptr);
|
||||||
|
void SelectGeneralPane();
|
||||||
void SelectAudioPane();
|
void SelectAudioPane();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ListTabWidget* m_tabs;
|
ListTabWidget* m_tabs;
|
||||||
int m_audio_pane_index = -1;
|
int m_audio_pane_index = -1;
|
||||||
|
int m_general_pane_index = -1;
|
||||||
};
|
};
|
||||||
|
|
|
@ -60,8 +60,10 @@
|
||||||
<!--NOTE: When adding moc'd files, you must list outputs in the ClCompile ItemGroup too!-->
|
<!--NOTE: When adding moc'd files, you must list outputs in the ClCompile ItemGroup too!-->
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<QtMoc Include="AboutDialog.h" />
|
<QtMoc Include="AboutDialog.h" />
|
||||||
|
<QtMoc Include="Config\CheatWarningWidget.h" />
|
||||||
<QtMoc Include="Config\ControllersWindow.h" />
|
<QtMoc Include="Config\ControllersWindow.h" />
|
||||||
<QtMoc Include="Config\FilesystemWidget.h" />
|
<QtMoc Include="Config\FilesystemWidget.h" />
|
||||||
|
<QtMoc Include="Config\GeckoCodeWidget.h" />
|
||||||
<QtMoc Include="Config\Mapping\IOWindow.h" />
|
<QtMoc Include="Config\Mapping\IOWindow.h" />
|
||||||
<QtMoc Include="Config\Mapping\MappingButton.h" />
|
<QtMoc Include="Config\Mapping\MappingButton.h" />
|
||||||
<QtMoc Include="Config\Mapping\MappingWidget.h" />
|
<QtMoc Include="Config\Mapping\MappingWidget.h" />
|
||||||
|
@ -113,14 +115,16 @@
|
||||||
<ClCompile Include="$(QtMocOutPrefix)AdvancedPane.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)AdvancedPane.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)AudioPane.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)AudioPane.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)AdvancedWidget.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)AdvancedWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)EnhancementsWidget.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)CheatWarningWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)ControllersWindow.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)ControllersWindow.cpp" />
|
||||||
|
<ClCompile Include="$(QtMocOutPrefix)EnhancementsWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)FilesystemWidget.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)FilesystemWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)WindowActivationEventFilter.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)WindowActivationEventFilter.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)GameList.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)GameList.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)GameListDialog.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)GameListDialog.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)GameListModel.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)GameListModel.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)GameTracker.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)GameTracker.cpp" />
|
||||||
|
<ClCompile Include="$(QtMocOutPrefix)GeckoCodeWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)GeneralPane.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)GeneralPane.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)GeneralWidget.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)GeneralWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)GraphicsBool.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)GraphicsBool.cpp" />
|
||||||
|
@ -156,8 +160,10 @@
|
||||||
<ClCompile Include="$(QtMocOutPrefix)SoftwareRendererWidget.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)SoftwareRendererWidget.cpp" />
|
||||||
<ClCompile Include="$(QtMocOutPrefix)ToolBar.cpp" />
|
<ClCompile Include="$(QtMocOutPrefix)ToolBar.cpp" />
|
||||||
<ClCompile Include="AboutDialog.cpp" />
|
<ClCompile Include="AboutDialog.cpp" />
|
||||||
|
<ClCompile Include="Config\CheatWarningWidget.cpp" />
|
||||||
<ClCompile Include="Config\ControllersWindow.cpp" />
|
<ClCompile Include="Config\ControllersWindow.cpp" />
|
||||||
<ClCompile Include="Config\FilesystemWidget.cpp" />
|
<ClCompile Include="Config\FilesystemWidget.cpp" />
|
||||||
|
<ClCompile Include="Config\GeckoCodeWidget.cpp" />
|
||||||
<ClCompile Include="Config\Graphics\AdvancedWidget.cpp" />
|
<ClCompile Include="Config\Graphics\AdvancedWidget.cpp" />
|
||||||
<ClCompile Include="Config\Graphics\EnhancementsWidget.cpp" />
|
<ClCompile Include="Config\Graphics\EnhancementsWidget.cpp" />
|
||||||
<ClCompile Include="Config\Graphics\HacksWidget.cpp" />
|
<ClCompile Include="Config\Graphics\HacksWidget.cpp" />
|
||||||
|
@ -229,8 +235,8 @@
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<!--Put standard C/C++ headers here-->
|
<!--Put standard C/C++ headers here-->
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClInclude Include="Config\LogWidget.h" />
|
<ClInclude Include="Config\CheatWarningWidget.h" />
|
||||||
<ClInclude Include="Config\LogConfigWidget.h" />
|
<ClInclude Include="Config\GeckoCodeWidget.h" />
|
||||||
<ClInclude Include="Config\Mapping\GCKeyboardEmu.h" />
|
<ClInclude Include="Config\Mapping\GCKeyboardEmu.h" />
|
||||||
<ClInclude Include="Config\Mapping\GCPadEmu.h" />
|
<ClInclude Include="Config\Mapping\GCPadEmu.h" />
|
||||||
<ClInclude Include="Config\Mapping\GCPadWiiU.h" />
|
<ClInclude Include="Config\Mapping\GCPadWiiU.h" />
|
||||||
|
|
|
@ -241,6 +241,9 @@ void GameList::ShowContextMenu(const QPoint&)
|
||||||
void GameList::OpenProperties()
|
void GameList::OpenProperties()
|
||||||
{
|
{
|
||||||
PropertiesDialog* properties = new PropertiesDialog(this, *GetSelectedGame());
|
PropertiesDialog* properties = new PropertiesDialog(this, *GetSelectedGame());
|
||||||
|
|
||||||
|
connect(properties, &PropertiesDialog::OpenGeneralSettings, this, &GameList::OpenGeneralSettings);
|
||||||
|
|
||||||
properties->show();
|
properties->show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,6 +31,7 @@ signals:
|
||||||
void GameSelected();
|
void GameSelected();
|
||||||
void NetPlayHost(const QString& game_id);
|
void NetPlayHost(const QString& game_id);
|
||||||
void SelectionChanged(QSharedPointer<GameFile> game_file);
|
void SelectionChanged(QSharedPointer<GameFile> game_file);
|
||||||
|
void OpenGeneralSettings();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void ShowContextMenu(const QPoint&);
|
void ShowContextMenu(const QPoint&);
|
||||||
|
|
|
@ -279,6 +279,8 @@ void MainWindow::ConnectGameList()
|
||||||
{
|
{
|
||||||
connect(m_game_list, &GameList::GameSelected, this, &MainWindow::Play);
|
connect(m_game_list, &GameList::GameSelected, this, &MainWindow::Play);
|
||||||
connect(m_game_list, &GameList::NetPlayHost, this, &MainWindow::NetPlayHost);
|
connect(m_game_list, &GameList::NetPlayHost, this, &MainWindow::NetPlayHost);
|
||||||
|
|
||||||
|
connect(m_game_list, &GameList::OpenGeneralSettings, this, &MainWindow::ShowGeneralWindow);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::ConnectRenderWidget()
|
void MainWindow::ConnectRenderWidget()
|
||||||
|
@ -550,6 +552,12 @@ void MainWindow::ShowAudioWindow()
|
||||||
ShowSettingsWindow();
|
ShowSettingsWindow();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainWindow::ShowGeneralWindow()
|
||||||
|
{
|
||||||
|
m_settings_window->SelectGeneralPane();
|
||||||
|
ShowSettingsWindow();
|
||||||
|
}
|
||||||
|
|
||||||
void MainWindow::ShowAboutDialog()
|
void MainWindow::ShowAboutDialog()
|
||||||
{
|
{
|
||||||
AboutDialog about{this};
|
AboutDialog about{this};
|
||||||
|
|
|
@ -91,6 +91,7 @@ private:
|
||||||
void HideRenderWidget();
|
void HideRenderWidget();
|
||||||
|
|
||||||
void ShowSettingsWindow();
|
void ShowSettingsWindow();
|
||||||
|
void ShowGeneralWindow();
|
||||||
void ShowAudioWindow();
|
void ShowAudioWindow();
|
||||||
void ShowControllersWindow();
|
void ShowControllersWindow();
|
||||||
void ShowGraphicsWindow();
|
void ShowGraphicsWindow();
|
||||||
|
|
|
@ -209,3 +209,17 @@ void Settings::ResetNetPlayServer(NetPlayServer* server)
|
||||||
{
|
{
|
||||||
m_server.reset(server);
|
m_server.reset(server);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Settings::GetCheatsEnabled() const
|
||||||
|
{
|
||||||
|
return SConfig::GetInstance().bEnableCheats;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Settings::SetCheatsEnabled(bool enabled)
|
||||||
|
{
|
||||||
|
if (SConfig::GetInstance().bEnableCheats != enabled)
|
||||||
|
{
|
||||||
|
SConfig::GetInstance().bEnableCheats = enabled;
|
||||||
|
emit EnableCheatsChanged(enabled);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -77,6 +77,10 @@ public:
|
||||||
NetPlayServer* GetNetPlayServer();
|
NetPlayServer* GetNetPlayServer();
|
||||||
void ResetNetPlayServer(NetPlayServer* server = nullptr);
|
void ResetNetPlayServer(NetPlayServer* server = nullptr);
|
||||||
|
|
||||||
|
// Cheats
|
||||||
|
bool GetCheatsEnabled() const;
|
||||||
|
void SetCheatsEnabled(bool enabled);
|
||||||
|
|
||||||
// Other
|
// Other
|
||||||
GameListModel* GetGameListModel() const;
|
GameListModel* GetGameListModel() const;
|
||||||
|
|
||||||
|
@ -91,6 +95,7 @@ signals:
|
||||||
void NANDRefresh();
|
void NANDRefresh();
|
||||||
void LogVisibilityChanged(bool visible);
|
void LogVisibilityChanged(bool visible);
|
||||||
void LogConfigVisibilityChanged(bool visible);
|
void LogConfigVisibilityChanged(bool visible);
|
||||||
|
void EnableCheatsChanged(bool enabled);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unique_ptr<NetPlayClient> m_client;
|
std::unique_ptr<NetPlayClient> m_client;
|
||||||
|
|
|
@ -145,7 +145,7 @@ void GeneralPane::LoadConfig()
|
||||||
m_checkbox_enable_analytics->setChecked(SConfig::GetInstance().m_analytics_enabled);
|
m_checkbox_enable_analytics->setChecked(SConfig::GetInstance().m_analytics_enabled);
|
||||||
#endif
|
#endif
|
||||||
m_checkbox_dualcore->setChecked(SConfig::GetInstance().bCPUThread);
|
m_checkbox_dualcore->setChecked(SConfig::GetInstance().bCPUThread);
|
||||||
m_checkbox_cheats->setChecked(SConfig::GetInstance().bEnableCheats);
|
m_checkbox_cheats->setChecked(Settings::Instance().GetCheatsEnabled());
|
||||||
int selection = qRound(SConfig::GetInstance().m_EmulationSpeed * 10);
|
int selection = qRound(SConfig::GetInstance().m_EmulationSpeed * 10);
|
||||||
if (selection < m_combobox_speedlimit->count())
|
if (selection < m_combobox_speedlimit->count())
|
||||||
m_combobox_speedlimit->setCurrentIndex(selection);
|
m_combobox_speedlimit->setCurrentIndex(selection);
|
||||||
|
@ -177,7 +177,7 @@ void GeneralPane::OnSaveConfig()
|
||||||
SConfig::GetInstance().m_analytics_enabled = m_checkbox_enable_analytics->isChecked();
|
SConfig::GetInstance().m_analytics_enabled = m_checkbox_enable_analytics->isChecked();
|
||||||
#endif
|
#endif
|
||||||
SConfig::GetInstance().bCPUThread = m_checkbox_dualcore->isChecked();
|
SConfig::GetInstance().bCPUThread = m_checkbox_dualcore->isChecked();
|
||||||
SConfig::GetInstance().bEnableCheats = m_checkbox_cheats->isChecked();
|
Settings::Instance().SetCheatsEnabled(m_checkbox_cheats->isChecked());
|
||||||
SConfig::GetInstance().m_EmulationSpeed = m_combobox_speedlimit->currentIndex() * 0.1f;
|
SConfig::GetInstance().m_EmulationSpeed = m_combobox_speedlimit->currentIndex() * 0.1f;
|
||||||
int engine_value = 0;
|
int engine_value = 0;
|
||||||
if (m_radio_interpreter->isChecked())
|
if (m_radio_interpreter->isChecked())
|
||||||
|
|
Loading…
Reference in New Issue