[HID] Add keyboard_keyup cvar (default true) since dash needs keyups to work properly

Made this a cvar since SR1 will double-press when it sees both keydown & keyup, strange.
This commit is contained in:
emoose 2020-01-15 00:02:01 +00:00 committed by illusion
parent 0793e03068
commit 8d51293d29
1 changed files with 18 additions and 9 deletions

View File

@ -21,6 +21,13 @@ DEFINE_bool(keyboard_passthru, false,
"Xenia keybinds, eg. H to show FPS, will still be in effect!)", "Xenia keybinds, eg. H to show FPS, will still be in effect!)",
"HID"); "HID");
DEFINE_bool(
keyboard_keyup, true,
"When using passthru, sends keyup events when keys are released. Some "
"games like SR1 don't like "
"seeing these, but dash won't work properly without them",
"HID");
namespace xe { namespace xe {
namespace hid { namespace hid {
namespace winkey { namespace winkey {
@ -394,22 +401,24 @@ X_RESULT WinKeyInputDriver::GetKeystroke(uint32_t user_index, uint32_t flags,
result = X_ERROR_SUCCESS; result = X_ERROR_SUCCESS;
} }
} else { } else {
// Handle keydown/keyup for VK_SHIFT // Handle keydown & keyup:
if (virtual_key == VK_SHIFT) { if (cvars::keyboard_keyup || virtual_key == VK_SHIFT) {
if (evt.transition == false) { if (evt.transition == false) {
keystroke_flags |= 0x0002; keystroke_flags |= 0x0002;
} else if (evt.transition == true) { } else if (evt.transition == true) {
keystroke_flags |= 0x0001; keystroke_flags |= 0x0001;
} }
} } else {
if (!cvars::keyboard_keyup) {
// Only handle keydown for other keys, since some stupid games will count // Only handle keydown, since some stupid games will count keyup as
// keyup as another keypress (seen in SR1..) // another keypress (seen in SR1..)
if (virtual_key != 0 && virtual_key != 0x10) { if (virtual_key != 0 && virtual_key != VK_SHIFT) {
if (evt.transition) { if (evt.transition) {
keystroke_flags |= 0x0001; keystroke_flags |= 0x0001;
} }
} }
}
}
if (keystroke_flags != 0) { if (keystroke_flags != 0) {
result = X_ERROR_SUCCESS; result = X_ERROR_SUCCESS;