diff options
Diffstat (limited to 'src/yuzu/configuration')
| -rw-r--r-- | src/yuzu/configuration/config.cpp | 9 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_filesystem.cpp | 10 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_filesystem.h | 1 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_filesystem.ui | 35 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_input_player.cpp | 106 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_input_player.h | 6 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_input_player_widget.cpp | 3 | 
7 files changed, 112 insertions, 58 deletions
| diff --git a/src/yuzu/configuration/config.cpp b/src/yuzu/configuration/config.cpp index 0635d13d0..3d6f64300 100644 --- a/src/yuzu/configuration/config.cpp +++ b/src/yuzu/configuration/config.cpp @@ -614,12 +614,6 @@ void Config::ReadDataStorageValues() {                                  QString::fromStdString(FS::GetUserPath(FS::UserPath::DumpDir)))                          .toString()                          .toStdString()); -    FS::GetUserPath(FS::UserPath::CacheDir, -                    qt_config -                        ->value(QStringLiteral("cache_directory"), -                                QString::fromStdString(FS::GetUserPath(FS::UserPath::CacheDir))) -                        .toString() -                        .toStdString());      Settings::values.gamecard_inserted =          ReadSetting(QStringLiteral("gamecard_inserted"), false).toBool();      Settings::values.gamecard_current_game = @@ -1218,9 +1212,6 @@ void Config::SaveDataStorageValues() {      WriteSetting(QStringLiteral("dump_directory"),                   QString::fromStdString(FS::GetUserPath(FS::UserPath::DumpDir)),                   QString::fromStdString(FS::GetUserPath(FS::UserPath::DumpDir))); -    WriteSetting(QStringLiteral("cache_directory"), -                 QString::fromStdString(FS::GetUserPath(FS::UserPath::CacheDir)), -                 QString::fromStdString(FS::GetUserPath(FS::UserPath::CacheDir)));      WriteSetting(QStringLiteral("gamecard_inserted"), Settings::values.gamecard_inserted, false);      WriteSetting(QStringLiteral("gamecard_current_game"), Settings::values.gamecard_current_game,                   false); diff --git a/src/yuzu/configuration/configure_filesystem.cpp b/src/yuzu/configuration/configure_filesystem.cpp index 7ab4a80f7..bde2d4620 100644 --- a/src/yuzu/configuration/configure_filesystem.cpp +++ b/src/yuzu/configuration/configure_filesystem.cpp @@ -26,8 +26,6 @@ ConfigureFilesystem::ConfigureFilesystem(QWidget* parent)              [this] { SetDirectory(DirectoryTarget::Dump, ui->dump_path_edit); });      connect(ui->load_path_button, &QToolButton::pressed, this,              [this] { SetDirectory(DirectoryTarget::Load, ui->load_path_edit); }); -    connect(ui->cache_directory_button, &QToolButton::pressed, this, -            [this] { SetDirectory(DirectoryTarget::Cache, ui->cache_directory_edit); });      connect(ui->reset_game_list_cache, &QPushButton::pressed, this,              &ConfigureFilesystem::ResetMetadata); @@ -50,8 +48,6 @@ void ConfigureFilesystem::setConfiguration() {          QString::fromStdString(Common::FS::GetUserPath(Common::FS::UserPath::DumpDir)));      ui->load_path_edit->setText(          QString::fromStdString(Common::FS::GetUserPath(Common::FS::UserPath::LoadDir))); -    ui->cache_directory_edit->setText( -        QString::fromStdString(Common::FS::GetUserPath(Common::FS::UserPath::CacheDir)));      ui->gamecard_inserted->setChecked(Settings::values.gamecard_inserted);      ui->gamecard_current_game->setChecked(Settings::values.gamecard_current_game); @@ -72,9 +68,6 @@ void ConfigureFilesystem::applyConfiguration() {                              ui->dump_path_edit->text().toStdString());      Common::FS::GetUserPath(Common::FS::UserPath::LoadDir,                              ui->load_path_edit->text().toStdString()); -    Common::FS::GetUserPath(Common::FS::UserPath::CacheDir, -                            ui->cache_directory_edit->text().toStdString()); -    Settings::values.gamecard_path = ui->gamecard_path_edit->text().toStdString();      Settings::values.gamecard_inserted = ui->gamecard_inserted->isChecked();      Settings::values.gamecard_current_game = ui->gamecard_current_game->isChecked(); @@ -103,9 +96,6 @@ void ConfigureFilesystem::SetDirectory(DirectoryTarget target, QLineEdit* edit)      case DirectoryTarget::Load:          caption = tr("Select Mod Load Directory...");          break; -    case DirectoryTarget::Cache: -        caption = tr("Select Cache Directory..."); -        break;      }      QString str; diff --git a/src/yuzu/configuration/configure_filesystem.h b/src/yuzu/configuration/configure_filesystem.h index a79303760..2147cd405 100644 --- a/src/yuzu/configuration/configure_filesystem.h +++ b/src/yuzu/configuration/configure_filesystem.h @@ -32,7 +32,6 @@ private:          Gamecard,          Dump,          Load, -        Cache,      };      void SetDirectory(DirectoryTarget target, QLineEdit* edit); diff --git a/src/yuzu/configuration/configure_filesystem.ui b/src/yuzu/configuration/configure_filesystem.ui index 84bea0600..62b9abc7a 100644 --- a/src/yuzu/configuration/configure_filesystem.ui +++ b/src/yuzu/configuration/configure_filesystem.ui @@ -198,40 +198,7 @@          <string>Caching</string>         </property>         <layout class="QGridLayout" name="gridLayout_5"> -        <item row="0" column="0"> -         <widget class="QLabel" name="label_10"> -          <property name="text"> -           <string>Cache Directory</string> -          </property> -         </widget> -        </item> -        <item row="0" column="1"> -         <spacer name="horizontalSpacer_3"> -          <property name="orientation"> -           <enum>Qt::Horizontal</enum> -          </property> -          <property name="sizeType"> -           <enum>QSizePolicy::Fixed</enum> -          </property> -          <property name="sizeHint" stdset="0"> -           <size> -            <width>40</width> -            <height>20</height> -           </size> -          </property> -         </spacer> -        </item> -        <item row="0" column="2"> -         <widget class="QLineEdit" name="cache_directory_edit"/> -        </item> -        <item row="0" column="3"> -         <widget class="QToolButton" name="cache_directory_button"> -          <property name="text"> -           <string>...</string> -          </property> -         </widget> -        </item> -        <item row="1" column="0" colspan="4"> +        <item row="0" column="0" colspan="2">           <layout class="QHBoxLayout" name="horizontalLayout_2">            <item>             <widget class="QCheckBox" name="cache_game_list"> diff --git a/src/yuzu/configuration/configure_input_player.cpp b/src/yuzu/configuration/configure_input_player.cpp index c9d19c948..21d0d3449 100644 --- a/src/yuzu/configuration/configure_input_player.cpp +++ b/src/yuzu/configuration/configure_input_player.cpp @@ -467,10 +467,14 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i      UpdateControllerIcon();      UpdateControllerAvailableButtons(); +    UpdateControllerEnabledButtons(); +    UpdateControllerButtonNames();      UpdateMotionButtons();      connect(ui->comboControllerType, qOverload<int>(&QComboBox::currentIndexChanged), [this](int) {          UpdateControllerIcon();          UpdateControllerAvailableButtons(); +        UpdateControllerEnabledButtons(); +        UpdateControllerButtonNames();          UpdateMotionButtons();      }); @@ -558,9 +562,6 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i              &ConfigureInputPlayer::SaveProfile);      LoadConfiguration(); - -    // TODO(wwylele): enable this when we actually emulate it -    ui->buttonHome->setEnabled(false);      ui->controllerFrame->SetPlayerInput(player_index, buttons_param, analogs_param);      ui->controllerFrame->SetConnectedStatus(ui->groupConnectedController->isChecked());  } @@ -924,6 +925,12 @@ void ConfigureInputPlayer::SetConnectableControllers() {                                                       Settings::ControllerType::Handheld);              ui->comboControllerType->addItem(tr("Handheld"));          } + +        if (enable_all || npad_style_set.gamecube == 1) { +            index_controller_type_pairs.emplace_back(ui->comboControllerType->count(), +                                                     Settings::ControllerType::GameCube); +            ui->comboControllerType->addItem(tr("GameCube Controller")); +        }      };      Core::System& system{Core::System::GetInstance()}; @@ -1014,7 +1021,7 @@ void ConfigureInputPlayer::UpdateControllerAvailableButtons() {      // List of all the widgets that will be hidden by any of the following layouts that need      // "unhidden" after the controller type changes -    const std::array<QWidget*, 9> layout_show = { +    const std::array<QWidget*, 11> layout_show = {          ui->buttonShoulderButtonsSLSR,          ui->horizontalSpacerShoulderButtonsWidget,          ui->horizontalSpacerShoulderButtonsWidget2, @@ -1024,6 +1031,8 @@ void ConfigureInputPlayer::UpdateControllerAvailableButtons() {          ui->buttonShoulderButtonsRight,          ui->buttonMiscButtonsPlusHome,          ui->bottomRight, +        ui->buttonMiscButtonsMinusGroup, +        ui->buttonMiscButtonsScreenshotGroup,      };      for (auto* widget : layout_show) { @@ -1056,6 +1065,14 @@ void ConfigureInputPlayer::UpdateControllerAvailableButtons() {              ui->bottomLeft,          };          break; +    case Settings::ControllerType::GameCube: +        layout_hidden = { +            ui->buttonShoulderButtonsSLSR, +            ui->horizontalSpacerShoulderButtonsWidget2, +            ui->buttonMiscButtonsMinusGroup, +            ui->buttonMiscButtonsScreenshotGroup, +        }; +        break;      }      for (auto* widget : layout_hidden) { @@ -1063,6 +1080,52 @@ void ConfigureInputPlayer::UpdateControllerAvailableButtons() {      }  } +void ConfigureInputPlayer::UpdateControllerEnabledButtons() { +    auto layout = GetControllerTypeFromIndex(ui->comboControllerType->currentIndex()); +    if (debug) { +        layout = Settings::ControllerType::ProController; +    } + +    // List of all the widgets that will be disabled by any of the following layouts that need +    // "enabled" after the controller type changes +    const std::array<QWidget*, 4> layout_enable = { +        ui->buttonHome, +        ui->buttonLStickPressedGroup, +        ui->groupRStickPressed, +        ui->buttonShoulderButtonsButtonLGroup, +    }; + +    for (auto* widget : layout_enable) { +        widget->setEnabled(true); +    } + +    std::vector<QWidget*> layout_disable; +    switch (layout) { +    case Settings::ControllerType::ProController: +    case Settings::ControllerType::DualJoyconDetached: +    case Settings::ControllerType::Handheld: +    case Settings::ControllerType::LeftJoycon: +    case Settings::ControllerType::RightJoycon: +        // TODO(wwylele): enable this when we actually emulate it +        layout_disable = { +            ui->buttonHome, +        }; +        break; +    case Settings::ControllerType::GameCube: +        layout_disable = { +            ui->buttonHome, +            ui->buttonLStickPressedGroup, +            ui->groupRStickPressed, +            ui->buttonShoulderButtonsButtonLGroup, +        }; +        break; +    } + +    for (auto* widget : layout_disable) { +        widget->setEnabled(false); +    } +} +  void ConfigureInputPlayer::UpdateMotionButtons() {      if (debug) {          // Motion isn't used with the debug controller, hide both groupboxes. @@ -1085,6 +1148,11 @@ void ConfigureInputPlayer::UpdateMotionButtons() {          ui->buttonMotionLeftGroup->hide();          ui->buttonMotionRightGroup->show();          break; +    case Settings::ControllerType::GameCube: +        // Hide both "Motion 1/2". +        ui->buttonMotionLeftGroup->hide(); +        ui->buttonMotionRightGroup->hide(); +        break;      case Settings::ControllerType::DualJoyconDetached:      default:          // Show both "Motion 1/2". @@ -1094,6 +1162,36 @@ void ConfigureInputPlayer::UpdateMotionButtons() {      }  } +void ConfigureInputPlayer::UpdateControllerButtonNames() { +    auto layout = GetControllerTypeFromIndex(ui->comboControllerType->currentIndex()); +    if (debug) { +        layout = Settings::ControllerType::ProController; +    } + +    switch (layout) { +    case Settings::ControllerType::ProController: +    case Settings::ControllerType::DualJoyconDetached: +    case Settings::ControllerType::Handheld: +    case Settings::ControllerType::LeftJoycon: +    case Settings::ControllerType::RightJoycon: +        ui->buttonMiscButtonsPlusGroup->setTitle(tr("Plus")); +        ui->buttonShoulderButtonsButtonZLGroup->setTitle(tr("ZL")); +        ui->buttonShoulderButtonsZRGroup->setTitle(tr("ZR")); +        ui->buttonShoulderButtonsRGroup->setTitle(tr("R")); +        ui->LStick->setTitle(tr("Left Stick")); +        ui->RStick->setTitle(tr("Right Stick")); +        break; +    case Settings::ControllerType::GameCube: +        ui->buttonMiscButtonsPlusGroup->setTitle(tr("Start / Pause")); +        ui->buttonShoulderButtonsButtonZLGroup->setTitle(tr("L")); +        ui->buttonShoulderButtonsZRGroup->setTitle(tr("R")); +        ui->buttonShoulderButtonsRGroup->setTitle(tr("Z")); +        ui->LStick->setTitle(tr("Control Stick")); +        ui->RStick->setTitle(tr("C-Stick")); +        break; +    } +} +  void ConfigureInputPlayer::UpdateMappingWithDefaults() {      if (ui->comboDevices->currentIndex() == 0) {          return; diff --git a/src/yuzu/configuration/configure_input_player.h b/src/yuzu/configuration/configure_input_player.h index da2b89136..efe953fbc 100644 --- a/src/yuzu/configuration/configure_input_player.h +++ b/src/yuzu/configuration/configure_input_player.h @@ -143,9 +143,15 @@ private:      /// Hides and disables controller settings based on the current controller type.      void UpdateControllerAvailableButtons(); +    /// Disables controller settings based on the current controller type. +    void UpdateControllerEnabledButtons(); +      /// Shows or hides motion groupboxes based on the current controller type.      void UpdateMotionButtons(); +    /// Alters the button names based on the current controller type. +    void UpdateControllerButtonNames(); +      /// Gets the default controller mapping for this device and auto configures the input to match.      void UpdateMappingWithDefaults(); diff --git a/src/yuzu/configuration/configure_input_player_widget.cpp b/src/yuzu/configuration/configure_input_player_widget.cpp index 0e8a964d2..61ba91cef 100644 --- a/src/yuzu/configuration/configure_input_player_widget.cpp +++ b/src/yuzu/configuration/configure_input_player_widget.cpp @@ -227,6 +227,9 @@ void PlayerControlPreview::paintEvent(QPaintEvent* event) {      case Settings::ControllerType::RightJoycon:          DrawRightController(p, center);          break; +    case Settings::ControllerType::GameCube: +        DrawGCController(p, center); +        break;      case Settings::ControllerType::ProController:      default:          DrawProController(p, center); | 
