| 
									
										
										
										
											2014-09-08 21:46:02 -07:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-09-03 18:12:58 -07:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  | #include <array>
 | 
					
						
							| 
									
										
										
										
											2016-01-25 01:19:21 -05:00
										 |  |  | #include <tuple>
 | 
					
						
							| 
									
										
										
										
											2015-01-18 15:07:48 -08:00
										 |  |  | #include "core/hle/service/hid/hid.h"
 | 
					
						
							| 
									
										
										
										
											2014-09-03 18:12:58 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  | class EmuWindow; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-03 18:12:58 -07:00
										 |  |  | namespace KeyMap { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-15 13:35:45 +03:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-05-15 19:35:06 +03:00
										 |  |  |  * Represents key mapping targets that are not real 3DS buttons. | 
					
						
							| 
									
										
										
										
											2016-05-15 13:35:45 +03:00
										 |  |  |  * They will be handled by KeyMap and translated to 3DS input. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  | enum class IndirectTarget { | 
					
						
							| 
									
										
										
										
											2016-05-15 13:35:45 +03:00
										 |  |  |     CirclePadUp, | 
					
						
							|  |  |  |     CirclePadDown, | 
					
						
							|  |  |  |     CirclePadLeft, | 
					
						
							|  |  |  |     CirclePadRight, | 
					
						
							|  |  |  |     CirclePadModifier, | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-05-15 19:35:06 +03:00
										 |  |  |  * Represents a key mapping target. It can be a PadState that represents real 3DS buttons, | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  |  * or an IndirectTarget. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct KeyTarget { | 
					
						
							|  |  |  |     bool direct; | 
					
						
							|  |  |  |     union { | 
					
						
							|  |  |  |         u32 direct_target_hex; | 
					
						
							|  |  |  |         IndirectTarget indirect_target; | 
					
						
							|  |  |  |     } target; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     KeyTarget() : direct(true) { | 
					
						
							|  |  |  |         target.direct_target_hex = 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     KeyTarget(Service::HID::PadState pad) : direct(true) { | 
					
						
							|  |  |  |         target.direct_target_hex = pad.hex; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     KeyTarget(IndirectTarget i) : direct(false) { | 
					
						
							|  |  |  |         target.indirect_target = i; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-08 21:46:02 -07:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Represents a key for a specific host device. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct HostDeviceKey { | 
					
						
							|  |  |  |     int key_code; | 
					
						
							|  |  |  |     int device_id; ///< Uniquely identifies a host device
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     bool operator<(const HostDeviceKey& other) const { | 
					
						
							|  |  |  |         return std::tie(key_code, device_id) < std::tie(other.key_code, other.device_id); | 
					
						
							| 
									
										
										
										
											2014-09-03 18:12:58 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     bool operator==(const HostDeviceKey& other) const { | 
					
						
							|  |  |  |         return std::tie(key_code, device_id) == std::tie(other.key_code, other.device_id); | 
					
						
							| 
									
										
										
										
											2014-09-03 18:12:58 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  | extern const std::array<KeyTarget, Settings::NativeInput::NUM_INPUTS> mapping_targets; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-08 21:46:02 -07:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Generates a new device id, which uniquely identifies a host device within KeyMap. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int NewDeviceId(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  |  * Maps a device-specific key to a target (a PadState or an IndirectTarget). | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void SetKeyMapping(HostDeviceKey key, KeyTarget target); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Clears all key mappings belonging to one device. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ClearKeyMapping(int device_id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-05-15 19:35:06 +03:00
										 |  |  |  * Maps a key press action and call the corresponding function in EmuWindow | 
					
						
							| 
									
										
										
										
											2014-09-08 21:46:02 -07:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  | void PressKey(EmuWindow& emu_window, HostDeviceKey key); | 
					
						
							| 
									
										
										
										
											2014-09-03 18:12:58 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-08 21:46:02 -07:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-05-15 19:35:06 +03:00
										 |  |  |  * Maps a key release action and call the corresponding function in EmuWindow | 
					
						
							| 
									
										
										
										
											2014-09-08 21:46:02 -07:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-05-12 13:09:36 +03:00
										 |  |  | void ReleaseKey(EmuWindow& emu_window, HostDeviceKey key); | 
					
						
							| 
									
										
										
										
											2014-09-03 18:12:58 -07:00
										 |  |  | } |