diff options
Diffstat (limited to 'src/yuzu/configuration')
23 files changed, 1270 insertions, 969 deletions
| diff --git a/src/yuzu/configuration/config.cpp b/src/yuzu/configuration/config.cpp index 59a193edd..cb71b8d11 100644 --- a/src/yuzu/configuration/config.cpp +++ b/src/yuzu/configuration/config.cpp @@ -578,7 +578,6 @@ void Config::ReadPathValues() {      UISettings::values.roms_path = ReadSetting(QStringLiteral("romsPath")).toString();      UISettings::values.symbols_path = ReadSetting(QStringLiteral("symbolsPath")).toString(); -    UISettings::values.screenshot_path = ReadSetting(QStringLiteral("screenshotPath")).toString();      UISettings::values.game_dir_deprecated =          ReadSetting(QStringLiteral("gameListRootDir"), QStringLiteral(".")).toString();      UISettings::values.game_dir_deprecated_deepscan = @@ -666,8 +665,6 @@ void Config::ReadRendererValues() {                        QStringLiteral("use_asynchronous_shaders"), false);      ReadSettingGlobal(Settings::values.use_fast_gpu_time, QStringLiteral("use_fast_gpu_time"),                        true); -    ReadSettingGlobal(Settings::values.force_30fps_mode, QStringLiteral("force_30fps_mode"), false); -      ReadSettingGlobal(Settings::values.bg_red, QStringLiteral("bg_red"), 0.0);      ReadSettingGlobal(Settings::values.bg_green, QStringLiteral("bg_green"), 0.0);      ReadSettingGlobal(Settings::values.bg_blue, QStringLiteral("bg_blue"), 0.0); @@ -675,6 +672,22 @@ void Config::ReadRendererValues() {      qt_config->endGroup();  } +void Config::ReadScreenshotValues() { +    qt_config->beginGroup(QStringLiteral("Screenshots")); + +    UISettings::values.enable_screenshot_save_as = +        ReadSetting(QStringLiteral("enable_screenshot_save_as"), true).toBool(); +    FileUtil::GetUserPath( +        FileUtil::UserPath::ScreenshotsDir, +        qt_config +            ->value(QStringLiteral("screenshot_path"), QString::fromStdString(FileUtil::GetUserPath( +                                                           FileUtil::UserPath::ScreenshotsDir))) +            .toString() +            .toStdString()); + +    qt_config->endGroup(); +} +  void Config::ReadShortcutValues() {      qt_config->beginGroup(QStringLiteral("Shortcuts")); @@ -756,6 +769,7 @@ void Config::ReadUIValues() {      ReadUIGamelistValues();      ReadUILayoutValues();      ReadPathValues(); +    ReadScreenshotValues();      ReadShortcutValues();      UISettings::values.single_window_mode = @@ -1085,7 +1099,6 @@ void Config::SavePathValues() {      WriteSetting(QStringLiteral("romsPath"), UISettings::values.roms_path);      WriteSetting(QStringLiteral("symbolsPath"), UISettings::values.symbols_path); -    WriteSetting(QStringLiteral("screenshotPath"), UISettings::values.screenshot_path);      qt_config->beginWriteArray(QStringLiteral("gamedirs"));      for (int i = 0; i < UISettings::values.game_dirs.size(); ++i) {          qt_config->setArrayIndex(i); @@ -1153,9 +1166,6 @@ void Config::SaveRendererValues() {                         Settings::values.use_asynchronous_shaders, false);      WriteSettingGlobal(QStringLiteral("use_fast_gpu_time"), Settings::values.use_fast_gpu_time,                         true); -    WriteSettingGlobal(QStringLiteral("force_30fps_mode"), Settings::values.force_30fps_mode, -                       false); -      // Cast to double because Qt's written float values are not human-readable      WriteSettingGlobal(QStringLiteral("bg_red"), Settings::values.bg_red, 0.0);      WriteSettingGlobal(QStringLiteral("bg_green"), Settings::values.bg_green, 0.0); @@ -1164,6 +1174,17 @@ void Config::SaveRendererValues() {      qt_config->endGroup();  } +void Config::SaveScreenshotValues() { +    qt_config->beginGroup(QStringLiteral("Screenshots")); + +    WriteSetting(QStringLiteral("enable_screenshot_save_as"), +                 UISettings::values.enable_screenshot_save_as); +    WriteSetting(QStringLiteral("screenshot_path"), +                 QString::fromStdString(FileUtil::GetUserPath(FileUtil::UserPath::ScreenshotsDir))); + +    qt_config->endGroup(); +} +  void Config::SaveShortcutValues() {      qt_config->beginGroup(QStringLiteral("Shortcuts")); @@ -1226,6 +1247,7 @@ void Config::SaveUIValues() {      SaveUIGamelistValues();      SaveUILayoutValues();      SavePathValues(); +    SaveScreenshotValues();      SaveShortcutValues();      WriteSetting(QStringLiteral("singleWindowMode"), UISettings::values.single_window_mode, true); diff --git a/src/yuzu/configuration/config.h b/src/yuzu/configuration/config.h index 8e815f829..e5f39b040 100644 --- a/src/yuzu/configuration/config.h +++ b/src/yuzu/configuration/config.h @@ -51,6 +51,7 @@ private:      void ReadPathValues();      void ReadCpuValues();      void ReadRendererValues(); +    void ReadScreenshotValues();      void ReadShortcutValues();      void ReadSystemValues();      void ReadUIValues(); @@ -76,6 +77,7 @@ private:      void SavePathValues();      void SaveCpuValues();      void SaveRendererValues(); +    void SaveScreenshotValues();      void SaveShortcutValues();      void SaveSystemValues();      void SaveUIValues(); diff --git a/src/yuzu/configuration/configuration_shared.cpp b/src/yuzu/configuration/configuration_shared.cpp index bb47c3933..f9becab6e 100644 --- a/src/yuzu/configuration/configuration_shared.cpp +++ b/src/yuzu/configuration/configuration_shared.cpp @@ -4,17 +4,20 @@  #include <QCheckBox>  #include <QComboBox> +#include <QObject> +#include <QString>  #include "core/settings.h"  #include "yuzu/configuration/configuration_shared.h"  #include "yuzu/configuration/configure_per_game.h"  void ConfigurationShared::ApplyPerGameSetting(Settings::Setting<bool>* setting, -                                              const QCheckBox* checkbox) { -    if (checkbox->checkState() == Qt::PartiallyChecked) { +                                              const QCheckBox* checkbox, +                                              const CheckState& tracker) { +    if (tracker == CheckState::Global) {          setting->SetGlobal(true);      } else {          setting->SetGlobal(false); -        setting->SetValue(checkbox->checkState() == Qt::Checked); +        setting->SetValue(checkbox->checkState());      }  } @@ -69,8 +72,69 @@ void ConfigurationShared::SetPerGameSetting(                                                             ConfigurationShared::USE_GLOBAL_OFFSET);  } -void ConfigurationShared::InsertGlobalItem(QComboBox* combobox) { -    const QString use_global_text = ConfigurePerGame::tr("Use global configuration"); +void ConfigurationShared::SetHighlight(QWidget* widget, const std::string& name, bool highlighted) { +    if (highlighted) { +        widget->setStyleSheet(QStringLiteral("QWidget#%1 { background-color:rgba(0,203,255,0.5) }") +                                  .arg(QString::fromStdString(name))); +    } else { +        widget->setStyleSheet(QStringLiteral("QWidget#%1 { background-color:rgba(0,0,0,0) }") +                                  .arg(QString::fromStdString(name))); +    } +    widget->show(); +} + +void ConfigurationShared::SetColoredTristate(QCheckBox* checkbox, const std::string& name, +                                             const Settings::Setting<bool>& setting, +                                             CheckState& tracker) { +    if (setting.UsingGlobal()) { +        tracker = CheckState::Global; +    } else { +        tracker = (setting.GetValue() == setting.GetValue(true)) ? CheckState::On : CheckState::Off; +    } +    SetHighlight(checkbox, name, tracker != CheckState::Global); +    QObject::connect(checkbox, &QCheckBox::clicked, checkbox, +                     [checkbox, name, setting, &tracker]() { +                         tracker = static_cast<CheckState>((static_cast<int>(tracker) + 1) % +                                                           static_cast<int>(CheckState::Count)); +                         if (tracker == CheckState::Global) { +                             checkbox->setChecked(setting.GetValue(true)); +                         } +                         SetHighlight(checkbox, name, tracker != CheckState::Global); +                     }); +} + +void ConfigurationShared::SetColoredTristate(QCheckBox* checkbox, const std::string& name, +                                             bool global, bool state, bool global_state, +                                             CheckState& tracker) { +    if (global) { +        tracker = CheckState::Global; +    } else { +        tracker = (state == global_state) ? CheckState::On : CheckState::Off; +    } +    SetHighlight(checkbox, name, tracker != CheckState::Global); +    QObject::connect(checkbox, &QCheckBox::clicked, checkbox, +                     [checkbox, name, global_state, &tracker]() { +                         tracker = static_cast<CheckState>((static_cast<int>(tracker) + 1) % +                                                           static_cast<int>(CheckState::Count)); +                         if (tracker == CheckState::Global) { +                             checkbox->setChecked(global_state); +                         } +                         SetHighlight(checkbox, name, tracker != CheckState::Global); +                     }); +} + +void ConfigurationShared::SetColoredComboBox(QComboBox* combobox, QWidget* target, +                                             const std::string& target_name, int global) { +    InsertGlobalItem(combobox, global); +    QObject::connect(combobox, static_cast<void (QComboBox::*)(int)>(&QComboBox::activated), target, +                     [target, target_name](int index) { +                         ConfigurationShared::SetHighlight(target, target_name, index != 0); +                     }); +} + +void ConfigurationShared::InsertGlobalItem(QComboBox* combobox, int global_index) { +    const QString use_global_text = +        ConfigurePerGame::tr("Use global configuration (%1)").arg(combobox->itemText(global_index));      combobox->insertItem(ConfigurationShared::USE_GLOBAL_INDEX, use_global_text);      combobox->insertSeparator(ConfigurationShared::USE_GLOBAL_SEPARATOR_INDEX);  } diff --git a/src/yuzu/configuration/configuration_shared.h b/src/yuzu/configuration/configuration_shared.h index b11b1b950..003148c68 100644 --- a/src/yuzu/configuration/configuration_shared.h +++ b/src/yuzu/configuration/configuration_shared.h @@ -15,9 +15,17 @@ constexpr int USE_GLOBAL_INDEX = 0;  constexpr int USE_GLOBAL_SEPARATOR_INDEX = 1;  constexpr int USE_GLOBAL_OFFSET = 2; +enum class CheckState { +    Off, +    On, +    Global, +    Count, +}; +  // Global-aware apply and set functions -void ApplyPerGameSetting(Settings::Setting<bool>* setting, const QCheckBox* checkbox); +void ApplyPerGameSetting(Settings::Setting<bool>* setting, const QCheckBox* checkbox, +                         const CheckState& tracker);  void ApplyPerGameSetting(Settings::Setting<int>* setting, const QComboBox* combobox);  void ApplyPerGameSetting(Settings::Setting<Settings::RendererBackend>* setting,                           const QComboBox* combobox); @@ -31,6 +39,14 @@ void SetPerGameSetting(QComboBox* combobox,  void SetPerGameSetting(QComboBox* combobox,                         const Settings::Setting<Settings::GPUAccuracy>* setting); -void InsertGlobalItem(QComboBox* combobox); +void SetHighlight(QWidget* widget, const std::string& name, bool highlighted); +void SetColoredTristate(QCheckBox* checkbox, const std::string& name, +                        const Settings::Setting<bool>& setting, CheckState& tracker); +void SetColoredTristate(QCheckBox* checkbox, const std::string& name, bool global, bool state, +                        bool global_state, CheckState& tracker); +void SetColoredComboBox(QComboBox* combobox, QWidget* target, const std::string& target_name, +                        int global); + +void InsertGlobalItem(QComboBox* combobox, int global_index);  } // namespace ConfigurationShared diff --git a/src/yuzu/configuration/configure_audio.cpp b/src/yuzu/configuration/configure_audio.cpp index cc021beec..fea632531 100644 --- a/src/yuzu/configuration/configure_audio.cpp +++ b/src/yuzu/configuration/configure_audio.cpp @@ -49,12 +49,9 @@ void ConfigureAudio::SetConfiguration() {      ui->volume_slider->setValue(Settings::values.volume.GetValue() * ui->volume_slider->maximum()); -    if (Settings::configuring_global) { -        ui->toggle_audio_stretching->setChecked( -            Settings::values.enable_audio_stretching.GetValue()); -    } else { -        ConfigurationShared::SetPerGameSetting(ui->toggle_audio_stretching, -                                               &Settings::values.enable_audio_stretching); +    ui->toggle_audio_stretching->setChecked(Settings::values.enable_audio_stretching.GetValue()); + +    if (!Settings::configuring_global) {          if (Settings::values.volume.UsingGlobal()) {              ui->volume_combo_box->setCurrentIndex(0);              ui->volume_slider->setEnabled(false); @@ -62,6 +59,8 @@ void ConfigureAudio::SetConfiguration() {              ui->volume_combo_box->setCurrentIndex(1);              ui->volume_slider->setEnabled(true);          } +        ConfigurationShared::SetHighlight(ui->volume_layout, "volume_layout", +                                          !Settings::values.volume.UsingGlobal());      }      SetVolumeIndicatorText(ui->volume_slider->sliderPosition());  } @@ -120,7 +119,8 @@ void ConfigureAudio::ApplyConfiguration() {          }      } else {          ConfigurationShared::ApplyPerGameSetting(&Settings::values.enable_audio_stretching, -                                                 ui->toggle_audio_stretching); +                                                 ui->toggle_audio_stretching, +                                                 enable_audio_stretching);          if (ui->volume_combo_box->currentIndex() == 0) {              Settings::values.volume.SetGlobal(true);          } else { @@ -173,9 +173,14 @@ void ConfigureAudio::SetupPerGameUI() {          return;      } -    ui->toggle_audio_stretching->setTristate(true); +    ConfigurationShared::SetColoredTristate(ui->toggle_audio_stretching, "toggle_audio_stretching", +                                            Settings::values.enable_audio_stretching, +                                            enable_audio_stretching);      connect(ui->volume_combo_box, static_cast<void (QComboBox::*)(int)>(&QComboBox::activated), -            this, [this](int index) { ui->volume_slider->setEnabled(index == 1); }); +            this, [this](int index) { +                ui->volume_slider->setEnabled(index == 1); +                ConfigurationShared::SetHighlight(ui->volume_layout, "volume_layout", index == 1); +            });      ui->output_sink_combo_box->setVisible(false);      ui->output_sink_label->setVisible(false); diff --git a/src/yuzu/configuration/configure_audio.h b/src/yuzu/configuration/configure_audio.h index d84f4a682..9dbd3d93e 100644 --- a/src/yuzu/configuration/configure_audio.h +++ b/src/yuzu/configuration/configure_audio.h @@ -7,6 +7,10 @@  #include <memory>  #include <QWidget> +namespace ConfigurationShared { +enum class CheckState; +} +  namespace Ui {  class ConfigureAudio;  } @@ -37,4 +41,6 @@ private:      void SetupPerGameUI();      std::unique_ptr<Ui::ConfigureAudio> ui; + +    ConfigurationShared::CheckState enable_audio_stretching;  }; diff --git a/src/yuzu/configuration/configure_audio.ui b/src/yuzu/configuration/configure_audio.ui index 862ccb988..9bd0cca96 100644 --- a/src/yuzu/configuration/configure_audio.ui +++ b/src/yuzu/configuration/configure_audio.ui @@ -56,80 +56,91 @@         </layout>        </item>        <item> -       <layout class="QHBoxLayout" name="horizontalLayout_2"> -        <property name="topMargin"> -         <number>0</number> -        </property> -        <item> -         <widget class="QComboBox" name="volume_combo_box"> -          <item> +       <widget class="QWidget" name="volume_layout" native="true"> +        <layout class="QHBoxLayout" name="horizontalLayout_2"> +         <property name="leftMargin"> +          <number>0</number> +         </property> +         <property name="topMargin"> +          <number>0</number> +         </property> +         <property name="rightMargin"> +          <number>0</number> +         </property> +         <property name="bottomMargin"> +          <number>0</number> +         </property> +         <item> +          <widget class="QComboBox" name="volume_combo_box"> +           <item> +            <property name="text"> +             <string>Use global volume</string> +            </property> +           </item> +           <item> +            <property name="text"> +             <string>Set volume:</string> +            </property> +           </item> +          </widget> +         </item> +         <item> +          <widget class="QLabel" name="volume_label">             <property name="text"> -            <string>Use global volume</string> +            <string>Volume:</string> +           </property> +          </widget> +         </item> +         <item> +          <spacer name="horizontalSpacer"> +           <property name="orientation"> +            <enum>Qt::Horizontal</enum> +           </property> +           <property name="sizeHint" stdset="0"> +            <size> +             <width>30</width> +             <height>20</height> +            </size> +           </property> +          </spacer> +         </item> +         <item> +          <widget class="QSlider" name="volume_slider"> +           <property name="sizePolicy"> +            <sizepolicy hsizetype="Expanding" vsizetype="Fixed"> +             <horstretch>0</horstretch> +             <verstretch>0</verstretch> +            </sizepolicy> +           </property> +           <property name="maximum"> +            <number>100</number> +           </property> +           <property name="pageStep"> +            <number>10</number> +           </property> +           <property name="orientation"> +            <enum>Qt::Horizontal</enum> +           </property> +          </widget> +         </item> +         <item> +          <widget class="QLabel" name="volume_indicator"> +           <property name="minimumSize"> +            <size> +             <width>32</width> +             <height>0</height> +            </size>             </property> -          </item> -          <item>             <property name="text"> -            <string>Set volume:</string> +            <string>0 %</string>             </property> -          </item> -         </widget> -        </item> -        <item> -         <widget class="QLabel" name="volume_label"> -          <property name="text"> -           <string>Volume:</string> -          </property> -         </widget> -        </item> -        <item> -         <spacer name="horizontalSpacer"> -          <property name="orientation"> -           <enum>Qt::Horizontal</enum> -          </property> -          <property name="sizeHint" stdset="0"> -           <size> -            <width>30</width> -            <height>20</height> -           </size> -          </property> -         </spacer> -        </item> -        <item> -         <widget class="QSlider" name="volume_slider"> -          <property name="sizePolicy"> -           <sizepolicy hsizetype="Expanding" vsizetype="Fixed"> -            <horstretch>0</horstretch> -            <verstretch>0</verstretch> -           </sizepolicy> -          </property> -          <property name="maximum"> -           <number>100</number> -          </property> -          <property name="pageStep"> -           <number>10</number> -          </property> -          <property name="orientation"> -           <enum>Qt::Horizontal</enum> -          </property> -         </widget> -        </item> -        <item> -         <widget class="QLabel" name="volume_indicator"> -          <property name="minimumSize"> -           <size> -            <width>32</width> -            <height>0</height> -           </size> -          </property> -          <property name="text"> -           <string>0 %</string> -          </property> -          <property name="alignment"> -           <set>Qt::AlignCenter</set> -          </property> -         </widget> -        </item> -       </layout> +           <property name="alignment"> +            <set>Qt::AlignCenter</set> +           </property> +          </widget> +         </item> +        </layout> +       </widget>        </item>       </layout>      </widget> diff --git a/src/yuzu/configuration/configure_debug.ui b/src/yuzu/configuration/configure_debug.ui index 272bdd6b8..9d6feb9f7 100644 --- a/src/yuzu/configuration/configure_debug.ui +++ b/src/yuzu/configuration/configure_debug.ui @@ -171,26 +171,6 @@       </property>       <layout class="QVBoxLayout" name="verticalLayout_6">        <item> -       <widget class="QCheckBox" name="dump_decompressed_nso"> -        <property name="whatsThis"> -         <string>When checked, any NSO yuzu tries to load or patch will be copied decompressed to the yuzu/dump directory.</string> -        </property> -        <property name="text"> -         <string>Dump Decompressed NSOs</string> -        </property> -       </widget> -      </item> -      <item> -       <widget class="QCheckBox" name="dump_exefs"> -        <property name="whatsThis"> -         <string>When checked, any game that yuzu loads will have its ExeFS dumped to the yuzu/dump directory.</string> -        </property> -        <property name="text"> -         <string>Dump ExeFS</string> -        </property> -       </widget> -      </item> -      <item>         <widget class="QCheckBox" name="reporting_services">          <property name="text">           <string>Enable Verbose Reporting Services</string> @@ -257,8 +237,6 @@    <tabstop>open_log_button</tabstop>    <tabstop>homebrew_args_edit</tabstop>    <tabstop>enable_graphics_debugging</tabstop> -  <tabstop>dump_decompressed_nso</tabstop> -  <tabstop>dump_exefs</tabstop>    <tabstop>reporting_services</tabstop>    <tabstop>quest_flag</tabstop>   </tabstops> diff --git a/src/yuzu/configuration/configure_general.cpp b/src/yuzu/configuration/configure_general.cpp index 20316c9cc..c0dbd9855 100644 --- a/src/yuzu/configuration/configure_general.cpp +++ b/src/yuzu/configuration/configure_general.cpp @@ -19,9 +19,10 @@ ConfigureGeneral::ConfigureGeneral(QWidget* parent)      SetConfiguration(); -    connect(ui->toggle_frame_limit, &QCheckBox::stateChanged, ui->frame_limit, [this]() { -        ui->frame_limit->setEnabled(ui->toggle_frame_limit->checkState() == Qt::Checked); -    }); +    if (Settings::configuring_global) { +        connect(ui->toggle_frame_limit, &QCheckBox::clicked, ui->frame_limit, +                [this]() { ui->frame_limit->setEnabled(ui->toggle_frame_limit->isChecked()); }); +    }  }  ConfigureGeneral::~ConfigureGeneral() = default; @@ -40,17 +41,12 @@ void ConfigureGeneral::SetConfiguration() {      ui->toggle_frame_limit->setChecked(Settings::values.use_frame_limit.GetValue());      ui->frame_limit->setValue(Settings::values.frame_limit.GetValue()); -    if (!Settings::configuring_global) { -        if (Settings::values.use_multi_core.UsingGlobal()) { -            ui->use_multi_core->setCheckState(Qt::PartiallyChecked); -        } -        if (Settings::values.use_frame_limit.UsingGlobal()) { -            ui->toggle_frame_limit->setCheckState(Qt::PartiallyChecked); -        } +    if (Settings::configuring_global) { +        ui->frame_limit->setEnabled(Settings::values.use_frame_limit.GetValue()); +    } else { +        ui->frame_limit->setEnabled(Settings::values.use_frame_limit.GetValue() && +                                    use_frame_limit != ConfigurationShared::CheckState::Global);      } - -    ui->frame_limit->setEnabled(ui->toggle_frame_limit->checkState() == Qt::Checked && -                                ui->toggle_frame_limit->isEnabled());  }  void ConfigureGeneral::ApplyConfiguration() { @@ -71,9 +67,9 @@ void ConfigureGeneral::ApplyConfiguration() {          }      } else {          ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_multi_core, -                                                 ui->use_multi_core); +                                                 ui->use_multi_core, use_multi_core); -        bool global_frame_limit = ui->toggle_frame_limit->checkState() == Qt::PartiallyChecked; +        bool global_frame_limit = use_frame_limit == ConfigurationShared::CheckState::Global;          Settings::values.use_frame_limit.SetGlobal(global_frame_limit);          Settings::values.frame_limit.SetGlobal(global_frame_limit);          if (!global_frame_limit) { @@ -109,6 +105,13 @@ void ConfigureGeneral::SetupPerGameUI() {      ui->toggle_background_pause->setVisible(false);      ui->toggle_hide_mouse->setVisible(false); -    ui->toggle_frame_limit->setTristate(true); -    ui->use_multi_core->setTristate(true); +    ConfigurationShared::SetColoredTristate(ui->toggle_frame_limit, "toggle_frame_limit", +                                            Settings::values.use_frame_limit, use_frame_limit); +    ConfigurationShared::SetColoredTristate(ui->use_multi_core, "use_multi_core", +                                            Settings::values.use_multi_core, use_multi_core); + +    connect(ui->toggle_frame_limit, &QCheckBox::clicked, ui->frame_limit, [this]() { +        ui->frame_limit->setEnabled(ui->toggle_frame_limit->isChecked() && +                                    (use_frame_limit != ConfigurationShared::CheckState::Global)); +    });  } diff --git a/src/yuzu/configuration/configure_general.h b/src/yuzu/configuration/configure_general.h index 9c785c22e..323ffbd8f 100644 --- a/src/yuzu/configuration/configure_general.h +++ b/src/yuzu/configuration/configure_general.h @@ -7,6 +7,10 @@  #include <memory>  #include <QWidget> +namespace ConfigurationShared { +enum class CheckState; +} +  class HotkeyRegistry;  namespace Ui { @@ -31,4 +35,7 @@ private:      void SetupPerGameUI();      std::unique_ptr<Ui::ConfigureGeneral> ui; + +    ConfigurationShared::CheckState use_frame_limit; +    ConfigurationShared::CheckState use_multi_core;  }; diff --git a/src/yuzu/configuration/configure_graphics.cpp b/src/yuzu/configuration/configure_graphics.cpp index cb4706bd6..3e42531c3 100644 --- a/src/yuzu/configuration/configure_graphics.cpp +++ b/src/yuzu/configuration/configure_graphics.cpp @@ -31,8 +31,14 @@ ConfigureGraphics::ConfigureGraphics(QWidget* parent)      SetConfiguration(); -    connect(ui->api, qOverload<int>(&QComboBox::currentIndexChanged), this, -            [this] { UpdateDeviceComboBox(); }); +    connect(ui->api, qOverload<int>(&QComboBox::currentIndexChanged), this, [this] { +        UpdateDeviceComboBox(); +        if (!Settings::configuring_global) { +            ConfigurationShared::SetHighlight(ui->api_layout, "api_layout", +                                              ui->api->currentIndex() != +                                                  ConfigurationShared::USE_GLOBAL_INDEX); +        } +    });      connect(ui->device, qOverload<int>(&QComboBox::activated), this,              [this](int device) { UpdateDeviceSelection(device); }); @@ -65,25 +71,26 @@ void ConfigureGraphics::SetConfiguration() {      ui->api->setEnabled(runtime_lock);      ui->use_asynchronous_gpu_emulation->setEnabled(runtime_lock);      ui->use_disk_shader_cache->setEnabled(runtime_lock); +    ui->use_disk_shader_cache->setChecked(Settings::values.use_disk_shader_cache.GetValue()); +    ui->use_asynchronous_gpu_emulation->setChecked( +        Settings::values.use_asynchronous_gpu_emulation.GetValue());      if (Settings::configuring_global) {          ui->api->setCurrentIndex(static_cast<int>(Settings::values.renderer_backend.GetValue()));          ui->aspect_ratio_combobox->setCurrentIndex(Settings::values.aspect_ratio.GetValue()); -        ui->use_disk_shader_cache->setChecked(Settings::values.use_disk_shader_cache.GetValue()); -        ui->use_asynchronous_gpu_emulation->setChecked( -            Settings::values.use_asynchronous_gpu_emulation.GetValue());      } else { -        ConfigurationShared::SetPerGameSetting(ui->use_disk_shader_cache, -                                               &Settings::values.use_disk_shader_cache); -        ConfigurationShared::SetPerGameSetting(ui->use_asynchronous_gpu_emulation, -                                               &Settings::values.use_asynchronous_gpu_emulation); -          ConfigurationShared::SetPerGameSetting(ui->api, &Settings::values.renderer_backend); +        ConfigurationShared::SetHighlight(ui->api_layout, "api_layout", +                                          !Settings::values.renderer_backend.UsingGlobal());          ConfigurationShared::SetPerGameSetting(ui->aspect_ratio_combobox,                                                 &Settings::values.aspect_ratio);          ui->bg_combobox->setCurrentIndex(Settings::values.bg_red.UsingGlobal() ? 0 : 1);          ui->bg_button->setEnabled(!Settings::values.bg_red.UsingGlobal()); +        ConfigurationShared::SetHighlight(ui->ar_label, "ar_label", +                                          !Settings::values.aspect_ratio.UsingGlobal()); +        ConfigurationShared::SetHighlight(ui->bg_layout, "bg_layout", +                                          !Settings::values.bg_red.UsingGlobal());      }      UpdateBackgroundColorButton(QColor::fromRgbF(Settings::values.bg_red.GetValue(), @@ -135,9 +142,10 @@ void ConfigureGraphics::ApplyConfiguration() {                                                   ui->aspect_ratio_combobox);          ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_disk_shader_cache, -                                                 ui->use_disk_shader_cache); +                                                 ui->use_disk_shader_cache, use_disk_shader_cache);          ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_asynchronous_gpu_emulation, -                                                 ui->use_asynchronous_gpu_emulation); +                                                 ui->use_asynchronous_gpu_emulation, +                                                 use_asynchronous_gpu_emulation);          if (ui->bg_combobox->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX) {              Settings::values.bg_red.SetGlobal(true); @@ -241,10 +249,20 @@ void ConfigureGraphics::SetupPerGameUI() {      }      connect(ui->bg_combobox, static_cast<void (QComboBox::*)(int)>(&QComboBox::activated), this, -            [this](int index) { ui->bg_button->setEnabled(index == 1); }); - -    ui->use_disk_shader_cache->setTristate(true); -    ui->use_asynchronous_gpu_emulation->setTristate(true); -    ConfigurationShared::InsertGlobalItem(ui->aspect_ratio_combobox); -    ConfigurationShared::InsertGlobalItem(ui->api); +            [this](int index) { +                ui->bg_button->setEnabled(index == 1); +                ConfigurationShared::SetHighlight(ui->bg_layout, "bg_layout", index == 1); +            }); + +    ConfigurationShared::SetColoredTristate(ui->use_disk_shader_cache, "use_disk_shader_cache", +                                            Settings::values.use_disk_shader_cache, +                                            use_disk_shader_cache); +    ConfigurationShared::SetColoredTristate( +        ui->use_asynchronous_gpu_emulation, "use_asynchronous_gpu_emulation", +        Settings::values.use_asynchronous_gpu_emulation, use_asynchronous_gpu_emulation); + +    ConfigurationShared::SetColoredComboBox(ui->aspect_ratio_combobox, ui->ar_label, "ar_label", +                                            Settings::values.aspect_ratio.GetValue(true)); +    ConfigurationShared::InsertGlobalItem( +        ui->api, static_cast<int>(Settings::values.renderer_backend.GetValue(true)));  } diff --git a/src/yuzu/configuration/configure_graphics.h b/src/yuzu/configuration/configure_graphics.h index 24f01c739..b4961f719 100644 --- a/src/yuzu/configuration/configure_graphics.h +++ b/src/yuzu/configuration/configure_graphics.h @@ -10,6 +10,10 @@  #include <QWidget>  #include "core/settings.h" +namespace ConfigurationShared { +enum class CheckState; +} +  namespace Ui {  class ConfigureGraphics;  } @@ -42,6 +46,9 @@ private:      std::unique_ptr<Ui::ConfigureGraphics> ui;      QColor bg_color; +    ConfigurationShared::CheckState use_disk_shader_cache; +    ConfigurationShared::CheckState use_asynchronous_gpu_emulation; +      std::vector<QString> vulkan_devices;      u32 vulkan_device{};  }; diff --git a/src/yuzu/configuration/configure_graphics.ui b/src/yuzu/configuration/configure_graphics.ui index 62418fc14..62aa337e7 100644 --- a/src/yuzu/configuration/configure_graphics.ui +++ b/src/yuzu/configuration/configure_graphics.ui @@ -6,7 +6,7 @@     <rect>      <x>0</x>      <y>0</y> -    <width>400</width> +    <width>437</width>      <height>321</height>     </rect>    </property> @@ -23,43 +23,56 @@         </property>         <layout class="QVBoxLayout" name="verticalLayout_3">          <item> -         <layout class="QHBoxLayout" name="horizontalLayout_4"> -          <item> -           <widget class="QLabel" name="label_2"> -            <property name="text"> -             <string>API:</string> -            </property> -           </widget> -          </item> -          <item> -           <widget class="QComboBox" name="api"> -            <item> +         <widget class="QWidget" name="api_layout" native="true"> +          <layout class="QGridLayout" name="gridLayout"> +           <property name="leftMargin"> +            <number>0</number> +           </property> +           <property name="topMargin"> +            <number>0</number> +           </property> +           <property name="rightMargin"> +            <number>0</number> +           </property> +           <property name="bottomMargin"> +            <number>0</number> +           </property> +           <property name="horizontalSpacing"> +            <number>6</number> +           </property> +           <item row="0" column="0"> +            <widget class="QLabel" name="api_label">               <property name="text"> -              <string notr="true">OpenGL</string> +              <string>API:</string>               </property> -            </item> -            <item> +            </widget> +           </item> +           <item row="0" column="1"> +            <widget class="QComboBox" name="api"> +             <item> +              <property name="text"> +               <string notr="true">OpenGL</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string notr="true">Vulkan</string> +              </property> +             </item> +            </widget> +           </item> +           <item row="1" column="0"> +            <widget class="QLabel" name="device_label">               <property name="text"> -              <string notr="true">Vulkan</string> +              <string>Device:</string>               </property> -            </item> -           </widget> -          </item> -         </layout> -        </item> -        <item> -         <layout class="QHBoxLayout" name="horizontalLayout_5"> -          <item> -           <widget class="QLabel" name="label_3"> -            <property name="text"> -             <string>Device:</string> -            </property> -           </widget> -          </item> -          <item> -           <widget class="QComboBox" name="device"/> -          </item> -         </layout> +            </widget> +           </item> +           <item row="1" column="1"> +            <widget class="QComboBox" name="device"/> +           </item> +          </layout> +         </widget>          </item>         </layout>        </widget> @@ -85,96 +98,133 @@           </widget>          </item>          <item> -         <layout class="QHBoxLayout" name="horizontalLayout_6"> -          <item> -           <widget class="QLabel" name="ar_label"> -            <property name="text"> -             <string>Aspect Ratio:</string> -            </property> -           </widget> -          </item> -          <item> -           <widget class="QComboBox" name="aspect_ratio_combobox"> -            <item> -             <property name="text"> -              <string>Default (16:9)</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>Force 4:3</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>Force 21:9</string> -             </property> -            </item> -            <item> +         <widget class="QWidget" name="aspect_ratio_layout" native="true"> +          <layout class="QHBoxLayout" name="horizontalLayout_6"> +           <property name="leftMargin"> +            <number>0</number> +           </property> +           <property name="topMargin"> +            <number>0</number> +           </property> +           <property name="rightMargin"> +            <number>0</number> +           </property> +           <property name="bottomMargin"> +            <number>0</number> +           </property> +           <item> +            <widget class="QLabel" name="ar_label">               <property name="text"> -              <string>Stretch to Window</string> +              <string>Aspect Ratio:</string>               </property> -            </item> -           </widget> -          </item> -         </layout> +            </widget> +           </item> +           <item> +            <widget class="QComboBox" name="aspect_ratio_combobox"> +             <item> +              <property name="text"> +               <string>Default (16:9)</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string>Force 4:3</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string>Force 21:9</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string>Stretch to Window</string> +              </property> +             </item> +            </widget> +           </item> +          </layout> +         </widget>          </item>          <item> -         <layout class="QHBoxLayout" name="horizontalLayout_3"> -          <item> -           <widget class="QComboBox" name="bg_combobox"> -            <property name="currentText"> -             <string>Use global background color</string> -            </property> -            <property name="currentIndex"> -             <number>0</number> -            </property> -            <property name="maxVisibleItems"> -             <number>10</number> -            </property> -            <item> -             <property name="text"> +         <widget class="QWidget" name="bg_layout" native="true"> +          <property name="sizePolicy"> +           <sizepolicy hsizetype="Preferred" vsizetype="Preferred"> +            <horstretch>0</horstretch> +            <verstretch>0</verstretch> +           </sizepolicy> +          </property> +          <layout class="QHBoxLayout" name="horizontalLayout_3"> +           <property name="spacing"> +            <number>6</number> +           </property> +           <property name="leftMargin"> +            <number>0</number> +           </property> +           <property name="topMargin"> +            <number>0</number> +           </property> +           <property name="rightMargin"> +            <number>0</number> +           </property> +           <property name="bottomMargin"> +            <number>0</number> +           </property> +           <item> +            <widget class="QComboBox" name="bg_combobox"> +             <property name="currentText">                <string>Use global background color</string>               </property> -            </item> -            <item> +             <property name="currentIndex"> +              <number>0</number> +             </property> +             <property name="maxVisibleItems"> +              <number>10</number> +             </property> +             <item> +              <property name="text"> +               <string>Use global background color</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string>Set background color:</string> +              </property> +             </item> +            </widget> +           </item> +           <item> +            <widget class="QLabel" name="bg_label">               <property name="text"> -              <string>Set background color:</string> +              <string>Background Color:</string>               </property> -            </item> -           </widget> -          </item> -          <item> -           <widget class="QLabel" name="bg_label"> -            <property name="text"> -             <string>Background Color:</string> -            </property> -           </widget> -          </item> -          <item> -           <spacer name="horizontalSpacer"> -            <property name="orientation"> -             <enum>Qt::Horizontal</enum> -            </property> -            <property name="sizeHint" stdset="0"> -             <size> -              <width>40</width> -              <height>20</height> -             </size> -            </property> -           </spacer> -          </item> -          <item> -           <widget class="QPushButton" name="bg_button"> -            <property name="maximumSize"> -             <size> -              <width>40</width> -              <height>16777215</height> -             </size> -            </property> -           </widget> -          </item> -         </layout> +            </widget> +           </item> +           <item> +            <spacer name="horizontalSpacer"> +             <property name="orientation"> +              <enum>Qt::Horizontal</enum> +             </property> +             <property name="sizeHint" stdset="0"> +              <size> +               <width>40</width> +               <height>20</height> +              </size> +             </property> +            </spacer> +           </item> +           <item> +            <widget class="QPushButton" name="bg_button"> +             <property name="maximumSize"> +              <size> +               <width>40</width> +               <height>16777215</height> +              </size> +             </property> +            </widget> +           </item> +          </layout> +         </widget>          </item>         </layout>        </widget> diff --git a/src/yuzu/configuration/configure_graphics_advanced.cpp b/src/yuzu/configuration/configure_graphics_advanced.cpp index ce30188cd..c5d1a778c 100644 --- a/src/yuzu/configuration/configure_graphics_advanced.cpp +++ b/src/yuzu/configuration/configure_graphics_advanced.cpp @@ -25,35 +25,26 @@ void ConfigureGraphicsAdvanced::SetConfiguration() {      ui->use_vsync->setEnabled(runtime_lock);      ui->use_assembly_shaders->setEnabled(runtime_lock);      ui->use_asynchronous_shaders->setEnabled(runtime_lock); -    ui->force_30fps_mode->setEnabled(runtime_lock);      ui->anisotropic_filtering_combobox->setEnabled(runtime_lock); +    ui->use_vsync->setChecked(Settings::values.use_vsync.GetValue()); +    ui->use_assembly_shaders->setChecked(Settings::values.use_assembly_shaders.GetValue()); +    ui->use_asynchronous_shaders->setChecked(Settings::values.use_asynchronous_shaders.GetValue()); +    ui->use_fast_gpu_time->setChecked(Settings::values.use_fast_gpu_time.GetValue()); +      if (Settings::configuring_global) {          ui->gpu_accuracy->setCurrentIndex(              static_cast<int>(Settings::values.gpu_accuracy.GetValue())); -        ui->use_vsync->setChecked(Settings::values.use_vsync.GetValue()); -        ui->use_assembly_shaders->setChecked(Settings::values.use_assembly_shaders.GetValue()); -        ui->use_asynchronous_shaders->setChecked( -            Settings::values.use_asynchronous_shaders.GetValue()); -        ui->use_fast_gpu_time->setChecked(Settings::values.use_fast_gpu_time.GetValue()); -        ui->force_30fps_mode->setChecked(Settings::values.force_30fps_mode.GetValue());          ui->anisotropic_filtering_combobox->setCurrentIndex(              Settings::values.max_anisotropy.GetValue());      } else {          ConfigurationShared::SetPerGameSetting(ui->gpu_accuracy, &Settings::values.gpu_accuracy); -        ConfigurationShared::SetPerGameSetting(ui->use_vsync, &Settings::values.use_vsync); -        ConfigurationShared::SetPerGameSetting(ui->use_assembly_shaders, -                                               &Settings::values.use_assembly_shaders); -        ConfigurationShared::SetPerGameSetting(ui->use_asynchronous_shaders, -                                               &Settings::values.use_asynchronous_shaders); -        ConfigurationShared::SetPerGameSetting(ui->use_asynchronous_shaders, -                                               &Settings::values.use_asynchronous_shaders); -        ConfigurationShared::SetPerGameSetting(ui->use_fast_gpu_time, -                                               &Settings::values.use_fast_gpu_time); -        ConfigurationShared::SetPerGameSetting(ui->force_30fps_mode, -                                               &Settings::values.force_30fps_mode);          ConfigurationShared::SetPerGameSetting(ui->anisotropic_filtering_combobox,                                                 &Settings::values.max_anisotropy); +        ConfigurationShared::SetHighlight(ui->label_gpu_accuracy, "label_gpu_accuracy", +                                          !Settings::values.gpu_accuracy.UsingGlobal()); +        ConfigurationShared::SetHighlight(ui->af_label, "af_label", +                                          !Settings::values.max_anisotropy.UsingGlobal());      }  } @@ -85,9 +76,6 @@ void ConfigureGraphicsAdvanced::ApplyConfiguration() {          if (Settings::values.use_fast_gpu_time.UsingGlobal()) {              Settings::values.use_fast_gpu_time.SetValue(ui->use_fast_gpu_time->isChecked());          } -        if (Settings::values.force_30fps_mode.UsingGlobal()) { -            Settings::values.force_30fps_mode.SetValue(ui->force_30fps_mode->isChecked()); -        }          if (Settings::values.max_anisotropy.UsingGlobal()) {              Settings::values.max_anisotropy.SetValue(                  ui->anisotropic_filtering_combobox->currentIndex()); @@ -95,17 +83,15 @@ void ConfigureGraphicsAdvanced::ApplyConfiguration() {      } else {          ConfigurationShared::ApplyPerGameSetting(&Settings::values.max_anisotropy,                                                   ui->anisotropic_filtering_combobox); -        ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_vsync, ui->use_vsync); +        ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_vsync, ui->use_vsync, +                                                 use_vsync);          ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_assembly_shaders, -                                                 ui->use_assembly_shaders); -        ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_asynchronous_shaders, -                                                 ui->use_asynchronous_shaders); +                                                 ui->use_assembly_shaders, use_assembly_shaders);          ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_asynchronous_shaders, -                                                 ui->use_asynchronous_shaders); +                                                 ui->use_asynchronous_shaders, +                                                 use_asynchronous_shaders);          ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_fast_gpu_time, -                                                 ui->use_fast_gpu_time); -        ConfigurationShared::ApplyPerGameSetting(&Settings::values.force_30fps_mode, -                                                 ui->force_30fps_mode); +                                                 ui->use_fast_gpu_time, use_fast_gpu_time);          ConfigurationShared::ApplyPerGameSetting(&Settings::values.max_anisotropy,                                                   ui->anisotropic_filtering_combobox); @@ -139,18 +125,26 @@ void ConfigureGraphicsAdvanced::SetupPerGameUI() {          ui->use_asynchronous_shaders->setEnabled(              Settings::values.use_asynchronous_shaders.UsingGlobal());          ui->use_fast_gpu_time->setEnabled(Settings::values.use_fast_gpu_time.UsingGlobal()); -        ui->force_30fps_mode->setEnabled(Settings::values.force_30fps_mode.UsingGlobal());          ui->anisotropic_filtering_combobox->setEnabled(              Settings::values.max_anisotropy.UsingGlobal());          return;      } -    ConfigurationShared::InsertGlobalItem(ui->gpu_accuracy); -    ui->use_vsync->setTristate(true); -    ui->use_assembly_shaders->setTristate(true); -    ui->use_asynchronous_shaders->setTristate(true); -    ui->use_fast_gpu_time->setTristate(true); -    ui->force_30fps_mode->setTristate(true); -    ConfigurationShared::InsertGlobalItem(ui->anisotropic_filtering_combobox); +    ConfigurationShared::SetColoredTristate(ui->use_vsync, "use_vsync", Settings::values.use_vsync, +                                            use_vsync); +    ConfigurationShared::SetColoredTristate(ui->use_assembly_shaders, "use_assembly_shaders", +                                            Settings::values.use_assembly_shaders, +                                            use_assembly_shaders); +    ConfigurationShared::SetColoredTristate( +        ui->use_asynchronous_shaders, "use_asynchronous_shaders", +        Settings::values.use_asynchronous_shaders, use_asynchronous_shaders); +    ConfigurationShared::SetColoredTristate(ui->use_fast_gpu_time, "use_fast_gpu_time", +                                            Settings::values.use_fast_gpu_time, use_fast_gpu_time); +    ConfigurationShared::SetColoredComboBox( +        ui->gpu_accuracy, ui->label_gpu_accuracy, "label_gpu_accuracy", +        static_cast<int>(Settings::values.gpu_accuracy.GetValue(true))); +    ConfigurationShared::SetColoredComboBox( +        ui->anisotropic_filtering_combobox, ui->af_label, "af_label", +        static_cast<int>(Settings::values.max_anisotropy.GetValue(true)));  } diff --git a/src/yuzu/configuration/configure_graphics_advanced.h b/src/yuzu/configuration/configure_graphics_advanced.h index c043588ff..e61b571c7 100644 --- a/src/yuzu/configuration/configure_graphics_advanced.h +++ b/src/yuzu/configuration/configure_graphics_advanced.h @@ -7,6 +7,10 @@  #include <memory>  #include <QWidget> +namespace ConfigurationShared { +enum class CheckState; +} +  namespace Ui {  class ConfigureGraphicsAdvanced;  } @@ -29,4 +33,9 @@ private:      void SetupPerGameUI();      std::unique_ptr<Ui::ConfigureGraphicsAdvanced> ui; + +    ConfigurationShared::CheckState use_vsync; +    ConfigurationShared::CheckState use_assembly_shaders; +    ConfigurationShared::CheckState use_asynchronous_shaders; +    ConfigurationShared::CheckState use_fast_gpu_time;  }; diff --git a/src/yuzu/configuration/configure_graphics_advanced.ui b/src/yuzu/configuration/configure_graphics_advanced.ui index 71e7dfe5e..a793c803d 100644 --- a/src/yuzu/configuration/configure_graphics_advanced.ui +++ b/src/yuzu/configuration/configure_graphics_advanced.ui @@ -6,7 +6,7 @@     <rect>      <x>0</x>      <y>0</y> -    <width>400</width> +    <width>404</width>      <height>321</height>     </rect>    </property> @@ -23,34 +23,48 @@         </property>         <layout class="QVBoxLayout" name="verticalLayout_3">          <item> -         <layout class="QHBoxLayout" name="horizontalLayout_2"> -          <item> -           <widget class="QLabel" name="label_gpu_accuracy"> -            <property name="text"> -             <string>Accuracy Level:</string> -            </property> -           </widget> -          </item> -          <item> -           <widget class="QComboBox" name="gpu_accuracy"> -            <item> +         <widget class="QWidget" name="gpu_accuracy_layout" native="true"> +          <layout class="QHBoxLayout" name="horizontalLayout_2"> +           <property name="leftMargin"> +            <number>0</number> +           </property> +           <property name="topMargin"> +            <number>0</number> +           </property> +           <property name="rightMargin"> +            <number>0</number> +           </property> +           <property name="bottomMargin"> +            <number>0</number> +           </property> +           <item> +            <widget class="QLabel" name="label_gpu_accuracy">               <property name="text"> -              <string notr="true">Normal</string> +              <string>Accuracy Level:</string>               </property> -            </item> -            <item> -             <property name="text"> -              <string notr="true">High</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string notr="true">Extreme(very slow)</string> -             </property> -            </item> -           </widget> -          </item> -         </layout> +            </widget> +           </item> +           <item> +            <widget class="QComboBox" name="gpu_accuracy"> +             <item> +              <property name="text"> +               <string notr="true">Normal</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string notr="true">High</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string notr="true">Extreme(very slow)</string> +              </property> +             </item> +            </widget> +           </item> +          </layout> +         </widget>          </item>          <item>           <widget class="QCheckBox" name="use_vsync"> @@ -83,13 +97,6 @@           </widget>          </item>          <item> -         <widget class="QCheckBox" name="force_30fps_mode"> -          <property name="text"> -           <string>Force 30 FPS mode</string> -          </property> -         </widget> -        </item> -        <item>           <widget class="QCheckBox" name="use_fast_gpu_time">            <property name="text">             <string>Use Fast GPU Time</string> @@ -97,44 +104,58 @@           </widget>          </item>          <item> -         <layout class="QHBoxLayout" name="horizontalLayout_1"> -          <item> -           <widget class="QLabel" name="af_label"> -            <property name="text"> -             <string>Anisotropic Filtering:</string> -            </property> -           </widget> -          </item> -          <item> -           <widget class="QComboBox" name="anisotropic_filtering_combobox"> -            <item> +         <widget class="QWidget" name="af_layout" native="true"> +          <layout class="QHBoxLayout" name="horizontalLayout_1"> +           <property name="leftMargin"> +            <number>0</number> +           </property> +           <property name="topMargin"> +            <number>0</number> +           </property> +           <property name="rightMargin"> +            <number>0</number> +           </property> +           <property name="bottomMargin"> +            <number>0</number> +           </property> +           <item> +            <widget class="QLabel" name="af_label">               <property name="text"> -              <string>Default</string> +              <string>Anisotropic Filtering:</string>               </property> -            </item> -            <item> -             <property name="text"> -              <string>2x</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>4x</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>8x</string> -             </property> -            </item> -            <item> -             <property name="text"> -              <string>16x</string> -             </property> -            </item> -           </widget> -          </item> -         </layout> +            </widget> +           </item> +           <item> +            <widget class="QComboBox" name="anisotropic_filtering_combobox"> +             <item> +              <property name="text"> +               <string>Default</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string>2x</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string>4x</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string>8x</string> +              </property> +             </item> +             <item> +              <property name="text"> +               <string>16x</string> +              </property> +             </item> +            </widget> +           </item> +          </layout> +         </widget>          </item>         </layout>        </widget> diff --git a/src/yuzu/configuration/configure_input_player.cpp b/src/yuzu/configuration/configure_input_player.cpp index 00433926d..b1850bc95 100644 --- a/src/yuzu/configuration/configure_input_player.cpp +++ b/src/yuzu/configuration/configure_input_player.cpp @@ -280,9 +280,9 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i          }          button->setContextMenuPolicy(Qt::CustomContextMenu); -        connect(button, &QPushButton::clicked, [=] { +        connect(button, &QPushButton::clicked, [=, this] {              HandleClick(button_map[button_id], -                        [=](Common::ParamPackage params) { +                        [=, this](Common::ParamPackage params) {                              // Workaround for ZL & ZR for analog triggers like on XBOX controllors.                              // Analog triggers (from controllers like the XBOX controller) would not                              // work due to a different range of their signals (from 0 to 255 on @@ -300,19 +300,20 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i                          },                          InputCommon::Polling::DeviceType::Button);          }); -        connect(button, &QPushButton::customContextMenuRequested, [=](const QPoint& menu_location) { -            QMenu context_menu; -            context_menu.addAction(tr("Clear"), [&] { -                buttons_param[button_id].Clear(); -                button_map[button_id]->setText(tr("[not set]")); -            }); -            context_menu.addAction(tr("Restore Default"), [&] { -                buttons_param[button_id] = Common::ParamPackage{ -                    InputCommon::GenerateKeyboardParam(Config::default_buttons[button_id])}; -                button_map[button_id]->setText(ButtonToText(buttons_param[button_id])); -            }); -            context_menu.exec(button_map[button_id]->mapToGlobal(menu_location)); -        }); +        connect(button, &QPushButton::customContextMenuRequested, +                [=, this](const QPoint& menu_location) { +                    QMenu context_menu; +                    context_menu.addAction(tr("Clear"), [&] { +                        buttons_param[button_id].Clear(); +                        button_map[button_id]->setText(tr("[not set]")); +                    }); +                    context_menu.addAction(tr("Restore Default"), [&] { +                        buttons_param[button_id] = Common::ParamPackage{ +                            InputCommon::GenerateKeyboardParam(Config::default_buttons[button_id])}; +                        button_map[button_id]->setText(ButtonToText(buttons_param[button_id])); +                    }); +                    context_menu.exec(button_map[button_id]->mapToGlobal(menu_location)); +                });      }      for (int analog_id = 0; analog_id < Settings::NativeAnalog::NumAnalogs; analog_id++) { @@ -323,16 +324,16 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i              }              analog_button->setContextMenuPolicy(Qt::CustomContextMenu); -            connect(analog_button, &QPushButton::clicked, [=]() { +            connect(analog_button, &QPushButton::clicked, [=, this] {                  HandleClick(analog_map_buttons[analog_id][sub_button_id], -                            [=](const Common::ParamPackage& params) { +                            [=, this](const Common::ParamPackage& params) {                                  SetAnalogButton(params, analogs_param[analog_id],                                                  analog_sub_buttons[sub_button_id]);                              },                              InputCommon::Polling::DeviceType::Button);              });              connect(analog_button, &QPushButton::customContextMenuRequested, -                    [=](const QPoint& menu_location) { +                    [=, this](const QPoint& menu_location) {                          QMenu context_menu;                          context_menu.addAction(tr("Clear"), [&] {                              analogs_param[analog_id].Erase(analog_sub_buttons[sub_button_id]); @@ -350,32 +351,35 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i                              menu_location));                      });          } -        connect(analog_map_stick[analog_id], &QPushButton::clicked, [=] { +        connect(analog_map_stick[analog_id], &QPushButton::clicked, [=, this] {              if (QMessageBox::information(                      this, tr("Information"),                      tr("After pressing OK, first move your joystick horizontally, "                         "and then vertically."),                      QMessageBox::Ok | QMessageBox::Cancel) == QMessageBox::Ok) { -                HandleClick( -                    analog_map_stick[analog_id], -                    [=](const Common::ParamPackage& params) { analogs_param[analog_id] = params; }, -                    InputCommon::Polling::DeviceType::Analog); +                HandleClick(analog_map_stick[analog_id], +                            [=, this](const Common::ParamPackage& params) { +                                analogs_param[analog_id] = params; +                            }, +                            InputCommon::Polling::DeviceType::Analog);              }          }); -        connect(analog_map_deadzone_and_modifier_slider[analog_id], &QSlider::valueChanged, [=] { -            const float slider_value = analog_map_deadzone_and_modifier_slider[analog_id]->value(); -            if (analogs_param[analog_id].Get("engine", "") == "sdl" || -                analogs_param[analog_id].Get("engine", "") == "gcpad") { -                analog_map_deadzone_and_modifier_slider_label[analog_id]->setText( -                    tr("Deadzone: %1%").arg(slider_value)); -                analogs_param[analog_id].Set("deadzone", slider_value / 100.0f); -            } else { -                analog_map_deadzone_and_modifier_slider_label[analog_id]->setText( -                    tr("Modifier Scale: %1%").arg(slider_value)); -                analogs_param[analog_id].Set("modifier_scale", slider_value / 100.0f); -            } -        }); +        connect(analog_map_deadzone_and_modifier_slider[analog_id], &QSlider::valueChanged, +                [=, this] { +                    const float slider_value = +                        analog_map_deadzone_and_modifier_slider[analog_id]->value(); +                    if (analogs_param[analog_id].Get("engine", "") == "sdl" || +                        analogs_param[analog_id].Get("engine", "") == "gcpad") { +                        analog_map_deadzone_and_modifier_slider_label[analog_id]->setText( +                            tr("Deadzone: %1%").arg(slider_value)); +                        analogs_param[analog_id].Set("deadzone", slider_value / 100.0f); +                    } else { +                        analog_map_deadzone_and_modifier_slider_label[analog_id]->setText( +                            tr("Modifier Scale: %1%").arg(slider_value)); +                        analogs_param[analog_id].Set("modifier_scale", slider_value / 100.0f); +                    } +                });      }      connect(ui->buttonClearAll, &QPushButton::clicked, [this] { ClearAll(); }); diff --git a/src/yuzu/configuration/configure_mouse_advanced.cpp b/src/yuzu/configuration/configure_mouse_advanced.cpp index e0647ea5b..ea2549363 100644 --- a/src/yuzu/configuration/configure_mouse_advanced.cpp +++ b/src/yuzu/configuration/configure_mouse_advanced.cpp @@ -83,25 +83,28 @@ ConfigureMouseAdvanced::ConfigureMouseAdvanced(QWidget* parent)          }          button->setContextMenuPolicy(Qt::CustomContextMenu); -        connect(button, &QPushButton::clicked, [=] { -            HandleClick( -                button_map[button_id], -                [=](const Common::ParamPackage& params) { buttons_param[button_id] = params; }, -                InputCommon::Polling::DeviceType::Button); -        }); -        connect(button, &QPushButton::customContextMenuRequested, [=](const QPoint& menu_location) { -            QMenu context_menu; -            context_menu.addAction(tr("Clear"), [&] { -                buttons_param[button_id].Clear(); -                button_map[button_id]->setText(tr("[not set]")); -            }); -            context_menu.addAction(tr("Restore Default"), [&] { -                buttons_param[button_id] = Common::ParamPackage{ -                    InputCommon::GenerateKeyboardParam(Config::default_mouse_buttons[button_id])}; -                button_map[button_id]->setText(ButtonToText(buttons_param[button_id])); -            }); -            context_menu.exec(button_map[button_id]->mapToGlobal(menu_location)); +        connect(button, &QPushButton::clicked, [=, this] { +            HandleClick(button_map[button_id], +                        [=, this](const Common::ParamPackage& params) { +                            buttons_param[button_id] = params; +                        }, +                        InputCommon::Polling::DeviceType::Button);          }); +        connect(button, &QPushButton::customContextMenuRequested, +                [=, this](const QPoint& menu_location) { +                    QMenu context_menu; +                    context_menu.addAction(tr("Clear"), [&] { +                        buttons_param[button_id].Clear(); +                        button_map[button_id]->setText(tr("[not set]")); +                    }); +                    context_menu.addAction(tr("Restore Default"), [&] { +                        buttons_param[button_id] = +                            Common::ParamPackage{InputCommon::GenerateKeyboardParam( +                                Config::default_mouse_buttons[button_id])}; +                        button_map[button_id]->setText(ButtonToText(buttons_param[button_id])); +                    }); +                    context_menu.exec(button_map[button_id]->mapToGlobal(menu_location)); +                });      }      connect(ui->buttonClearAll, &QPushButton::clicked, [this] { ClearAll(); }); diff --git a/src/yuzu/configuration/configure_system.cpp b/src/yuzu/configuration/configure_system.cpp index 68e02738b..0c4daf147 100644 --- a/src/yuzu/configuration/configure_system.cpp +++ b/src/yuzu/configuration/configure_system.cpp @@ -67,21 +67,21 @@ void ConfigureSystem::SetConfiguration() {      const auto rtc_time = Settings::values.custom_rtc.GetValue().value_or(          std::chrono::seconds(QDateTime::currentSecsSinceEpoch())); +    ui->rng_seed_checkbox->setChecked(Settings::values.rng_seed.GetValue().has_value()); +    ui->rng_seed_edit->setEnabled(Settings::values.rng_seed.GetValue().has_value() && +                                  Settings::values.rng_seed.UsingGlobal()); +    ui->rng_seed_edit->setText(rng_seed); + +    ui->custom_rtc_checkbox->setChecked(Settings::values.custom_rtc.GetValue().has_value()); +    ui->custom_rtc_edit->setEnabled(Settings::values.custom_rtc.GetValue().has_value() && +                                    Settings::values.rng_seed.UsingGlobal()); +    ui->custom_rtc_edit->setDateTime(QDateTime::fromSecsSinceEpoch(rtc_time.count())); +      if (Settings::configuring_global) {          ui->combo_language->setCurrentIndex(Settings::values.language_index.GetValue());          ui->combo_region->setCurrentIndex(Settings::values.region_index.GetValue());          ui->combo_time_zone->setCurrentIndex(Settings::values.time_zone_index.GetValue());          ui->combo_sound->setCurrentIndex(Settings::values.sound_index.GetValue()); - -        ui->rng_seed_checkbox->setChecked(Settings::values.rng_seed.GetValue().has_value()); -        ui->rng_seed_edit->setEnabled(Settings::values.rng_seed.GetValue().has_value() && -                                      Settings::values.rng_seed.UsingGlobal()); -        ui->rng_seed_edit->setText(rng_seed); - -        ui->custom_rtc_checkbox->setChecked(Settings::values.custom_rtc.GetValue().has_value()); -        ui->custom_rtc_edit->setEnabled(Settings::values.custom_rtc.GetValue().has_value() && -                                        Settings::values.rng_seed.UsingGlobal()); -        ui->custom_rtc_edit->setDateTime(QDateTime::fromSecsSinceEpoch(rtc_time.count()));      } else {          ConfigurationShared::SetPerGameSetting(ui->combo_language,                                                 &Settings::values.language_index); @@ -90,27 +90,14 @@ void ConfigureSystem::SetConfiguration() {                                                 &Settings::values.time_zone_index);          ConfigurationShared::SetPerGameSetting(ui->combo_sound, &Settings::values.sound_index); -        if (Settings::values.rng_seed.UsingGlobal()) { -            ui->rng_seed_checkbox->setCheckState(Qt::PartiallyChecked); -        } else { -            ui->rng_seed_checkbox->setCheckState( -                Settings::values.rng_seed.GetValue().has_value() ? Qt::Checked : Qt::Unchecked); -            ui->rng_seed_edit->setEnabled(Settings::values.rng_seed.GetValue().has_value()); -            if (Settings::values.rng_seed.GetValue().has_value()) { -                ui->rng_seed_edit->setText(rng_seed); -            } -        } - -        if (Settings::values.custom_rtc.UsingGlobal()) { -            ui->custom_rtc_checkbox->setCheckState(Qt::PartiallyChecked); -        } else { -            ui->custom_rtc_checkbox->setCheckState( -                Settings::values.custom_rtc.GetValue().has_value() ? Qt::Checked : Qt::Unchecked); -            ui->custom_rtc_edit->setEnabled(Settings::values.custom_rtc.GetValue().has_value()); -            if (Settings::values.custom_rtc.GetValue().has_value()) { -                ui->custom_rtc_edit->setDateTime(QDateTime::fromSecsSinceEpoch(rtc_time.count())); -            } -        } +        ConfigurationShared::SetHighlight(ui->label_language, "label_language", +                                          !Settings::values.language_index.UsingGlobal()); +        ConfigurationShared::SetHighlight(ui->label_region, "label_region", +                                          !Settings::values.region_index.UsingGlobal()); +        ConfigurationShared::SetHighlight(ui->label_timezone, "label_timezone", +                                          !Settings::values.time_zone_index.UsingGlobal()); +        ConfigurationShared::SetHighlight(ui->label_sound, "label_sound", +                                          !Settings::values.sound_index.UsingGlobal());      }  } @@ -161,37 +148,44 @@ void ConfigureSystem::ApplyConfiguration() {                                                   ui->combo_time_zone);          ConfigurationShared::ApplyPerGameSetting(&Settings::values.sound_index, ui->combo_sound); -        switch (ui->rng_seed_checkbox->checkState()) { -        case Qt::Checked: -            Settings::values.rng_seed.SetGlobal(false); -            Settings::values.rng_seed.SetValue(ui->rng_seed_edit->text().toULongLong(nullptr, 16)); -            break; -        case Qt::Unchecked: +        switch (use_rng_seed) { +        case ConfigurationShared::CheckState::On: +        case ConfigurationShared::CheckState::Off:              Settings::values.rng_seed.SetGlobal(false); -            Settings::values.rng_seed.SetValue(std::nullopt); +            if (ui->rng_seed_checkbox->isChecked()) { +                Settings::values.rng_seed.SetValue( +                    ui->rng_seed_edit->text().toULongLong(nullptr, 16)); +            } else { +                Settings::values.rng_seed.SetValue(std::nullopt); +            }              break; -        case Qt::PartiallyChecked: +        case ConfigurationShared::CheckState::Global:              Settings::values.rng_seed.SetGlobal(false);              Settings::values.rng_seed.SetValue(std::nullopt);              Settings::values.rng_seed.SetGlobal(true);              break; +        case ConfigurationShared::CheckState::Count: +            break;          } -        switch (ui->custom_rtc_checkbox->checkState()) { -        case Qt::Checked: -            Settings::values.custom_rtc.SetGlobal(false); -            Settings::values.custom_rtc.SetValue( -                std::chrono::seconds(ui->custom_rtc_edit->dateTime().toSecsSinceEpoch())); -            break; -        case Qt::Unchecked: +        switch (use_custom_rtc) { +        case ConfigurationShared::CheckState::On: +        case ConfigurationShared::CheckState::Off:              Settings::values.custom_rtc.SetGlobal(false); -            Settings::values.custom_rtc.SetValue(std::nullopt); +            if (ui->custom_rtc_checkbox->isChecked()) { +                Settings::values.custom_rtc.SetValue( +                    std::chrono::seconds(ui->custom_rtc_edit->dateTime().toSecsSinceEpoch())); +            } else { +                Settings::values.custom_rtc.SetValue(std::nullopt); +            }              break; -        case Qt::PartiallyChecked: +        case ConfigurationShared::CheckState::Global:              Settings::values.custom_rtc.SetGlobal(false);              Settings::values.custom_rtc.SetValue(std::nullopt);              Settings::values.custom_rtc.SetGlobal(true);              break; +        case ConfigurationShared::CheckState::Count: +            break;          }      } @@ -229,10 +223,23 @@ void ConfigureSystem::SetupPerGameUI() {          return;      } -    ConfigurationShared::InsertGlobalItem(ui->combo_language); -    ConfigurationShared::InsertGlobalItem(ui->combo_region); -    ConfigurationShared::InsertGlobalItem(ui->combo_time_zone); -    ConfigurationShared::InsertGlobalItem(ui->combo_sound); -    ui->rng_seed_checkbox->setTristate(true); -    ui->custom_rtc_checkbox->setTristate(true); +    ConfigurationShared::SetColoredComboBox(ui->combo_language, ui->label_language, +                                            "label_language", +                                            Settings::values.language_index.GetValue(true)); +    ConfigurationShared::SetColoredComboBox(ui->combo_region, ui->label_region, "label_region", +                                            Settings::values.region_index.GetValue(true)); +    ConfigurationShared::SetColoredComboBox(ui->combo_time_zone, ui->label_timezone, +                                            "label_timezone", +                                            Settings::values.time_zone_index.GetValue(true)); +    ConfigurationShared::SetColoredComboBox(ui->combo_sound, ui->label_sound, "label_sound", +                                            Settings::values.sound_index.GetValue(true)); + +    ConfigurationShared::SetColoredTristate( +        ui->rng_seed_checkbox, "rng_seed_checkbox", Settings::values.rng_seed.UsingGlobal(), +        Settings::values.rng_seed.GetValue().has_value(), +        Settings::values.rng_seed.GetValue(true).has_value(), use_rng_seed); +    ConfigurationShared::SetColoredTristate( +        ui->custom_rtc_checkbox, "custom_rtc_checkbox", Settings::values.custom_rtc.UsingGlobal(), +        Settings::values.custom_rtc.GetValue().has_value(), +        Settings::values.custom_rtc.GetValue(true).has_value(), use_custom_rtc);  } diff --git a/src/yuzu/configuration/configure_system.h b/src/yuzu/configuration/configure_system.h index f317ef8b5..fc5cd2945 100644 --- a/src/yuzu/configuration/configure_system.h +++ b/src/yuzu/configuration/configure_system.h @@ -9,6 +9,10 @@  #include <QList>  #include <QWidget> +namespace ConfigurationShared { +enum class CheckState; +} +  namespace Ui {  class ConfigureSystem;  } @@ -41,4 +45,7 @@ private:      int region_index = 0;      int time_zone_index = 0;      int sound_index = 0; + +    ConfigurationShared::CheckState use_rng_seed; +    ConfigurationShared::CheckState use_custom_rtc;  }; diff --git a/src/yuzu/configuration/configure_system.ui b/src/yuzu/configuration/configure_system.ui index 9c8cca6dc..53b95658b 100644 --- a/src/yuzu/configuration/configure_system.ui +++ b/src/yuzu/configuration/configure_system.ui @@ -21,490 +21,494 @@         <property name="title">          <string>System Settings</string>         </property> -       <layout class="QGridLayout" name="gridLayout"> -        <item row="3" column="0"> -         <widget class="QLabel" name="label_sound"> -          <property name="text"> -           <string>Sound output mode</string> -          </property> -         </widget> -        </item> -        <item row="4" column="0"> -         <widget class="QLabel" name="label_console_id"> -          <property name="text"> -           <string>Console ID:</string> -          </property> -         </widget> -        </item> -        <item row="0" column="1"> -         <widget class="QComboBox" name="combo_language"> -          <property name="toolTip"> -           <string>Note: this can be overridden when region setting is auto-select</string> -          </property> -          <item> -           <property name="text"> -            <string>Japanese (日本語)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>English</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>French (français)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>German (Deutsch)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Italian (italiano)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Spanish (español)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Chinese</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Korean (한국어)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Dutch (Nederlands)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Portuguese (português)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Russian (Русский)</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Taiwanese</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>British English</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Canadian French</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Latin American Spanish</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Simplified Chinese</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Traditional Chinese (正體中文)</string> -           </property> -          </item> -         </widget> -        </item> -        <item row="1" column="0"> -         <widget class="QLabel" name="label_region"> -          <property name="text"> -           <string>Region:</string> -          </property> -         </widget> -        </item> -        <item row="1" column="1"> -         <widget class="QComboBox" name="combo_region"> -          <item> -           <property name="text"> -            <string>Japan</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>USA</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Europe</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Australia</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>China</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Korea</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Taiwan</string> -           </property> -          </item> -         </widget> -        </item> -        <item row="2" column="0"> -         <widget class="QLabel" name="label_timezone"> -          <property name="text"> -           <string>Time Zone:</string> -          </property> -         </widget> -        </item> -        <item row="2" column="1"> -         <widget class="QComboBox" name="combo_time_zone"> -          <item> -           <property name="text"> -            <string>Auto</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Default</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>CET</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>CST6CDT</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Cuba</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>EET</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Egypt</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Eire</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>EST</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>EST5EDT</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>GB</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>GB-Eire</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>GMT</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>GMT+0</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>GMT-0</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>GMT0</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Greenwich</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Hongkong</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>HST</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Iceland</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Iran</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Israel</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Jamaica</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Japan</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Kwajalein</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Libya</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>MET</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>MST</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>MST7MDT</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Navajo</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>NZ</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>NZ-CHAT</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Poland</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Portugal</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>PRC</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>PST8PDT</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>ROC</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>ROK</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Singapore</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Turkey</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>UCT</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Universal</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>UTC</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>W-SU</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>WET</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Zulu</string> -           </property> -          </item> -         </widget> -        </item> -        <item row="6" column="0"> -         <widget class="QCheckBox" name="rng_seed_checkbox"> -          <property name="text"> -           <string>RNG Seed</string> -          </property> -         </widget> -        </item> -        <item row="3" column="1"> -         <widget class="QComboBox" name="combo_sound"> -          <item> -           <property name="text"> -            <string>Mono</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Stereo</string> -           </property> -          </item> -          <item> -           <property name="text"> -            <string>Surround</string> -           </property> -          </item> -         </widget> -        </item> -        <item row="0" column="0"> -         <widget class="QLabel" name="label_language"> -          <property name="text"> -           <string>Language</string> -          </property> -         </widget> -        </item> -        <item row="4" column="1"> -         <widget class="QPushButton" name="button_regenerate_console_id"> -          <property name="sizePolicy"> -           <sizepolicy hsizetype="Fixed" vsizetype="Fixed"> -            <horstretch>0</horstretch> -            <verstretch>0</verstretch> -           </sizepolicy> -          </property> -          <property name="layoutDirection"> -           <enum>Qt::RightToLeft</enum> -          </property> -          <property name="text"> -           <string>Regenerate</string> -          </property> -         </widget> -        </item> -        <item row="5" column="0"> -         <widget class="QCheckBox" name="custom_rtc_checkbox"> -          <property name="text"> -           <string>Custom RTC</string> -          </property> -         </widget> -        </item> -        <item row="5" column="1"> -         <widget class="QDateTimeEdit" name="custom_rtc_edit"> -          <property name="minimumDate"> -           <date> -            <year>1970</year> -            <month>1</month> -            <day>1</day> -           </date> -          </property> -          <property name="displayFormat"> -           <string>d MMM yyyy h:mm:ss AP</string> -          </property> -         </widget> -        </item> -        <item row="6" column="1"> -         <widget class="QLineEdit" name="rng_seed_edit"> -          <property name="sizePolicy"> -           <sizepolicy hsizetype="Minimum" vsizetype="Fixed"> -            <horstretch>0</horstretch> -            <verstretch>0</verstretch> -           </sizepolicy> -          </property> -          <property name="font"> -           <font> -            <family>Lucida Console</family> -           </font> -          </property> -          <property name="inputMask"> -           <string notr="true">HHHHHHHH</string> -          </property> -          <property name="maxLength"> -           <number>8</number> -          </property> -         </widget> +       <layout class="QVBoxLayout" name="verticalLayout_2"> +        <item> +         <layout class="QGridLayout" name="gridLayout_2"> +          <item row="1" column="0"> +           <widget class="QLabel" name="label_region"> +            <property name="text"> +             <string>Region:</string> +            </property> +           </widget> +          </item> +          <item row="2" column="1"> +           <widget class="QComboBox" name="combo_time_zone"> +            <item> +             <property name="text"> +              <string>Auto</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Default</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>CET</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>CST6CDT</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Cuba</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>EET</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Egypt</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Eire</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>EST</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>EST5EDT</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>GB</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>GB-Eire</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>GMT</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>GMT+0</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>GMT-0</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>GMT0</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Greenwich</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Hongkong</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>HST</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Iceland</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Iran</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Israel</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Jamaica</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Japan</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Kwajalein</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Libya</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>MET</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>MST</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>MST7MDT</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Navajo</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>NZ</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>NZ-CHAT</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Poland</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Portugal</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>PRC</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>PST8PDT</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>ROC</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>ROK</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Singapore</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Turkey</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>UCT</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Universal</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>UTC</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>W-SU</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>WET</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Zulu</string> +             </property> +            </item> +           </widget> +          </item> +          <item row="1" column="1"> +           <widget class="QComboBox" name="combo_region"> +            <item> +             <property name="text"> +              <string>Japan</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>USA</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Europe</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Australia</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>China</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Korea</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Taiwan</string> +             </property> +            </item> +           </widget> +          </item> +          <item row="2" column="0"> +           <widget class="QLabel" name="label_timezone"> +            <property name="text"> +             <string>Time Zone:</string> +            </property> +           </widget> +          </item> +          <item row="0" column="1"> +           <widget class="QComboBox" name="combo_language"> +            <property name="toolTip"> +             <string>Note: this can be overridden when region setting is auto-select</string> +            </property> +            <item> +             <property name="text"> +              <string>Japanese (日本語)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>English</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>French (français)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>German (Deutsch)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Italian (italiano)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Spanish (español)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Chinese</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Korean (한국어)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Dutch (Nederlands)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Portuguese (português)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Russian (Русский)</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Taiwanese</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>British English</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Canadian French</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Latin American Spanish</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Simplified Chinese</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Traditional Chinese (正體中文)</string> +             </property> +            </item> +           </widget> +          </item> +          <item row="5" column="0"> +           <widget class="QCheckBox" name="custom_rtc_checkbox"> +            <property name="text"> +             <string>Custom RTC</string> +            </property> +           </widget> +          </item> +          <item row="0" column="0"> +           <widget class="QLabel" name="label_language"> +            <property name="text"> +             <string>Language</string> +            </property> +           </widget> +          </item> +          <item row="6" column="0"> +           <widget class="QCheckBox" name="rng_seed_checkbox"> +            <property name="text"> +             <string>RNG Seed</string> +            </property> +           </widget> +          </item> +          <item row="3" column="1"> +           <widget class="QComboBox" name="combo_sound"> +            <item> +             <property name="text"> +              <string>Mono</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Stereo</string> +             </property> +            </item> +            <item> +             <property name="text"> +              <string>Surround</string> +             </property> +            </item> +           </widget> +          </item> +          <item row="4" column="0"> +           <widget class="QLabel" name="label_console_id"> +            <property name="text"> +             <string>Console ID:</string> +            </property> +           </widget> +          </item> +          <item row="3" column="0"> +           <widget class="QLabel" name="label_sound"> +            <property name="text"> +             <string>Sound output mode</string> +            </property> +           </widget> +          </item> +          <item row="5" column="1"> +           <widget class="QDateTimeEdit" name="custom_rtc_edit"> +            <property name="minimumDate"> +             <date> +              <year>1970</year> +              <month>1</month> +              <day>1</day> +             </date> +            </property> +            <property name="displayFormat"> +             <string>d MMM yyyy h:mm:ss AP</string> +            </property> +           </widget> +          </item> +          <item row="6" column="1"> +           <widget class="QLineEdit" name="rng_seed_edit"> +            <property name="sizePolicy"> +             <sizepolicy hsizetype="Minimum" vsizetype="Fixed"> +              <horstretch>0</horstretch> +              <verstretch>0</verstretch> +             </sizepolicy> +            </property> +            <property name="font"> +             <font> +              <family>Lucida Console</family> +             </font> +            </property> +            <property name="inputMask"> +             <string notr="true">HHHHHHHH</string> +            </property> +            <property name="maxLength"> +             <number>8</number> +            </property> +           </widget> +          </item> +          <item row="4" column="1"> +           <widget class="QPushButton" name="button_regenerate_console_id"> +            <property name="sizePolicy"> +             <sizepolicy hsizetype="Fixed" vsizetype="Fixed"> +              <horstretch>0</horstretch> +              <verstretch>0</verstretch> +             </sizepolicy> +            </property> +            <property name="layoutDirection"> +             <enum>Qt::RightToLeft</enum> +            </property> +            <property name="text"> +             <string>Regenerate</string> +            </property> +           </widget> +          </item> +         </layout>          </item>         </layout>        </widget> diff --git a/src/yuzu/configuration/configure_ui.cpp b/src/yuzu/configuration/configure_ui.cpp index 24b6c5b72..2c20b68d0 100644 --- a/src/yuzu/configuration/configure_ui.cpp +++ b/src/yuzu/configuration/configure_ui.cpp @@ -4,9 +4,11 @@  #include <array>  #include <utility> +#include <QFileDialog>  #include <QDirIterator>  #include "common/common_types.h" +#include "common/file_util.h"  #include "core/settings.h"  #include "ui_configure_ui.h"  #include "yuzu/configuration/configure_ui.h" @@ -52,9 +54,21 @@ ConfigureUi::ConfigureUi(QWidget* parent) : QWidget(parent), ui(new Ui::Configur      // Update text ComboBoxes after user interaction.      connect(ui->row_1_text_combobox, QOverload<int>::of(&QComboBox::activated), -            [=]() { ConfigureUi::UpdateSecondRowComboBox(); }); +            [this] { ConfigureUi::UpdateSecondRowComboBox(); });      connect(ui->row_2_text_combobox, QOverload<int>::of(&QComboBox::activated), -            [=]() { ConfigureUi::UpdateFirstRowComboBox(); }); +            [this] { ConfigureUi::UpdateFirstRowComboBox(); }); + +    // Set screenshot path to user specification. +    connect(ui->screenshot_path_button, &QToolButton::pressed, this, [this] { +        const QString& filename = +            QFileDialog::getExistingDirectory( +                this, tr("Select Screenshots Path..."), +                QString::fromStdString(FileUtil::GetUserPath(FileUtil::UserPath::ScreenshotsDir))) + +            QDir::separator(); +        if (!filename.isEmpty()) { +            ui->screenshot_path_edit->setText(filename); +        } +    });  }  ConfigureUi::~ConfigureUi() = default; @@ -66,6 +80,10 @@ void ConfigureUi::ApplyConfiguration() {      UISettings::values.icon_size = ui->icon_size_combobox->currentData().toUInt();      UISettings::values.row_1_text_id = ui->row_1_text_combobox->currentData().toUInt();      UISettings::values.row_2_text_id = ui->row_2_text_combobox->currentData().toUInt(); + +    UISettings::values.enable_screenshot_save_as = ui->enable_screenshot_save_as->isChecked(); +    FileUtil::GetUserPath(FileUtil::UserPath::ScreenshotsDir, +                          ui->screenshot_path_edit->text().toStdString());      Settings::Apply();  } @@ -80,6 +98,10 @@ void ConfigureUi::SetConfiguration() {      ui->show_add_ons->setChecked(UISettings::values.show_add_ons);      ui->icon_size_combobox->setCurrentIndex(          ui->icon_size_combobox->findData(UISettings::values.icon_size)); + +    ui->enable_screenshot_save_as->setChecked(UISettings::values.enable_screenshot_save_as); +    ui->screenshot_path_edit->setText( +        QString::fromStdString(FileUtil::GetUserPath(FileUtil::UserPath::ScreenshotsDir)));  }  void ConfigureUi::changeEvent(QEvent* event) { diff --git a/src/yuzu/configuration/configure_ui.ui b/src/yuzu/configuration/configure_ui.ui index 0b81747d7..d895b799f 100644 --- a/src/yuzu/configuration/configure_ui.ui +++ b/src/yuzu/configuration/configure_ui.ui @@ -6,8 +6,8 @@     <rect>      <x>0</x>      <y>0</y> -    <width>300</width> -    <height>377</height> +    <width>363</width> +    <height>391</height>     </rect>    </property>    <property name="windowTitle"> @@ -128,6 +128,47 @@      </widget>     </item>     <item> +    <widget class="QGroupBox" name="screenshots_GroupBox"> +     <property name="title"> +      <string>Screenshots</string> +     </property> +     <layout class="QVBoxLayout" name="verticalLayout_4"> +      <item> +       <layout class="QVBoxLayout" name="verticalLayout_3"> +        <item> +         <widget class="QCheckBox" name="enable_screenshot_save_as"> +          <property name="text"> +           <string>Ask Where To Save Screenshots (Windows Only)</string> +          </property> +         </widget> +        </item> +        <item> +         <layout class="QHBoxLayout" name="horizontalLayout_4"> +          <item> +           <widget class="QLabel" name="label"> +            <property name="text"> +             <string>Screenshots Path: </string> +            </property> +           </widget> +          </item> +          <item> +           <widget class="QLineEdit" name="screenshot_path_edit"/> +          </item> +          <item> +           <widget class="QToolButton" name="screenshot_path_button"> +            <property name="text"> +             <string>...</string> +            </property> +           </widget> +          </item> +         </layout> +        </item> +       </layout> +      </item> +     </layout> +    </widget> +   </item> +   <item>      <spacer name="verticalSpacer">       <property name="orientation">        <enum>Qt::Vertical</enum> | 
