Merge pull request #7760 from german77/inverted_keyboard
yuzu: Add modifiers for keyboard
This commit is contained in:
		| @@ -147,7 +147,7 @@ QString ConfigureInputPlayer::ButtonToText(const Common::ParamPackage& param) { | |||||||
|     // Retrieve the names from Qt |     // Retrieve the names from Qt | ||||||
|     if (param.Get("engine", "") == "keyboard") { |     if (param.Get("engine", "") == "keyboard") { | ||||||
|         const QString button_str = GetKeyName(param.Get("code", 0)); |         const QString button_str = GetKeyName(param.Get("code", 0)); | ||||||
|         return QObject::tr("%1%2").arg(toggle, button_str); |         return QObject::tr("%1%2%3").arg(toggle, inverted, button_str); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (common_button_name == Common::Input::ButtonNames::Invalid) { |     if (common_button_name == Common::Input::ButtonNames::Invalid) { | ||||||
| @@ -341,7 +341,7 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i | |||||||
|                         emulated_controller->SetButtonParam(button_id, {}); |                         emulated_controller->SetButtonParam(button_id, {}); | ||||||
|                         button_map[button_id]->setText(tr("[not set]")); |                         button_map[button_id]->setText(tr("[not set]")); | ||||||
|                     }); |                     }); | ||||||
|                     if (param.Has("button") || param.Has("hat")) { |                     if (param.Has("code") || param.Has("button") || param.Has("hat")) { | ||||||
|                         context_menu.addAction(tr("Toggle button"), [&] { |                         context_menu.addAction(tr("Toggle button"), [&] { | ||||||
|                             const bool toggle_value = !param.Get("toggle", false); |                             const bool toggle_value = !param.Get("toggle", false); | ||||||
|                             param.Set("toggle", toggle_value); |                             param.Set("toggle", toggle_value); | ||||||
| @@ -349,8 +349,8 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i | |||||||
|                             emulated_controller->SetButtonParam(button_id, param); |                             emulated_controller->SetButtonParam(button_id, param); | ||||||
|                         }); |                         }); | ||||||
|                         context_menu.addAction(tr("Invert button"), [&] { |                         context_menu.addAction(tr("Invert button"), [&] { | ||||||
|                             const bool toggle_value = !param.Get("inverted", false); |                             const bool invert_value = !param.Get("inverted", false); | ||||||
|                             param.Set("inverted", toggle_value); |                             param.Set("inverted", invert_value); | ||||||
|                             button_map[button_id]->setText(ButtonToText(param)); |                             button_map[button_id]->setText(ButtonToText(param)); | ||||||
|                             emulated_controller->SetButtonParam(button_id, param); |                             emulated_controller->SetButtonParam(button_id, param); | ||||||
|                         }); |                         }); | ||||||
| @@ -510,7 +510,8 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i | |||||||
|  |  | ||||||
|         analog_map_modifier_button[analog_id]->setContextMenuPolicy(Qt::CustomContextMenu); |         analog_map_modifier_button[analog_id]->setContextMenuPolicy(Qt::CustomContextMenu); | ||||||
|  |  | ||||||
|         connect(analog_map_modifier_button[analog_id], &QPushButton::customContextMenuRequested, |         connect( | ||||||
|  |             analog_map_modifier_button[analog_id], &QPushButton::customContextMenuRequested, | ||||||
|             [=, this](const QPoint& menu_location) { |             [=, this](const QPoint& menu_location) { | ||||||
|                 QMenu context_menu; |                 QMenu context_menu; | ||||||
|                 Common::ParamPackage param = emulated_controller->GetStickParam(analog_id); |                 Common::ParamPackage param = emulated_controller->GetStickParam(analog_id); | ||||||
| @@ -525,8 +526,16 @@ ConfigureInputPlayer::ConfigureInputPlayer(QWidget* parent, std::size_t player_i | |||||||
|                     const bool toggle_value = !modifier_param.Get("toggle", false); |                     const bool toggle_value = !modifier_param.Get("toggle", false); | ||||||
|                     modifier_param.Set("toggle", toggle_value); |                     modifier_param.Set("toggle", toggle_value); | ||||||
|                     param.Set("modifier", modifier_param.Serialize()); |                     param.Set("modifier", modifier_param.Serialize()); | ||||||
|                         analog_map_modifier_button[analog_id]->setText( |                     analog_map_modifier_button[analog_id]->setText(ButtonToText(modifier_param)); | ||||||
|                             ButtonToText(modifier_param)); |                     emulated_controller->SetStickParam(analog_id, param); | ||||||
|  |                 }); | ||||||
|  |                 context_menu.addAction(tr("Invert button"), [&] { | ||||||
|  |                     Common::ParamPackage modifier_param = | ||||||
|  |                         Common::ParamPackage{param.Get("modifier", "")}; | ||||||
|  |                     const bool invert_value = !modifier_param.Get("inverted", false); | ||||||
|  |                     modifier_param.Set("inverted", invert_value); | ||||||
|  |                     param.Set("modifier", modifier_param.Serialize()); | ||||||
|  |                     analog_map_modifier_button[analog_id]->setText(ButtonToText(modifier_param)); | ||||||
|                     emulated_controller->SetStickParam(analog_id, param); |                     emulated_controller->SetStickParam(analog_id, param); | ||||||
|                 }); |                 }); | ||||||
|                 context_menu.exec( |                 context_menu.exec( | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 bunnei
					bunnei