Refactor translate mode

This commit is contained in:
Asura
2022-08-11 23:59:18 -07:00
parent 577cce549f
commit b916ef3659
3 changed files with 7 additions and 16 deletions

View File

@@ -822,16 +822,10 @@ fn legacy_keyboard_mode(evt: &KeyEvent) {
}
fn translate_keyboard_mode(evt: &KeyEvent) {
// Caps affects the keycode map of the peer system(Linux).
let mut en = ENIGO.lock().unwrap();
if en.get_key_state(Key::CapsLock){
rdev_key_click(RdevKey::CapsLock);
}
let chr = char::from_u32(evt.chr()).unwrap_or_default();
if evt.down {
KBD_CONTEXT.lock().unwrap().unicode_char_down(chr).expect("unicode_char_down error");
} else {
KBD_CONTEXT.lock().unwrap().unicode_char_up(chr).expect("unicode_char_up error");
// down(true)->press && press(false)-> release
if evt.down && !evt.press {
KBD_CONTEXT.lock().unwrap().unicode_char(chr).expect("unicode_char_down error");
}
}

View File

@@ -1108,11 +1108,8 @@ impl Handler {
let mut key_event = KeyEvent::new();
key_event.set_chr(chr as _);
key_event.down = true;
self.send_key_event(key_event, KeyboardMode::Translate);
let mut key_event = KeyEvent::new();
key_event.set_chr(chr as _);
key_event.down = false;
key_event.press = false;
self.send_key_event(key_event, KeyboardMode::Translate);
}
} else {