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 03:09:36 -07:00
|
|
|
#include <array>
|
2016-01-24 22:19:21 -08: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 03:09:36 -07:00
|
|
|
class EmuWindow;
|
|
|
|
|
2014-09-03 18:12:58 -07:00
|
|
|
namespace KeyMap {
|
|
|
|
|
2016-05-15 03:35:45 -07:00
|
|
|
/**
|
|
|
|
* Represents a key mapping target that are not 3DS real buttons.
|
|
|
|
* They will be handled by KeyMap and translated to 3DS input.
|
|
|
|
*/
|
2016-05-12 03:09:36 -07:00
|
|
|
enum class IndirectTarget {
|
2016-05-15 03:35:45 -07:00
|
|
|
CirclePadUp,
|
|
|
|
CirclePadDown,
|
|
|
|
CirclePadLeft,
|
|
|
|
CirclePadRight,
|
|
|
|
CirclePadModifier,
|
2016-05-12 03:09:36 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents a key mapping target. It can be a PadState that represents 3DS real buttons,
|
|
|
|
* 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-01-24 22:19:21 -08: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-01-24 22:19:21 -08: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 03:09:36 -07: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 03:09:36 -07: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);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maps a key press actions and call the corresponding function in EmuWindow
|
2014-09-08 21:46:02 -07:00
|
|
|
*/
|
2016-05-12 03:09:36 -07: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-12 03:09:36 -07:00
|
|
|
* Maps a key release actions and call the corresponding function in EmuWindow
|
2014-09-08 21:46:02 -07:00
|
|
|
*/
|
2016-05-12 03:09:36 -07:00
|
|
|
void ReleaseKey(EmuWindow& emu_window, HostDeviceKey key);
|
2014-09-03 18:12:58 -07:00
|
|
|
|
|
|
|
}
|