mirror of
				https://github.com/PabloMK7/citra.git
				synced 2025-10-31 05:40:04 +00:00 
			
		
		
		
	Added support for multiple input device types for KeyMap and connected Qt.
This commit is contained in:
		
							parent
							
								
									4a94ec934a
								
							
						
					
					
						commit
						02fd19b2f6
					
				
					 12 changed files with 256 additions and 201 deletions
				
			
		|  | @ -4,6 +4,7 @@ configure_file("${CMAKE_CURRENT_SOURCE_DIR}/scm_rev.cpp.in" "${CMAKE_CURRENT_SOU | |||
| set(SRCS | ||||
|             break_points.cpp | ||||
|             console_listener.cpp | ||||
|             emu_window.cpp | ||||
|             extended_trace.cpp | ||||
|             file_search.cpp | ||||
|             file_util.cpp | ||||
|  |  | |||
							
								
								
									
										17
									
								
								src/common/emu_window.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/common/emu_window.cpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,17 @@ | |||
| // Copyright 2014 Citra Emulator Project
 | ||||
| // Licensed under GPLv2
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #include "emu_window.h" | ||||
| 
 | ||||
| void EmuWindow::KeyPressed(KeyMap::HostDeviceKey key) { | ||||
|     HID_User::PadState mapped_key = KeyMap::GetPadKey(key); | ||||
| 
 | ||||
|     HID_User::PadButtonPress(mapped_key); | ||||
| } | ||||
| 
 | ||||
| void EmuWindow::KeyReleased(KeyMap::HostDeviceKey key) { | ||||
|     HID_User::PadState mapped_key = KeyMap::GetPadKey(key); | ||||
| 
 | ||||
|     HID_User::PadButtonRelease(mapped_key); | ||||
| } | ||||
|  | @ -8,7 +8,6 @@ | |||
| #include "common/scm_rev.h" | ||||
| 
 | ||||
| #include "common/key_map.h" | ||||
| #include "core/hle/service/hid.h" | ||||
| 
 | ||||
| // Abstraction class used to provide an interface between emulation code and the frontend (e.g. SDL, 
 | ||||
| //  QGLWidget, GLFW, etc...)
 | ||||
|  | @ -35,21 +34,11 @@ public: | |||
|     /// Releases (dunno if this is the "right" word) the GLFW context from the caller thread
 | ||||
|     virtual void DoneCurrent() = 0; | ||||
| 
 | ||||
|     static void KeyPressed(KeyMap::CitraKey key) { | ||||
|         HID_User::PADState mapped_key = KeyMap::Get3DSKey(key); | ||||
|     /// Signals a key press action to the HID module
 | ||||
|     static void KeyPressed(KeyMap::HostDeviceKey key); | ||||
| 
 | ||||
|         if (mapped_key.hex != HID_User::PAD_NONE.hex) { | ||||
|             HID_User::PADButtonPress(mapped_key); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     static void KeyReleased(KeyMap::CitraKey key) { | ||||
|         HID_User::PADState mapped_key = KeyMap::Get3DSKey(key); | ||||
| 
 | ||||
|         if (mapped_key.hex != HID_User::PAD_NONE.hex) { | ||||
|             HID_User::PADButtonRelease(mapped_key); | ||||
|         } | ||||
|     } | ||||
|     /// Signals a key release action to the HID module
 | ||||
|     static void KeyReleased(KeyMap::HostDeviceKey key); | ||||
| 
 | ||||
|     Config GetConfig() const {  | ||||
|         return m_config; | ||||
|  |  | |||
|  | @ -1,21 +1,25 @@ | |||
| // Copyright 2013 Dolphin Emulator Project
 | ||||
| // Copyright 2014 Citra Emulator Project
 | ||||
| // Licensed under GPLv2
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #include "key_map.h" | ||||
| #include <map> | ||||
| 
 | ||||
| 
 | ||||
| namespace KeyMap { | ||||
| 
 | ||||
| std::map<CitraKey, HID_User::PADState> g_key_map; | ||||
| static std::map<HostDeviceKey, HID_User::PadState> key_map; | ||||
| static int next_device_id = 0; | ||||
| 
 | ||||
| void SetKeyMapping(CitraKey key, HID_User::PADState padState) { | ||||
|     g_key_map[key].hex = padState.hex; | ||||
| int NewDeviceId() { | ||||
|     return next_device_id++; | ||||
| } | ||||
| 
 | ||||
| HID_User::PADState Get3DSKey(CitraKey key) { | ||||
|     return g_key_map[key]; | ||||
| void SetKeyMapping(HostDeviceKey key, HID_User::PadState padState) { | ||||
|     key_map[key].hex = padState.hex; | ||||
| } | ||||
| 
 | ||||
| HID_User::PadState GetPadKey(HostDeviceKey key) { | ||||
|     return key_map[key]; | ||||
| } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -1,4 +1,4 @@ | |||
| // Copyright 2013 Dolphin Emulator Project
 | ||||
| // Copyright 2014 Citra Emulator Project
 | ||||
| // Licensed under GPLv2
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
|  | @ -8,28 +8,38 @@ | |||
| 
 | ||||
| namespace KeyMap { | ||||
| 
 | ||||
| class CitraKey { | ||||
| public: | ||||
|     CitraKey() : keyCode(0) {} | ||||
|     CitraKey(int code) : keyCode(code) {} | ||||
| /**
 | ||||
|  * Represents a key for a specific host device. | ||||
|  */ | ||||
| struct HostDeviceKey { | ||||
|     int key_code; | ||||
|     int device_id; ///< Uniquely identifies a host device
 | ||||
| 
 | ||||
|     int keyCode; | ||||
| 
 | ||||
|     bool operator < (const CitraKey &other) const { | ||||
|         return keyCode < other.keyCode; | ||||
|     bool operator < (const HostDeviceKey &other) const { | ||||
|         if (device_id == other.device_id) { | ||||
|             return key_code < other.key_code; | ||||
|         } | ||||
|         return device_id < other.device_id; | ||||
|     } | ||||
| 
 | ||||
|     bool operator == (const CitraKey &other) const { | ||||
|         return keyCode == other.keyCode; | ||||
|     bool operator == (const HostDeviceKey &other) const { | ||||
|         return device_id == other.device_id && key_code == other.key_code; | ||||
|     } | ||||
| }; | ||||
| 
 | ||||
| struct DefaultKeyMapping { | ||||
|     KeyMap::CitraKey key; | ||||
|     HID_User::PADState state; | ||||
| }; | ||||
| /**
 | ||||
|  * Generates a new device id, which uniquely identifies a host device within KeyMap. | ||||
|  */ | ||||
| int NewDeviceId(); | ||||
| 
 | ||||
| void SetKeyMapping(CitraKey key, HID_User::PADState padState); | ||||
| HID_User::PADState Get3DSKey(CitraKey key); | ||||
| /**
 | ||||
|  * Maps a device-specific key to a PadState. | ||||
|  */ | ||||
| void SetKeyMapping(HostDeviceKey key, HID_User::PadState padState); | ||||
| 
 | ||||
| /**
 | ||||
|  * Gets the PadState that's mapped to the provided device-specific key. | ||||
|  */ | ||||
| HID_User::PadState GetPadKey(HostDeviceKey key); | ||||
| 
 | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue