diff --git a/Source/Core/DolphinQt/Config/Graphics/HacksWidget.cpp b/Source/Core/DolphinQt/Config/Graphics/HacksWidget.cpp index 49a1c50b685d..014508f460b7 100644 --- a/Source/Core/DolphinQt/Config/Graphics/HacksWidget.cpp +++ b/Source/Core/DolphinQt/Config/Graphics/HacksWidget.cpp @@ -25,23 +25,18 @@ HacksWidget::HacksWidget(GraphicsWindow* parent) { CreateWidgets(); - LoadSettings(); ConnectWidgets(); AddDescriptions(); connect(parent, &GraphicsWindow::BackendChanged, this, &HacksWidget::OnBackendChanged); OnBackendChanged(QString::fromStdString(Config::Get(Config::MAIN_GFX_BACKEND))); - connect(&Settings::Instance(), &Settings::ConfigChanged, this, &HacksWidget::LoadSettings); - connect(m_gpu_texture_decoding, &QCheckBox::toggled, [this, parent] { - SaveSettings(); - emit parent->UseGPUTextureDecodingChanged(); - }); + connect(m_gpu_texture_decoding, &QCheckBox::toggled, + [this, parent] { emit parent->UseGPUTextureDecodingChanged(); }); } HacksWidget::HacksWidget(GameConfigWidget* parent, Config::Layer* layer) : m_game_layer(layer) { CreateWidgets(); - LoadSettings(); ConnectWidgets(); AddDescriptions(); } @@ -73,11 +68,8 @@ void HacksWidget::CreateWidgets() auto* texture_cache_layout = new QGridLayout(); texture_cache_box->setLayout(texture_cache_layout); - m_accuracy = new ToolTipSlider(Qt::Horizontal); - m_accuracy->setMinimum(0); - m_accuracy->setMaximum(2); - m_accuracy->setPageStep(1); - m_accuracy->setTickPosition(QSlider::TicksBelow); + m_accuracy = + new ConfigSlider({0, 512, 128}, Config::GFX_SAFE_TEXTURE_CACHE_COLOR_SAMPLES, m_game_layer); m_gpu_texture_decoding = new ConfigBool(tr("GPU Texture Decoding"), Config::GFX_ENABLE_GPU_TEXTURE_DECODING, m_game_layer); @@ -158,7 +150,6 @@ void HacksWidget::OnBackendChanged(const QString& backend_name) void HacksWidget::ConnectWidgets() { - connect(m_accuracy, &QSlider::valueChanged, [this](int) { SaveSettings(); }); connect(m_store_efb_copies, &QCheckBox::stateChanged, [this](int) { UpdateDeferEFBCopiesEnabled(); }); connect(m_store_xfb_copies, &QCheckBox::stateChanged, @@ -169,65 +160,6 @@ void HacksWidget::ConnectWidgets() [this](int) { UpdateSkipPresentingDuplicateFramesEnabled(); }); } -void HacksWidget::LoadSettings() -{ - const QSignalBlocker blocker(m_accuracy); - auto samples = Config::Get(Config::GFX_SAFE_TEXTURE_CACHE_COLOR_SAMPLES); - - // Re-enable the slider in case it was disabled because of a custom value - m_accuracy->setEnabled(true); - - int slider_pos = 0; - - switch (samples) - { - case 512: - slider_pos = 1; - break; - case 128: - slider_pos = 2; - break; - case 0: - slider_pos = 0; - break; - // Custom values, ought not to be touched - default: - m_accuracy->setEnabled(false); - } - - m_accuracy->setValue(slider_pos); - - QFont bf = m_accuracy_label->font(); - - bf.setBold(Config::GetActiveLayerForConfig(Config::GFX_SAFE_TEXTURE_CACHE_COLOR_SAMPLES) != - Config::LayerType::Base); - - m_accuracy_label->setFont(bf); -} - -void HacksWidget::SaveSettings() -{ - int slider_pos = m_accuracy->value(); - - if (m_accuracy->isEnabled()) - { - int samples = 0; - switch (slider_pos) - { - case 0: - samples = 0; - break; - case 1: - samples = 512; - break; - case 2: - samples = 128; - } - - Config::SetBaseOrCurrent(Config::GFX_SAFE_TEXTURE_CACHE_COLOR_SAMPLES, samples); - } -} - void HacksWidget::AddDescriptions() { static const char TR_SKIP_EFB_CPU_ACCESS_DESCRIPTION[] = QT_TR_NOOP( diff --git a/Source/Core/DolphinQt/Config/Graphics/HacksWidget.h b/Source/Core/DolphinQt/Config/Graphics/HacksWidget.h index 391570278c3f..2447e40dfcc0 100644 --- a/Source/Core/DolphinQt/Config/Graphics/HacksWidget.h +++ b/Source/Core/DolphinQt/Config/Graphics/HacksWidget.h @@ -6,6 +6,7 @@ #include class ConfigBool; +class ConfigSlider; class GameConfigWidget; class GraphicsWindow; class QLabel; @@ -24,9 +25,6 @@ class HacksWidget final : public QWidget HacksWidget(GameConfigWidget* parent, Config::Layer* layer); private: - void LoadSettings(); - void SaveSettings(); - void OnBackendChanged(const QString& backend_name); // EFB @@ -37,7 +35,7 @@ class HacksWidget final : public QWidget // Texture Cache QLabel* m_accuracy_label; - ToolTipSlider* m_accuracy; + ConfigSlider* m_accuracy; ConfigBool* m_gpu_texture_decoding; // External Framebuffer