| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | // Copyright 2016 Citra Emulator Project
 | 
					
						
							|  |  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #pragma once
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include <array>
 | 
					
						
							|  |  |  |  | #include <functional>
 | 
					
						
							|  |  |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2018-11-03 12:55:39 -04:00
										 |  |  |  | #include <optional>
 | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2018-11-27 05:02:12 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-27 15:16:47 -04:00
										 |  |  |  | #include <QWidget>
 | 
					
						
							| 
									
										
										
										
											2018-11-27 05:02:12 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | #include "common/param_package.h"
 | 
					
						
							|  |  |  |  | #include "core/settings.h"
 | 
					
						
							|  |  |  |  | #include "ui_configure_input.h"
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  | class QCheckBox; | 
					
						
							| 
									
										
										
										
											2019-01-17 12:06:38 -05:00
										 |  |  |  | class QKeyEvent; | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  | class QLabel; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | class QPushButton; | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  | class QSlider; | 
					
						
							|  |  |  |  | class QSpinBox; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | class QString; | 
					
						
							|  |  |  |  | class QTimer; | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  | class QWidget; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-27 15:16:47 -04:00
										 |  |  |  | namespace InputCommon { | 
					
						
							|  |  |  |  | class InputSubsystem; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-17 12:06:38 -05:00
										 |  |  |  | namespace InputCommon::Polling { | 
					
						
							|  |  |  |  | class DevicePoller; | 
					
						
							|  |  |  |  | enum class DeviceType; | 
					
						
							|  |  |  |  | } // namespace InputCommon::Polling
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | namespace Ui { | 
					
						
							|  |  |  |  | class ConfigureInputPlayer; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  | class ConfigureInputPlayer : public QWidget { | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  |     Q_OBJECT | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     explicit ConfigureInputPlayer(QWidget* parent, std::size_t player_index, QWidget* bottom_row, | 
					
						
							| 
									
										
										
										
											2020-08-27 15:16:47 -04:00
										 |  |  |  |                                   InputCommon::InputSubsystem* input_subsystem_, | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |                                   bool debug = false); | 
					
						
							| 
									
										
										
										
											2018-11-04 10:18:59 -05:00
										 |  |  |  |     ~ConfigureInputPlayer() override; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     /// Save all button configurations to settings file.
 | 
					
						
							| 
									
										
										
										
											2019-05-26 00:39:23 -04:00
										 |  |  |  |     void ApplyConfiguration(); | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-17 12:00:29 -04:00
										 |  |  |  |     /// Set the connection state checkbox (used to sync state).
 | 
					
						
							|  |  |  |  |     void ConnectPlayer(bool connected); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     /// Update the input devices combobox.
 | 
					
						
							| 
									
										
										
										
											2020-09-17 12:00:29 -04:00
										 |  |  |  |     void UpdateInputDeviceCombobox(); | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// Restore all buttons to their default values.
 | 
					
						
							|  |  |  |  |     void RestoreDefaults(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// Clear all input configuration.
 | 
					
						
							|  |  |  |  |     void ClearAll(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | signals: | 
					
						
							|  |  |  |  |     /// Emitted when this controller is connected by the user.
 | 
					
						
							|  |  |  |  |     void Connected(bool connected); | 
					
						
							|  |  |  |  |     /// Emitted when the Handheld mode is selected (undocked with dual joycons attached).
 | 
					
						
							|  |  |  |  |     void HandheldStateChanged(bool is_handheld); | 
					
						
							|  |  |  |  |     /// Emitted when the input devices combobox is being refreshed.
 | 
					
						
							|  |  |  |  |     void RefreshInputDevices(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | protected: | 
					
						
							|  |  |  |  |     void showEvent(QShowEvent* event) override; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | private: | 
					
						
							| 
									
										
										
										
											2019-06-05 18:39:46 -04:00
										 |  |  |  |     void changeEvent(QEvent* event) override; | 
					
						
							|  |  |  |  |     void RetranslateUI(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-27 05:02:12 -05:00
										 |  |  |  |     /// Load configuration settings.
 | 
					
						
							| 
									
										
										
										
											2019-05-26 00:39:23 -04:00
										 |  |  |  |     void LoadConfiguration(); | 
					
						
							| 
									
										
										
										
											2018-11-27 05:02:12 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// Called when the button was pressed.
 | 
					
						
							| 
									
										
										
										
											2019-05-26 00:39:23 -04:00
										 |  |  |  |     void HandleClick(QPushButton* button, | 
					
						
							| 
									
										
										
										
											2018-11-27 05:02:12 -05:00
										 |  |  |  |                      std::function<void(const Common::ParamPackage&)> new_input_setter, | 
					
						
							|  |  |  |  |                      InputCommon::Polling::DeviceType type); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     /// Finish polling and configure input using the input_setter.
 | 
					
						
							| 
									
										
										
										
											2019-05-26 00:39:23 -04:00
										 |  |  |  |     void SetPollingResult(const Common::ParamPackage& params, bool abort); | 
					
						
							| 
									
										
										
										
											2018-11-27 05:02:12 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-17 12:00:29 -04:00
										 |  |  |  |     /// Checks whether a given input can be accepted.
 | 
					
						
							|  |  |  |  |     bool IsInputAcceptable(const Common::ParamPackage& params) const; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-23 08:04:26 -04:00
										 |  |  |  |     /// Handle mouse button press events.
 | 
					
						
							|  |  |  |  |     void mousePressEvent(QMouseEvent* event) override; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-27 05:02:12 -05:00
										 |  |  |  |     /// Handle key press events.
 | 
					
						
							|  |  |  |  |     void keyPressEvent(QKeyEvent* event) override; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     /// Update UI to reflect current configuration.
 | 
					
						
							|  |  |  |  |     void UpdateUI(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-17 12:00:29 -04:00
										 |  |  |  |     /// Update the available input devices.
 | 
					
						
							|  |  |  |  |     void UpdateInputDevices(); | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// Update the current controller icon.
 | 
					
						
							|  |  |  |  |     void UpdateControllerIcon(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// Hides and disables controller settings based on the current controller type.
 | 
					
						
							|  |  |  |  |     void UpdateControllerAvailableButtons(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-02 12:33:37 -04:00
										 |  |  |  |     /// Shows or hides motion groupboxes based on the current controller type.
 | 
					
						
							|  |  |  |  |     void UpdateMotionButtons(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     /// Gets the default controller mapping for this device and auto configures the input to match.
 | 
					
						
							|  |  |  |  |     void UpdateMappingWithDefaults(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  |     std::unique_ptr<Ui::ConfigureInputPlayer> ui; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-27 05:17:11 -05:00
										 |  |  |  |     std::size_t player_index; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  |     bool debug; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-27 15:16:47 -04:00
										 |  |  |  |     InputCommon::InputSubsystem* input_subsystem; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  |     std::unique_ptr<QTimer> timeout_timer; | 
					
						
							|  |  |  |  |     std::unique_ptr<QTimer> poll_timer; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     static constexpr int PLAYER_COUNT = 8; | 
					
						
							|  |  |  |  |     std::array<QCheckBox*, PLAYER_COUNT> player_connected_checkbox; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  |     /// This will be the the setting function when an input is awaiting configuration.
 | 
					
						
							| 
									
										
										
										
											2018-11-03 12:55:39 -04:00
										 |  |  |  |     std::optional<std::function<void(const Common::ParamPackage&)>> input_setter; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     std::array<Common::ParamPackage, Settings::NativeButton::NumButtons> buttons_param; | 
					
						
							|  |  |  |  |     std::array<Common::ParamPackage, Settings::NativeAnalog::NumAnalogs> analogs_param; | 
					
						
							| 
									
										
										
										
											2020-09-04 21:48:03 -05:00
										 |  |  |  |     std::array<Common::ParamPackage, Settings::NativeMotion::NumMotions> motions_param; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     static constexpr int ANALOG_SUB_BUTTONS_NUM = 4; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// Each button input is represented by a QPushButton.
 | 
					
						
							| 
									
										
										
										
											2020-08-23 10:56:19 -04:00
										 |  |  |  |     std::array<QPushButton*, Settings::NativeButton::NumButtons> button_map; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     /// A group of four QPushButtons represent one analog input. The buttons each represent up,
 | 
					
						
							|  |  |  |  |     /// down, left, right, respectively.
 | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  |     std::array<std::array<QPushButton*, ANALOG_SUB_BUTTONS_NUM>, Settings::NativeAnalog::NumAnalogs> | 
					
						
							|  |  |  |  |         analog_map_buttons; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-20 14:23:25 -04:00
										 |  |  |  |     /// Each motion input is represented by a QPushButton.
 | 
					
						
							|  |  |  |  |     std::array<QPushButton*, Settings::NativeMotion::NumMotions> motion_map; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     std::array<QLabel*, Settings::NativeAnalog::NumAnalogs> analog_map_deadzone_label; | 
					
						
							|  |  |  |  |     std::array<QSlider*, Settings::NativeAnalog::NumAnalogs> analog_map_deadzone_slider; | 
					
						
							|  |  |  |  |     std::array<QGroupBox*, Settings::NativeAnalog::NumAnalogs> analog_map_modifier_groupbox; | 
					
						
							| 
									
										
										
										
											2020-10-20 14:23:25 -04:00
										 |  |  |  |     std::array<QPushButton*, Settings::NativeAnalog::NumAnalogs> analog_map_modifier_button; | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     std::array<QLabel*, Settings::NativeAnalog::NumAnalogs> analog_map_modifier_label; | 
					
						
							|  |  |  |  |     std::array<QSlider*, Settings::NativeAnalog::NumAnalogs> analog_map_modifier_slider; | 
					
						
							|  |  |  |  |     std::array<QGroupBox*, Settings::NativeAnalog::NumAnalogs> analog_map_range_groupbox; | 
					
						
							|  |  |  |  |     std::array<QSpinBox*, Settings::NativeAnalog::NumAnalogs> analog_map_range_spinbox; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     static const std::array<std::string, ANALOG_SUB_BUTTONS_NUM> analog_sub_buttons; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     std::vector<std::unique_ptr<InputCommon::Polling::DevicePoller>> device_pollers; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// A flag to indicate if keyboard keys are okay when configuring an input. If this is false,
 | 
					
						
							|  |  |  |  |     /// keyboard events are ignored.
 | 
					
						
							| 
									
										
										
										
											2020-08-23 08:04:26 -04:00
										 |  |  |  |     bool want_keyboard_mouse = false; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     /// List of physical devices users can map with. If a SDL backed device is selected, then you
 | 
					
						
							| 
									
										
										
										
											2020-09-17 12:00:29 -04:00
										 |  |  |  |     /// can use this device to get a default mapping.
 | 
					
						
							| 
									
										
										
										
											2020-07-22 10:39:53 -04:00
										 |  |  |  |     std::vector<Common::ParamPackage> input_devices; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /// Bottom row is where console wide settings are held, and its "owned" by the parent
 | 
					
						
							|  |  |  |  |     /// ConfigureInput widget. On show, add this widget to the main layout. This will change the
 | 
					
						
							|  |  |  |  |     /// parent of the widget to this widget (but thats fine).
 | 
					
						
							|  |  |  |  |     QWidget* bottom_row; | 
					
						
							| 
									
										
										
										
											2018-11-01 22:11:44 -04:00
										 |  |  |  | }; |