diff options
| author | Jules Aguillon | 2022-02-22 19:32:16 +0100 |
|---|---|---|
| committer | Jules Aguillon | 2022-02-22 19:32:16 +0100 |
| commit | 14dabb6f519275a800f1fbf13620f420555b0d0c (patch) | |
| tree | d757a0deeaba8639e75635b05dcb038159436b43 /srcs/juloo.keyboard2/KeyEventHandler.java | |
| parent | 84bce23fec5a551839d621f9ac20ba2127f01e29 (diff) | |
| download | unexpected-keyboard-14dabb6f519275a800f1fbf13620f420555b0d0c.tar.gz unexpected-keyboard-14dabb6f519275a800f1fbf13620f420555b0d0c.zip | |
Send key events for the modifiers
Before sending a key event while modifiers are active, send events for
the modifier keys.
Some applications don't look at the "metaState" flags but instead keep
track of the up and down events for the modifiers.
For example, the basic text views that are in every applications
correctly handle the "metaState" flags except for one binding:
Selecting text with the arrows while pressing shift.
Diffstat (limited to 'srcs/juloo.keyboard2/KeyEventHandler.java')
| -rw-r--r-- | srcs/juloo.keyboard2/KeyEventHandler.java | 51 |
1 files changed, 36 insertions, 15 deletions
diff --git a/srcs/juloo.keyboard2/KeyEventHandler.java b/srcs/juloo.keyboard2/KeyEventHandler.java index dad6642..86cfc8c 100644 --- a/srcs/juloo.keyboard2/KeyEventHandler.java +++ b/srcs/juloo.keyboard2/KeyEventHandler.java @@ -25,11 +25,11 @@ class KeyEventHandler implements Config.IKeyEventHandler case KeyValue.EVENT_ACTION: _recv.performAction(); return; default: if ((flags & (KeyValue.FLAG_CTRL | KeyValue.FLAG_ALT | KeyValue.FLAG_META)) != 0) - handleMetaKeyUp(key, flags); + handleKeyUpWithModifier(key, flags); else if (key.char_ != KeyValue.CHAR_NONE) _recv.commitChar(key.char_); else if (key.eventCode != KeyValue.EVENT_NONE) - handleMetaKeyUp(key, flags); + handleKeyUpWithModifier(key, flags); else _recv.commitText(key.symbol); } @@ -45,22 +45,43 @@ class KeyEventHandler implements Config.IKeyEventHandler // getCurrentInputConnection().deleteSurroundingText(before, after); // } - private void handleMetaKeyUp(KeyValue key, int flags) + private int sendMetaKey(int eventCode, int metaFlags, int metaState, boolean down) { - int meta = 0; - if (key.eventCode == KeyValue.EVENT_NONE) - return ; - if ((flags & KeyValue.FLAG_CTRL) != 0) - meta |= KeyEvent.META_CTRL_LEFT_ON | KeyEvent.META_CTRL_ON; - if ((flags & KeyValue.FLAG_ALT) != 0) - meta |= KeyEvent.META_ALT_LEFT_ON | KeyEvent.META_ALT_ON; - if ((flags & KeyValue.FLAG_SHIFT) != 0) - meta |= KeyEvent.META_SHIFT_LEFT_ON | KeyEvent.META_SHIFT_ON; + int action; + int updatedMetaState; + if (down) { action = KeyEvent.ACTION_DOWN; updatedMetaState = metaState | metaFlags; } + else { action = KeyEvent.ACTION_UP; updatedMetaState = metaState & ~metaFlags; } + _recv.sendKeyEvent(action, eventCode, metaState); + return updatedMetaState; + } + + /* Send key events corresponding to pressed modifier keys. */ + private int sendMetaKeys(int flags, int metaState, boolean down) + { + if ((flags & KeyValue.FLAG_CTRL) != 0) + metaState = sendMetaKey(KeyEvent.KEYCODE_CTRL_LEFT, KeyEvent.META_CTRL_LEFT_ON | KeyEvent.META_CTRL_ON, metaState, down); + if ((flags & KeyValue.FLAG_ALT) != 0) + metaState = sendMetaKey(KeyEvent.KEYCODE_ALT_LEFT, KeyEvent.META_ALT_LEFT_ON | KeyEvent.META_ALT_ON, metaState, down); + if ((flags & KeyValue.FLAG_SHIFT) != 0) + metaState = sendMetaKey(KeyEvent.KEYCODE_SHIFT_LEFT, KeyEvent.META_SHIFT_LEFT_ON | KeyEvent.META_SHIFT_ON, metaState, down); if ((flags & KeyValue.FLAG_META) != 0) - meta |= KeyEvent.META_META_LEFT_ON | KeyEvent.META_META_ON; - _recv.sendKeyEvent(key.eventCode, meta); + metaState = sendMetaKey(KeyEvent.KEYCODE_META_LEFT, KeyEvent.META_META_LEFT_ON | KeyEvent.META_META_ON, metaState, down); + return metaState; } + /* + * Don't set KeyEvent.FLAG_SOFT_KEYBOARD. + */ + private void handleKeyUpWithModifier(KeyValue key, int flags) + { + if (key.eventCode == KeyValue.EVENT_NONE) + return ; + int metaState = sendMetaKeys(flags, 0, true); + _recv.sendKeyEvent(KeyEvent.ACTION_DOWN, key.eventCode, metaState); + _recv.sendKeyEvent(KeyEvent.ACTION_UP, key.eventCode, metaState); + sendMetaKeys(flags, metaState, false); + } + public static interface IReceiver { public void switchToNextInputMethod(); @@ -72,7 +93,7 @@ class KeyEventHandler implements Config.IKeyEventHandler /** 'res_id' is '-1' for the currently selected layout. */ public void setLayout(int res_id); - public void sendKeyEvent(int eventCode, int meta); + public void sendKeyEvent(int eventAction, int eventCode, int meta); public void commitText(String text); public void commitChar(char c); |
