mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu-mainline.git
				synced 2025-03-21 01:53:15 +00:00 
			
		
		
		
	applets/controller: Use a pair of emulated controller index to controller type
This commit is contained in:
		
							parent
							
								
									102630f2b2
								
							
						
					
					
						commit
						8758378dc4
					
				@ -72,40 +72,6 @@ bool IsControllerCompatible(Settings::ControllerType controller_type,
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Maps the controller type combobox index to Controller Type enum
 | 
			
		||||
constexpr Settings::ControllerType GetControllerTypeFromIndex(int index) {
 | 
			
		||||
    switch (index) {
 | 
			
		||||
    case 0:
 | 
			
		||||
    default:
 | 
			
		||||
        return Settings::ControllerType::ProController;
 | 
			
		||||
    case 1:
 | 
			
		||||
        return Settings::ControllerType::DualJoyconDetached;
 | 
			
		||||
    case 2:
 | 
			
		||||
        return Settings::ControllerType::LeftJoycon;
 | 
			
		||||
    case 3:
 | 
			
		||||
        return Settings::ControllerType::RightJoycon;
 | 
			
		||||
    case 4:
 | 
			
		||||
        return Settings::ControllerType::Handheld;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Maps the Controller Type enum to controller type combobox index
 | 
			
		||||
constexpr int GetIndexFromControllerType(Settings::ControllerType type) {
 | 
			
		||||
    switch (type) {
 | 
			
		||||
    case Settings::ControllerType::ProController:
 | 
			
		||||
    default:
 | 
			
		||||
        return 0;
 | 
			
		||||
    case Settings::ControllerType::DualJoyconDetached:
 | 
			
		||||
        return 1;
 | 
			
		||||
    case Settings::ControllerType::LeftJoycon:
 | 
			
		||||
        return 2;
 | 
			
		||||
    case Settings::ControllerType::RightJoycon:
 | 
			
		||||
        return 3;
 | 
			
		||||
    case Settings::ControllerType::Handheld:
 | 
			
		||||
        return 4;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
} // namespace
 | 
			
		||||
 | 
			
		||||
QtControllerSelectorDialog::QtControllerSelectorDialog(
 | 
			
		||||
@ -184,6 +150,11 @@ QtControllerSelectorDialog::QtControllerSelectorDialog(
 | 
			
		||||
    // This avoids unintentionally changing the states of elements while loading them in.
 | 
			
		||||
    SetSupportedControllers();
 | 
			
		||||
    DisableUnsupportedPlayers();
 | 
			
		||||
 | 
			
		||||
    for (std::size_t player_index = 0; player_index < NUM_PLAYERS; ++player_index) {
 | 
			
		||||
        SetEmulatedControllers(player_index);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    LoadConfiguration();
 | 
			
		||||
 | 
			
		||||
    for (std::size_t i = 0; i < NUM_PLAYERS; ++i) {
 | 
			
		||||
@ -223,8 +194,8 @@ QtControllerSelectorDialog::QtControllerSelectorDialog(
 | 
			
		||||
 | 
			
		||||
        if (i == 0) {
 | 
			
		||||
            connect(emulated_controllers[i], qOverload<int>(&QComboBox::currentIndexChanged),
 | 
			
		||||
                    [this](int index) {
 | 
			
		||||
                        UpdateDockedState(GetControllerTypeFromIndex(index) ==
 | 
			
		||||
                    [this, i](int index) {
 | 
			
		||||
                        UpdateDockedState(GetControllerTypeFromIndex(index, i) ==
 | 
			
		||||
                                          Settings::ControllerType::Handheld);
 | 
			
		||||
                    });
 | 
			
		||||
        }
 | 
			
		||||
@ -281,8 +252,8 @@ void QtControllerSelectorDialog::LoadConfiguration() {
 | 
			
		||||
            (index == 0 && Settings::values.players.GetValue()[HANDHELD_INDEX].connected);
 | 
			
		||||
        player_groupboxes[index]->setChecked(connected);
 | 
			
		||||
        connected_controller_checkboxes[index]->setChecked(connected);
 | 
			
		||||
        emulated_controllers[index]->setCurrentIndex(
 | 
			
		||||
            GetIndexFromControllerType(Settings::values.players.GetValue()[index].controller_type));
 | 
			
		||||
        emulated_controllers[index]->setCurrentIndex(GetIndexFromControllerType(
 | 
			
		||||
            Settings::values.players.GetValue()[index].controller_type, index));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    UpdateDockedState(Settings::values.players.GetValue()[HANDHELD_INDEX].connected);
 | 
			
		||||
@ -338,7 +309,7 @@ bool QtControllerSelectorDialog::CheckIfParametersMet() {
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            const auto compatible = IsControllerCompatible(
 | 
			
		||||
                GetControllerTypeFromIndex(emulated_controllers[index]->currentIndex()),
 | 
			
		||||
                GetControllerTypeFromIndex(emulated_controllers[index]->currentIndex(), index),
 | 
			
		||||
                parameters);
 | 
			
		||||
 | 
			
		||||
            // If any controller is found to be incompatible, return false early.
 | 
			
		||||
@ -422,6 +393,63 @@ void QtControllerSelectorDialog::SetSupportedControllers() {
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void QtControllerSelectorDialog::SetEmulatedControllers(std::size_t player_index) {
 | 
			
		||||
    auto& pairs = index_controller_type_pairs[player_index];
 | 
			
		||||
 | 
			
		||||
    pairs.clear();
 | 
			
		||||
    emulated_controllers[player_index]->clear();
 | 
			
		||||
 | 
			
		||||
    pairs.emplace_back(emulated_controllers[player_index]->count(),
 | 
			
		||||
                       Settings::ControllerType::ProController);
 | 
			
		||||
    emulated_controllers[player_index]->addItem(tr("Pro Controller"));
 | 
			
		||||
 | 
			
		||||
    pairs.emplace_back(emulated_controllers[player_index]->count(),
 | 
			
		||||
                       Settings::ControllerType::DualJoyconDetached);
 | 
			
		||||
    emulated_controllers[player_index]->addItem(tr("Dual Joycons"));
 | 
			
		||||
 | 
			
		||||
    pairs.emplace_back(emulated_controllers[player_index]->count(),
 | 
			
		||||
                       Settings::ControllerType::LeftJoycon);
 | 
			
		||||
    emulated_controllers[player_index]->addItem(tr("Left Joycon"));
 | 
			
		||||
 | 
			
		||||
    pairs.emplace_back(emulated_controllers[player_index]->count(),
 | 
			
		||||
                       Settings::ControllerType::RightJoycon);
 | 
			
		||||
    emulated_controllers[player_index]->addItem(tr("Right Joycon"));
 | 
			
		||||
 | 
			
		||||
    if (player_index == 0) {
 | 
			
		||||
        pairs.emplace_back(emulated_controllers[player_index]->count(),
 | 
			
		||||
                           Settings::ControllerType::Handheld);
 | 
			
		||||
        emulated_controllers[player_index]->addItem(tr("Handheld"));
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
Settings::ControllerType QtControllerSelectorDialog::GetControllerTypeFromIndex(
 | 
			
		||||
    int index, std::size_t player_index) const {
 | 
			
		||||
    const auto& pairs = index_controller_type_pairs[player_index];
 | 
			
		||||
 | 
			
		||||
    const auto it = std::find_if(pairs.begin(), pairs.end(),
 | 
			
		||||
                                 [index](const auto& pair) { return pair.first == index; });
 | 
			
		||||
 | 
			
		||||
    if (it == pairs.end()) {
 | 
			
		||||
        return Settings::ControllerType::ProController;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return it->second;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int QtControllerSelectorDialog::GetIndexFromControllerType(Settings::ControllerType type,
 | 
			
		||||
                                                           std::size_t player_index) const {
 | 
			
		||||
    const auto& pairs = index_controller_type_pairs[player_index];
 | 
			
		||||
 | 
			
		||||
    const auto it = std::find_if(pairs.begin(), pairs.end(),
 | 
			
		||||
                                 [type](const auto& pair) { return pair.second == type; });
 | 
			
		||||
 | 
			
		||||
    if (it == pairs.end()) {
 | 
			
		||||
        return 0;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return it->first;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void QtControllerSelectorDialog::UpdateControllerIcon(std::size_t player_index) {
 | 
			
		||||
    if (!player_groupboxes[player_index]->isChecked()) {
 | 
			
		||||
        connected_controller_icons[player_index]->setStyleSheet(QString{});
 | 
			
		||||
@ -430,7 +458,8 @@ void QtControllerSelectorDialog::UpdateControllerIcon(std::size_t player_index)
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    const QString stylesheet = [this, player_index] {
 | 
			
		||||
        switch (GetControllerTypeFromIndex(emulated_controllers[player_index]->currentIndex())) {
 | 
			
		||||
        switch (GetControllerTypeFromIndex(emulated_controllers[player_index]->currentIndex(),
 | 
			
		||||
                                           player_index)) {
 | 
			
		||||
        case Settings::ControllerType::ProController:
 | 
			
		||||
            return QStringLiteral("image: url(:/controller/applet_pro_controller%0); ");
 | 
			
		||||
        case Settings::ControllerType::DualJoyconDetached:
 | 
			
		||||
@ -446,6 +475,12 @@ void QtControllerSelectorDialog::UpdateControllerIcon(std::size_t player_index)
 | 
			
		||||
        }
 | 
			
		||||
    }();
 | 
			
		||||
 | 
			
		||||
    if (stylesheet.isEmpty()) {
 | 
			
		||||
        connected_controller_icons[player_index]->setStyleSheet(QString{});
 | 
			
		||||
        player_labels[player_index]->show();
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    const QString theme = [] {
 | 
			
		||||
        if (QIcon::themeName().contains(QStringLiteral("dark"))) {
 | 
			
		||||
            return QStringLiteral("_dark");
 | 
			
		||||
@ -463,8 +498,8 @@ void QtControllerSelectorDialog::UpdateControllerIcon(std::size_t player_index)
 | 
			
		||||
void QtControllerSelectorDialog::UpdateControllerState(std::size_t player_index) {
 | 
			
		||||
    auto& player = Settings::values.players.GetValue()[player_index];
 | 
			
		||||
 | 
			
		||||
    const auto controller_type =
 | 
			
		||||
        GetControllerTypeFromIndex(emulated_controllers[player_index]->currentIndex());
 | 
			
		||||
    const auto controller_type = GetControllerTypeFromIndex(
 | 
			
		||||
        emulated_controllers[player_index]->currentIndex(), player_index);
 | 
			
		||||
    const auto player_connected = player_groupboxes[player_index]->isChecked() &&
 | 
			
		||||
                                  controller_type != Settings::ControllerType::Handheld;
 | 
			
		||||
 | 
			
		||||
@ -507,8 +542,8 @@ void QtControllerSelectorDialog::UpdateControllerState(std::size_t player_index)
 | 
			
		||||
 | 
			
		||||
void QtControllerSelectorDialog::UpdateLEDPattern(std::size_t player_index) {
 | 
			
		||||
    if (!player_groupboxes[player_index]->isChecked() ||
 | 
			
		||||
        GetControllerTypeFromIndex(emulated_controllers[player_index]->currentIndex()) ==
 | 
			
		||||
            Settings::ControllerType::Handheld) {
 | 
			
		||||
        GetControllerTypeFromIndex(emulated_controllers[player_index]->currentIndex(),
 | 
			
		||||
                                   player_index) == Settings::ControllerType::Handheld) {
 | 
			
		||||
        led_patterns_boxes[player_index][0]->setChecked(false);
 | 
			
		||||
        led_patterns_boxes[player_index][1]->setChecked(false);
 | 
			
		||||
        led_patterns_boxes[player_index][2]->setChecked(false);
 | 
			
		||||
 | 
			
		||||
@ -22,6 +22,10 @@ namespace InputCommon {
 | 
			
		||||
class InputSubsystem;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
namespace Settings {
 | 
			
		||||
enum class ControllerType;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
namespace Ui {
 | 
			
		||||
class QtControllerSelectorDialog;
 | 
			
		||||
}
 | 
			
		||||
@ -57,6 +61,15 @@ private:
 | 
			
		||||
    // Sets the controller icons for "Supported Controller Types".
 | 
			
		||||
    void SetSupportedControllers();
 | 
			
		||||
 | 
			
		||||
    // Sets the emulated controllers per player.
 | 
			
		||||
    void SetEmulatedControllers(std::size_t player_index);
 | 
			
		||||
 | 
			
		||||
    // Gets the Controller Type for a given controller combobox index per player.
 | 
			
		||||
    Settings::ControllerType GetControllerTypeFromIndex(int index, std::size_t player_index) const;
 | 
			
		||||
 | 
			
		||||
    // Gets the controller combobox index for a given Controller Type per player.
 | 
			
		||||
    int GetIndexFromControllerType(Settings::ControllerType type, std::size_t player_index) const;
 | 
			
		||||
 | 
			
		||||
    // Updates the controller icons per player.
 | 
			
		||||
    void UpdateControllerIcon(std::size_t player_index);
 | 
			
		||||
 | 
			
		||||
@ -114,6 +127,10 @@ private:
 | 
			
		||||
    // Comboboxes with a list of emulated controllers per player.
 | 
			
		||||
    std::array<QComboBox*, NUM_PLAYERS> emulated_controllers;
 | 
			
		||||
 | 
			
		||||
    /// Pairs of emulated controller index and Controller Type enum per player.
 | 
			
		||||
    std::array<std::vector<std::pair<int, Settings::ControllerType>>, NUM_PLAYERS>
 | 
			
		||||
        index_controller_type_pairs;
 | 
			
		||||
 | 
			
		||||
    // Labels representing the number of connected controllers
 | 
			
		||||
    // above the "Connected Controllers" checkboxes.
 | 
			
		||||
    std::array<QLabel*, NUM_PLAYERS> connected_controller_labels;
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user