[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:
parent
0793e03068
commit
8d51293d29
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue