Added support for multiple input device types for KeyMap and connected Qt.

This commit is contained in:
Kevin Hartman 2014-09-08 21:46:02 -07:00
parent 4a94ec934a
commit 02fd19b2f6
12 changed files with 256 additions and 201 deletions

View file

@ -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
View 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);
}

View file

@ -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;

View file

@ -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];
}
}

View file

@ -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);
}