Change from radio buttons to combobox, sizing fix and slight reorganization

This commit is contained in:
Ethan Roseman 2019-10-15 18:23:12 -04:00
parent 1ce566f9fd
commit 2647e412ae
3 changed files with 29 additions and 33 deletions

View File

@ -47,7 +47,7 @@ SettingsWindow::SettingsWindow(QWidget* parent) : QDialog(parent)
wii_pane->OnEmulationStateChanged(state != Core::State::Uninitialized); wii_pane->OnEmulationStateChanged(state != Core::State::Uninitialized);
}); });
m_tab_widget->addTab(new AdvancedPane(), tr("Advanced")); m_tab_widget->addTab(GetWrappedWidget(new AdvancedPane, this, 125, 200), tr("Advanced"));
// Dialog box buttons // Dialog box buttons
QDialogButtonBox* close_box = new QDialogButtonBox(QDialogButtonBox::Close); QDialogButtonBox* close_box = new QDialogButtonBox(QDialogButtonBox::Close);

View File

@ -5,7 +5,9 @@
#include "DolphinQt/Settings/AdvancedPane.h" #include "DolphinQt/Settings/AdvancedPane.h"
#include <QCheckBox> #include <QCheckBox>
#include <QComboBox>
#include <QDateTimeEdit> #include <QDateTimeEdit>
#include <QFormLayout>
#include <QGroupBox> #include <QGroupBox>
#include <QHBoxLayout> #include <QHBoxLayout>
#include <QLabel> #include <QLabel>
@ -52,24 +54,28 @@ void AdvancedPane::CreateLayout()
cpu_options->setLayout(cpu_options_layout); cpu_options->setLayout(cpu_options_layout);
main_layout->addWidget(cpu_options); main_layout->addWidget(cpu_options);
auto* engine_group = new QGroupBox(tr("CPU Emulation Engine")); QGridLayout* cpu_emulation_layout = new QGridLayout();
auto* engine_group_layout = new QVBoxLayout; QLabel* cpu_emulation_engine_label = new QLabel(tr("CPU Emulation Engine:"));
engine_group->setLayout(engine_group_layout); m_cpu_emulation_engine_combobox = new QComboBox(this);
for (PowerPC::CPUCore cpu_core : PowerPC::AvailableCPUCores()) for (PowerPC::CPUCore cpu_core : PowerPC::AvailableCPUCores())
{ {
m_cpu_cores.emplace_back(new QRadioButton(tr(CPU_CORE_NAMES.at(cpu_core)))); m_cpu_emulation_engine_combobox->addItem(tr(CPU_CORE_NAMES.at(cpu_core)));
engine_group_layout->addWidget(m_cpu_cores.back());
} }
cpu_emulation_layout->addWidget(cpu_emulation_engine_label, 0, 0);
cpu_emulation_layout->addWidget(m_cpu_emulation_engine_combobox, 0, 1, Qt::AlignLeft);
cpu_options_layout->addLayout(cpu_emulation_layout);
cpu_options_layout->addWidget(engine_group); auto* clock_override = new QGroupBox(tr("Clock Override"));
auto* clock_override_layout = new QVBoxLayout();
clock_override->setLayout(clock_override_layout);
main_layout->addWidget(clock_override);
m_cpu_clock_override_checkbox = new QCheckBox(tr("Enable Emulated CPU Clock Override")); m_cpu_clock_override_checkbox = new QCheckBox(tr("Enable Emulated CPU Clock Override"));
cpu_options_layout->addWidget(m_cpu_clock_override_checkbox); clock_override_layout->addWidget(m_cpu_clock_override_checkbox);
auto* cpu_clock_override_slider_layout = new QHBoxLayout(); auto* cpu_clock_override_slider_layout = new QHBoxLayout();
cpu_clock_override_slider_layout->setContentsMargins(0, 0, 0, 0); cpu_clock_override_slider_layout->setContentsMargins(0, 0, 0, 0);
cpu_options_layout->addLayout(cpu_clock_override_slider_layout); clock_override_layout->addLayout(cpu_clock_override_slider_layout);
m_cpu_clock_override_slider = new QSlider(Qt::Horizontal); m_cpu_clock_override_slider = new QSlider(Qt::Horizontal);
m_cpu_clock_override_slider->setRange(0, 150); m_cpu_clock_override_slider->setRange(0, 150);
@ -87,7 +93,7 @@ void AdvancedPane::CreateLayout()
"break games and cause glitches. Do so at your own risk. " "break games and cause glitches. Do so at your own risk. "
"Please do not report bugs that occur with a non-default clock.")); "Please do not report bugs that occur with a non-default clock."));
cpu_clock_override_description->setWordWrap(true); cpu_clock_override_description->setWordWrap(true);
cpu_options_layout->addWidget(cpu_clock_override_description); clock_override_layout->addWidget(cpu_clock_override_description);
auto* rtc_options = new QGroupBox(tr("Custom RTC Options")); auto* rtc_options = new QGroupBox(tr("Custom RTC Options"));
rtc_options->setLayout(new QVBoxLayout()); rtc_options->setLayout(new QVBoxLayout());
@ -123,21 +129,13 @@ void AdvancedPane::CreateLayout()
void AdvancedPane::ConnectLayout() void AdvancedPane::ConnectLayout()
{ {
for (QRadioButton* radio_button : m_cpu_cores) connect(m_cpu_emulation_engine_combobox,
{ static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
connect(radio_button, &QRadioButton::toggled, [this](bool toggled) { [this](int index) {
for (size_t i = 0; i < m_cpu_cores.size(); ++i) SConfig::GetInstance().cpu_core = PowerPC::AvailableCPUCores()[index];
{ Config::SetBaseOrCurrent(Config::MAIN_CPU_CORE, PowerPC::AvailableCPUCores()[index]);
if (m_cpu_cores[i]->isChecked()) Update();
{ });
SConfig::GetInstance().cpu_core = PowerPC::AvailableCPUCores()[i];
Config::SetBaseOrCurrent(Config::MAIN_CPU_CORE, PowerPC::AvailableCPUCores()[i]);
break;
}
}
Update();
});
}
m_cpu_clock_override_checkbox->setChecked(SConfig::GetInstance().m_OCEnable); m_cpu_clock_override_checkbox->setChecked(SConfig::GetInstance().m_OCEnable);
connect(m_cpu_clock_override_checkbox, &QCheckBox::toggled, [this](bool enable_clock_override) { connect(m_cpu_clock_override_checkbox, &QCheckBox::toggled, [this](bool enable_clock_override) {
@ -176,10 +174,10 @@ void AdvancedPane::Update()
const bool enable_custom_rtc_widgets = SConfig::GetInstance().bEnableCustomRTC && !running; const bool enable_custom_rtc_widgets = SConfig::GetInstance().bEnableCustomRTC && !running;
const std::vector<PowerPC::CPUCore>& available_cpu_cores = PowerPC::AvailableCPUCores(); const std::vector<PowerPC::CPUCore>& available_cpu_cores = PowerPC::AvailableCPUCores();
for (size_t i = 0; i < available_cpu_cores.size(); ++i) for (int i = 0; i < available_cpu_cores.size(); ++i)
{ {
if (available_cpu_cores[i] == SConfig::GetInstance().cpu_core) if (available_cpu_cores[i] == SConfig::GetInstance().cpu_core)
m_cpu_cores[i]->setChecked(true); m_cpu_emulation_engine_combobox->setCurrentIndex(i);
} }
QFont bf = font(); QFont bf = font();
@ -211,7 +209,5 @@ void AdvancedPane::Update()
void AdvancedPane::OnEmulationStateChanged(Core::State state) void AdvancedPane::OnEmulationStateChanged(Core::State state)
{ {
const bool running = state != Core::State::Uninitialized; const bool running = state != Core::State::Uninitialized;
m_cpu_emulation_engine_combobox->setEnabled(!running);
for (QRadioButton* radio_button : m_cpu_cores)
radio_button->setEnabled(!running);
} }

View File

@ -9,6 +9,7 @@
#include <QWidget> #include <QWidget>
class QCheckBox; class QCheckBox;
class QComboBox;
class QLabel; class QLabel;
class QRadioButton; class QRadioButton;
class QSlider; class QSlider;
@ -31,6 +32,7 @@ private:
void Update(); void Update();
void OnEmulationStateChanged(Core::State state); void OnEmulationStateChanged(Core::State state);
QComboBox* m_cpu_emulation_engine_combobox;
QCheckBox* m_cpu_clock_override_checkbox; QCheckBox* m_cpu_clock_override_checkbox;
QSlider* m_cpu_clock_override_slider; QSlider* m_cpu_clock_override_slider;
QLabel* m_cpu_clock_override_slider_label; QLabel* m_cpu_clock_override_slider_label;
@ -38,6 +40,4 @@ private:
QCheckBox* m_custom_rtc_checkbox; QCheckBox* m_custom_rtc_checkbox;
QDateTimeEdit* m_custom_rtc_datetime; QDateTimeEdit* m_custom_rtc_datetime;
std::vector<QRadioButton*> m_cpu_cores;
}; };