Ported: Fix incorrect Android scancodes - madmiraal

Also ported:  Fix wrong android key mapping.
Fixes the wrong mapping of `Key::HOME`. Androids `KEYCODE_HOME` is in fact the hardware home button the right mapping is `KEYCODE_MOVE_HOME`.
Also adds mappings to keys that were not present before.
- HolonProduction
2f7de4c8ed
477d24b6d1
This commit is contained in:
Relintai 2022-11-30 18:58:00 +01:00
parent d0bb264cc2
commit ba39fa8970
8 changed files with 210 additions and 160 deletions

View File

@ -57,14 +57,17 @@ void AndroidInputHandler::_set_key_modifier_state(Ref<InputEventWithModifiers> e
ev->set_control(control_mem); ev->set_control(control_mem);
} }
void AndroidInputHandler::process_key_event(int p_keycode, int p_scancode, int p_unicode_char, bool p_pressed) { void AndroidInputHandler::process_key_event(int p_scancode, int p_physical_scancode, int p_unicode, bool p_pressed) {
Ref<InputEventKey> ev; Ref<InputEventKey> ev;
ev.instance(); ev.instance();
int val = p_unicode_char;
unsigned int scancode = android_get_keysym(p_keycode);
unsigned int phy_scancode = android_get_keysym(p_scancode);
switch (scancode) { unsigned int physical_scancode = godot_code_from_android_code(p_physical_scancode);
unsigned int scancode = physical_scancode;
if (p_scancode != 0) {
scancode = godot_code_from_unicode(p_scancode);
}
switch (physical_scancode) {
case KEY_SHIFT: { case KEY_SHIFT: {
shift_mem = p_pressed; shift_mem = p_pressed;
} break; } break;
@ -77,25 +80,18 @@ void AndroidInputHandler::process_key_event(int p_keycode, int p_scancode, int p
case KEY_META: { case KEY_META: {
meta_mem = p_pressed; meta_mem = p_pressed;
} break; } break;
default:
break;
} }
ev->set_scancode(scancode); ev->set_scancode(scancode);
ev->set_physical_scancode(phy_scancode); ev->set_physical_scancode(physical_scancode);
ev->set_unicode(p_unicode);
ev->set_unicode(val);
ev->set_pressed(p_pressed); ev->set_pressed(p_pressed);
_set_key_modifier_state(ev); _set_key_modifier_state(ev);
if (val == '\n') { if (p_physical_scancode == AKEYCODE_BACK) {
ev->set_scancode(KEY_ENTER);
} else if (val == 61448) {
ev->set_scancode(KEY_BACKSPACE);
ev->set_unicode(KEY_BACKSPACE);
} else if (val == 61453) {
ev->set_scancode(KEY_ENTER);
ev->set_unicode(KEY_ENTER);
} else if (p_scancode == 4) {
if (MainLoop *main_loop = OS::get_singleton()->get_main_loop()) { if (MainLoop *main_loop = OS::get_singleton()->get_main_loop()) {
main_loop->call_deferred("notification", MainLoop::NOTIFICATION_WM_GO_BACK_REQUEST); main_loop->call_deferred("notification", MainLoop::NOTIFICATION_WM_GO_BACK_REQUEST);
} }

View File

@ -95,7 +95,7 @@ private:
public: public:
void process_joy_event(const JoypadEvent &p_event); void process_joy_event(const JoypadEvent &p_event);
void process_key_event(int p_keycode, int p_scancode, int p_unicode_char, bool p_pressed); void process_key_event(int p_scancode, int p_physical_scancode, int p_unicode, bool p_pressed);
void process_mouse_event(int p_event_action, int p_event_android_buttons_mask, Point2 p_event_pos, Vector2 p_delta, bool p_double_click, bool p_source_mouse_relative); void process_mouse_event(int p_event_action, int p_event_android_buttons_mask, Point2 p_event_pos, Vector2 p_delta, bool p_double_click, bool p_source_mouse_relative);
void process_touch_event(int p_event, int p_pointer, const Vector<TouchPos> &p_points, bool p_double_tap); void process_touch_event(int p_event, int p_pointer, const Vector<TouchPos> &p_points, bool p_double_tap);
void process_magnify(Point2 p_pos, float p_factor); void process_magnify(Point2 p_pos, float p_factor);

View File

@ -30,12 +30,50 @@
#include "android_keys_utils.h" #include "android_keys_utils.h"
unsigned int android_get_keysym(unsigned int p_code) { unsigned int pandemoinum_code_from_android_code(unsigned int p_code) {
for (int i = 0; _ak_to_keycode[i].keysym != KEY_UNKNOWN; i++) { for (int i = 0; android_pandemonium_code_pairs[i].android_code != AKEYCODE_MAX; i++) {
if (_ak_to_keycode[i].keycode == p_code) { if (android_pandemonium_code_pairs[i].android_code == p_code) {
return _ak_to_keycode[i].keysym; return android_pandemonium_code_pairs[i].pandemonium_code;
} }
} }
return KEY_UNKNOWN; return KEY_UNKNOWN;
} }
unsigned int pandemonium_code_from_unicode(unsigned int p_code) {
unsigned int code = p_code;
if (code > 0xFF) {
return KEY_UNKNOWN;
}
// Known control codes.
if (code == '\b') { // 0x08
return KEY_BACKSPACE;
}
if (code == '\t') { // 0x09
return KEY_TAB;
}
if (code == '\n') { // 0x0A
return KEY_ENTER;
}
if (code == 0x1B) {
return KEY_ESCAPE;
}
if (code == 0x7F) {
return KEY_DELETE;
}
// Unknown control codes.
if (code <= 0x1F || (code >= 0x80 && code <= 0x9F)) {
return KEY_UNKNOWN;
}
// Convert to uppercase.
if (code >= 'a' && code <= 'z') { // 0x61 - 0x7A
code -= ('a' - 'A');
}
if (code >= u'à' && code <= u'ö') { // 0xE0 - 0xF6
code -= (u'à' - u'À'); // 0xE0 - 0xC0
}
if (code >= u'ø' && code <= u'þ') { // 0xF8 - 0xFF
code -= (u'ø' - u'Ø'); // 0xF8 - 0xD8
}
return code;
}

View File

@ -33,129 +33,144 @@
#include <android/input.h> #include <android/input.h>
#include <core/os/keyboard.h> #include <core/os/keyboard.h>
struct _WinTranslatePair { #define AKEYCODE_MAX 0xFFFF
unsigned int keysym;
unsigned int keycode; struct AndroidPandemoniumCodePair {
unsigned int android_code = 0;
unsigned int pandemonium_code = 0;
}; };
static _WinTranslatePair _ak_to_keycode[] = { static AndroidPandemoniumCodePair android_pandemonium_code_pairs[] = {
{ KEY_TAB, AKEYCODE_TAB }, { AKEYCODE_UNKNOWN, KEY_UNKNOWN }, // (0) Unknown key code.
{ KEY_ENTER, AKEYCODE_ENTER }, { AKEYCODE_BACK, KEY_BACK }, // (4) Back key.
{ KEY_SHIFT, AKEYCODE_SHIFT_LEFT }, { AKEYCODE_0, KEY_0 }, // (7) '0' key.
{ KEY_SHIFT, AKEYCODE_SHIFT_RIGHT }, { AKEYCODE_1, KEY_1 }, // (8) '1' key.
{ KEY_ALT, AKEYCODE_ALT_LEFT }, { AKEYCODE_2, KEY_2 }, // (9) '2' key.
{ KEY_ALT, AKEYCODE_ALT_RIGHT }, { AKEYCODE_3, KEY_3 }, // (10) '3' key.
{ KEY_MENU, AKEYCODE_MENU }, { AKEYCODE_4, KEY_4 }, // (11) '4' key.
{ KEY_PAUSE, AKEYCODE_MEDIA_PLAY_PAUSE }, { AKEYCODE_5, KEY_5 }, // (12) '5' key.
{ KEY_ESCAPE, AKEYCODE_BACK }, { AKEYCODE_6, KEY_6 }, // (13) '6' key.
{ KEY_SPACE, AKEYCODE_SPACE }, { AKEYCODE_7, KEY_7 }, // (14) '7' key.
{ KEY_PAGEUP, AKEYCODE_PAGE_UP }, { AKEYCODE_8, KEY_8 }, // (15) '8' key.
{ KEY_PAGEDOWN, AKEYCODE_PAGE_DOWN }, { AKEYCODE_9, KEY_9 }, // (16) '9' key.
{ KEY_HOME, AKEYCODE_HOME }, //(0x24) { AKEYCODE_STAR, KEY_ASTERISK }, // (17) '*' key.
{ KEY_LEFT, AKEYCODE_DPAD_LEFT }, { AKEYCODE_POUND, KEY_NUMBERSIGN }, // (18) '#' key.
{ KEY_UP, AKEYCODE_DPAD_UP }, { AKEYCODE_DPAD_UP, KEY_UP }, // (19) Directional Pad Up key.
{ KEY_RIGHT, AKEYCODE_DPAD_RIGHT }, { AKEYCODE_DPAD_DOWN, KEY_DOWN }, // (20) Directional Pad Down key.
{ KEY_DOWN, AKEYCODE_DPAD_DOWN }, { AKEYCODE_DPAD_LEFT, KEY_LEFT }, // (21) Directional Pad Left key.
{ KEY_PERIODCENTERED, AKEYCODE_DPAD_CENTER }, { AKEYCODE_DPAD_RIGHT, KEY_RIGHT }, // (22) Directional Pad Right key.
{ KEY_BACKSPACE, AKEYCODE_DEL }, { AKEYCODE_VOLUME_UP, KEY_VOLUMEUP }, // (24) Volume Up key.
{ KEY_0, AKEYCODE_0 }, ////0 key { AKEYCODE_VOLUME_DOWN, KEY_VOLUMEDOWN }, // (25) Volume Down key.
{ KEY_1, AKEYCODE_1 }, ////1 key { AKEYCODE_POWER, KEY_STANDBY }, // (26) Power key.
{ KEY_2, AKEYCODE_2 }, ////2 key { AKEYCODE_CLEAR, KEY_CLEAR }, // (28) Clear key.
{ KEY_3, AKEYCODE_3 }, ////3 key { AKEYCODE_A, KEY_A }, // (29) 'A' key.
{ KEY_4, AKEYCODE_4 }, ////4 key { AKEYCODE_B, KEY_B }, // (30) 'B' key.
{ KEY_5, AKEYCODE_5 }, ////5 key { AKEYCODE_C, KEY_C }, // (31) 'C' key.
{ KEY_6, AKEYCODE_6 }, ////6 key { AKEYCODE_D, KEY_D }, // (32) 'D' key.
{ KEY_7, AKEYCODE_7 }, ////7 key { AKEYCODE_E, KEY_E }, // (33) 'E' key.
{ KEY_8, AKEYCODE_8 }, ////8 key { AKEYCODE_F, KEY_F }, // (34) 'F' key.
{ KEY_9, AKEYCODE_9 }, ////9 key { AKEYCODE_G, KEY_G }, // (35) 'G' key.
{ KEY_A, AKEYCODE_A }, ////A key { AKEYCODE_H, KEY_H }, // (36) 'H' key.
{ KEY_B, AKEYCODE_B }, ////B key { AKEYCODE_I, KEY_I }, // (37) 'I' key.
{ KEY_C, AKEYCODE_C }, ////C key { AKEYCODE_J, KEY_J }, // (38) 'J' key.
{ KEY_D, AKEYCODE_D }, ////D key { AKEYCODE_K, KEY_K }, // (39) 'K' key.
{ KEY_E, AKEYCODE_E }, ////E key { AKEYCODE_L, KEY_L }, // (40) 'L' key.
{ KEY_F, AKEYCODE_F }, ////F key { AKEYCODE_M, KEY_M }, // (41) 'M' key.
{ KEY_G, AKEYCODE_G }, ////G key { AKEYCODE_N, KEY_N }, // (42) 'N' key.
{ KEY_H, AKEYCODE_H }, ////H key { AKEYCODE_O, KEY_O }, // (43) 'O' key.
{ KEY_I, AKEYCODE_I }, ////I key { AKEYCODE_P, KEY_P }, // (44) 'P' key.
{ KEY_J, AKEYCODE_J }, ////J key { AKEYCODE_Q, KEY_Q }, // (45) 'Q' key.
{ KEY_K, AKEYCODE_K }, ////K key { AKEYCODE_R, KEY_R }, // (46) 'R' key.
{ KEY_L, AKEYCODE_L }, ////L key { AKEYCODE_S, KEY_S }, // (47) 'S' key.
{ KEY_M, AKEYCODE_M }, ////M key { AKEYCODE_T, KEY_T }, // (48) 'T' key.
{ KEY_N, AKEYCODE_N }, ////N key { AKEYCODE_U, KEY_U }, // (49) 'U' key.
{ KEY_O, AKEYCODE_O }, ////O key { AKEYCODE_V, KEY_V }, // (50) 'V' key.
{ KEY_P, AKEYCODE_P }, ////P key { AKEYCODE_W, KEY_W }, // (51) 'W' key.
{ KEY_Q, AKEYCODE_Q }, ////Q key { AKEYCODE_X, KEY_X }, // (52) 'X' key.
{ KEY_R, AKEYCODE_R }, ////R key { AKEYCODE_Y, KEY_Y }, // (53) 'Y' key.
{ KEY_S, AKEYCODE_S }, ////S key { AKEYCODE_Z, KEY_Z }, // (54) 'Z' key.
{ KEY_T, AKEYCODE_T }, ////T key { AKEYCODE_COMMA, KEY_COMMA }, // (55) ', key.
{ KEY_U, AKEYCODE_U }, ////U key { AKEYCODE_PERIOD, KEY_PERIOD }, // (56) '.' key.
{ KEY_V, AKEYCODE_V }, ////V key { AKEYCODE_ALT_LEFT, KEY_ALT }, // (57) Left Alt modifier key.
{ KEY_W, AKEYCODE_W }, ////W key { AKEYCODE_ALT_RIGHT, KEY_ALT }, // (58) Right Alt modifier key.
{ KEY_X, AKEYCODE_X }, ////X key { AKEYCODE_SHIFT_LEFT, KEY_SHIFT }, // (59) Left Shift modifier key.
{ KEY_Y, AKEYCODE_Y }, ////Y key { AKEYCODE_SHIFT_RIGHT, KEY_SHIFT }, // (60) Right Shift modifier key.
{ KEY_Z, AKEYCODE_Z }, ////Z key { AKEYCODE_TAB, KEY_TAB }, // (61) Tab key.
{ KEY_HOMEPAGE, AKEYCODE_EXPLORER }, { AKEYCODE_SPACE, KEY_SPACE }, // (62) Space key.
{ KEY_LAUNCH0, AKEYCODE_BUTTON_A }, { AKEYCODE_ENVELOPE, KEY_LAUNCHMAIL }, // (65) Envelope special function key.
{ KEY_LAUNCH1, AKEYCODE_BUTTON_B }, { AKEYCODE_ENTER, KEY_ENTER }, // (66) Enter key.
{ KEY_LAUNCH2, AKEYCODE_BUTTON_C }, { AKEYCODE_DEL, KEY_BACKSPACE }, // (67) Backspace key.
{ KEY_LAUNCH3, AKEYCODE_BUTTON_X }, { AKEYCODE_GRAVE, KEY_QUOTELEFT }, // (68) '`' (backtick) key.
{ KEY_LAUNCH4, AKEYCODE_BUTTON_Y }, { AKEYCODE_MINUS, KEY_MINUS }, // (69) '-'.
{ KEY_LAUNCH5, AKEYCODE_BUTTON_Z }, { AKEYCODE_EQUALS, KEY_EQUAL }, // (70) '=' key.
{ KEY_LAUNCH6, AKEYCODE_BUTTON_L1 }, { AKEYCODE_LEFT_BRACKET, KEY_BRACKETLEFT }, // (71) '[' key.
{ KEY_LAUNCH7, AKEYCODE_BUTTON_R1 }, { AKEYCODE_RIGHT_BRACKET, KEY_BRACKETRIGHT }, // (72) ']' key.
{ KEY_LAUNCH8, AKEYCODE_BUTTON_L2 }, { AKEYCODE_BACKSLASH, KEY_BACKSLASH }, // (73) '\' key.
{ KEY_LAUNCH9, AKEYCODE_BUTTON_R2 }, { AKEYCODE_SEMICOLON, KEY_SEMICOLON }, // (74) ';' key.
{ KEY_LAUNCHA, AKEYCODE_BUTTON_THUMBL }, { AKEYCODE_APOSTROPHE, KEY_APOSTROPHE }, // (75) ''' (apostrophe) key.
{ KEY_LAUNCHB, AKEYCODE_BUTTON_THUMBR }, { AKEYCODE_SLASH, KEY_SLASH }, // (76) '/' key.
{ KEY_LAUNCHC, AKEYCODE_BUTTON_START }, { AKEYCODE_AT, KEY_AT }, // (77) '@' key.
{ KEY_LAUNCHD, AKEYCODE_BUTTON_SELECT }, { AKEYCODE_PLUS, KEY_PLUS }, // (81) '+' key.
{ KEY_LAUNCHE, AKEYCODE_BUTTON_MODE }, { AKEYCODE_MENU, KEY_MENU }, // (82) Menu key.
{ KEY_VOLUMEMUTE, AKEYCODE_MUTE }, { AKEYCODE_SEARCH, KEY_SEARCH }, // (84) Search key.
{ KEY_VOLUMEDOWN, AKEYCODE_VOLUME_DOWN }, { AKEYCODE_MEDIA_STOP, KEY_MEDIASTOP }, // (86) Stop media key.
{ KEY_VOLUMEUP, AKEYCODE_VOLUME_UP }, { AKEYCODE_MEDIA_NEXT, KEY_MEDIANEXT }, // (87) Play Next media key.
{ KEY_BACK, AKEYCODE_MEDIA_REWIND }, { AKEYCODE_MEDIA_PREVIOUS, KEY_MEDIAPREVIOUS }, // (88) Play Previous media key.
{ KEY_FORWARD, AKEYCODE_MEDIA_FAST_FORWARD }, { AKEYCODE_PAGE_UP, KEY_PAGEUP }, // (92) Page Up key.
{ KEY_MEDIANEXT, AKEYCODE_MEDIA_NEXT }, { AKEYCODE_PAGE_DOWN, KEY_PAGEDOWN }, // (93) Page Down key.
{ KEY_MEDIAPREVIOUS, AKEYCODE_MEDIA_PREVIOUS }, { AKEYCODE_ESCAPE, KEY_ESCAPE }, // (111) Escape key.
{ KEY_MEDIASTOP, AKEYCODE_MEDIA_STOP }, { AKEYCODE_FORWARD_DEL, KEY_DELETE }, // (112) Forward Delete key.
{ KEY_PLUS, AKEYCODE_PLUS }, { AKEYCODE_CTRL_LEFT, KEY_CONTROL }, // (113) Left Control modifier key.
{ KEY_EQUAL, AKEYCODE_EQUALS }, // the '+' key { AKEYCODE_CTRL_RIGHT, KEY_CONTROL }, // (114) Right Control modifier key.
{ KEY_COMMA, AKEYCODE_COMMA }, // the ',' key { AKEYCODE_CAPS_LOCK, KEY_CAPSLOCK }, // (115) Caps Lock key.
{ KEY_MINUS, AKEYCODE_MINUS }, // the '-' key { AKEYCODE_SCROLL_LOCK, KEY_SCROLLLOCK }, // (116) Scroll Lock key.
{ KEY_SLASH, AKEYCODE_SLASH }, // the '/?' key { AKEYCODE_META_LEFT, KEY_META }, // (117) Left Meta modifier key.
{ KEY_BACKSLASH, AKEYCODE_BACKSLASH }, { AKEYCODE_META_RIGHT, KEY_META }, // (118) Right Meta modifier key.
{ KEY_BRACKETLEFT, AKEYCODE_LEFT_BRACKET }, { AKEYCODE_SYSRQ, KEY_PRINT }, // (120) System Request / Print Screen key.
{ KEY_BRACKETRIGHT, AKEYCODE_RIGHT_BRACKET }, { AKEYCODE_BREAK, KEY_PAUSE }, // (121) Break / Pause key.
{ KEY_CONTROL, AKEYCODE_CTRL_LEFT }, { AKEYCODE_MOVE_HOME, KEY_HOME }, // (122) Home Movement key.
{ KEY_CONTROL, AKEYCODE_CTRL_RIGHT }, { AKEYCODE_MOVE_END, KEY_END }, // (123) End Movement key.
{ KEY_UNKNOWN, 0 } { AKEYCODE_INSERT, KEY_INSERT }, // (124) Insert key.
{ AKEYCODE_FORWARD, KEY_FORWARD }, // (125) Forward key.
{ AKEYCODE_MEDIA_PLAY, KEY_MEDIAPLAY }, // (126) Play media key.
{ AKEYCODE_MEDIA_RECORD, KEY_MEDIARECORD }, // (130) Record media key.
{ AKEYCODE_F1, KEY_F1 }, // (131) F1 key.
{ AKEYCODE_F2, KEY_F2 }, // (132) F2 key.
{ AKEYCODE_F3, KEY_F3 }, // (133) F3 key.
{ AKEYCODE_F4, KEY_F4 }, // (134) F4 key.
{ AKEYCODE_F5, KEY_F5 }, // (135) F5 key.
{ AKEYCODE_F6, KEY_F6 }, // (136) F6 key.
{ AKEYCODE_F7, KEY_F7 }, // (137) F7 key.
{ AKEYCODE_F8, KEY_F8 }, // (138) F8 key.
{ AKEYCODE_F9, KEY_F9 }, // (139) F9 key.
{ AKEYCODE_F10, KEY_F10 }, // (140) F10 key.
{ AKEYCODE_F11, KEY_F11 }, // (141) F11 key.
{ AKEYCODE_F12, KEY_F12 }, // (142) F12 key.
{ AKEYCODE_NUM_LOCK, KEY_NUMLOCK }, // (143) Num Lock key.
{ AKEYCODE_NUMPAD_0, KEY_KP_0 }, // (144) Numeric keypad '0' key.
{ AKEYCODE_NUMPAD_1, KEY_KP_1 }, // (145) Numeric keypad '1' key.
{ AKEYCODE_NUMPAD_2, KEY_KP_2 }, // (146) Numeric keypad '2' key.
{ AKEYCODE_NUMPAD_3, KEY_KP_3 }, // (147) Numeric keypad '3' key.
{ AKEYCODE_NUMPAD_4, KEY_KP_4 }, // (148) Numeric keypad '4' key.
{ AKEYCODE_NUMPAD_5, KEY_KP_5 }, // (149) Numeric keypad '5' key.
{ AKEYCODE_NUMPAD_6, KEY_KP_6 }, // (150) Numeric keypad '6' key.
{ AKEYCODE_NUMPAD_7, KEY_KP_7 }, // (151) Numeric keypad '7' key.
{ AKEYCODE_NUMPAD_8, KEY_KP_8 }, // (152) Numeric keypad '8' key.
{ AKEYCODE_NUMPAD_9, KEY_KP_9 }, // (153) Numeric keypad '9' key.
{ AKEYCODE_NUMPAD_DIVIDE, KEY_KP_DIVIDE }, // (154) Numeric keypad '/' key (for division).
{ AKEYCODE_NUMPAD_MULTIPLY, KEY_KP_MULTIPLY }, // (155) Numeric keypad '*' key (for multiplication).
{ AKEYCODE_NUMPAD_SUBTRACT, KEY_KP_SUBTRACT }, // (156) Numeric keypad '-' key (for subtraction).
{ AKEYCODE_NUMPAD_ADD, KEY_KP_ADD }, // (157) Numeric keypad '+' key (for addition).
{ AKEYCODE_NUMPAD_DOT, KEY_KP_PERIOD }, // (158) Numeric keypad '.' key (for decimals or digit grouping).
{ AKEYCODE_NUMPAD_ENTER, KEY_KP_ENTER }, // (160) Numeric keypad Enter key.
{ AKEYCODE_VOLUME_MUTE, KEY_VOLUMEMUTE }, // (164) Volume Mute key.
{ AKEYCODE_YEN, KEY_YEN }, // (216) Japanese Yen key.
{ AKEYCODE_HELP, KEY_HELP }, // (259) Help key.
{ AKEYCODE_REFRESH, KEY_REFRESH }, // (285) Refresh key.
{ AKEYCODE_MAX, KEY_UNKNOWN }
}; };
/*
TODO: map these android key:
AKEYCODE_SOFT_LEFT = 1,
AKEYCODE_SOFT_RIGHT = 2,
AKEYCODE_CALL = 5,
AKEYCODE_ENDCALL = 6,
AKEYCODE_STAR = 17,
AKEYCODE_POUND = 18,
AKEYCODE_POWER = 26,
AKEYCODE_CAMERA = 27,
AKEYCODE_CLEAR = 28,
AKEYCODE_SYM = 63,
AKEYCODE_ENVELOPE = 65,
AKEYCODE_GRAVE = 68,
AKEYCODE_SEMICOLON = 74,
AKEYCODE_APOSTROPHE = 75,
AKEYCODE_AT = 77,
AKEYCODE_NUM = 78,
AKEYCODE_HEADSETHOOK = 79,
AKEYCODE_FOCUS = 80, // *Camera* focus
AKEYCODE_NOTIFICATION = 83,
AKEYCODE_SEARCH = 84,
AKEYCODE_PICTSYMBOLS = 94,
AKEYCODE_SWITCH_CHARSET = 95,
*/
unsigned int android_get_keysym(unsigned int p_code); unsigned int pandemonium_code_from_android_code(unsigned int p_code);
unsigned int pandemonium_code_from_unicode(unsigned int p_code);
#endif // ANDROID_KEYS_UTILS_H #endif // ANDROID_KEYS_UTILS_H

View File

@ -128,9 +128,14 @@ public class PandemoniumInputHandler implements InputManager.InputDeviceListener
PandemoniumLib.joybutton(pandemoniumJoyId, button, false); PandemoniumLib.joybutton(pandemoniumJoyId, button, false);
} }
} else { } else {
final int scanCode = event.getScanCode(); // getKeyCode(): The physical key that was pressed.
final int chr = event.getUnicodeChar(0); // getScanCode(): Hardware key id. Device dependent and only used for debugging.
PandemoniumLib.key(keyCode, scanCode, chr, false); // Pandemonium's scancodes match the ASCII codes, so for single byte unicode characters,
// we can use the unmodified unicode character to determine PandemoniumLib's scancode.
final int scancode = event.getUnicodeChar(0);
final int physical_scancode = event.getKeyCode();
final int unicode = event.getUnicodeChar();
PandemoniumLib.key(scancode, physical_scancode, unicode, false);
}; };
return true; return true;

View File

@ -92,11 +92,9 @@ public class PandemoniumTextInputWrapper implements TextWatcher, OnEditorActionL
@Override @Override
public void beforeTextChanged(final CharSequence pCharSequence, final int start, final int count, final int after) { public void beforeTextChanged(final CharSequence pCharSequence, final int start, final int count, final int after) {
//Log.d(TAG, "beforeTextChanged(" + pCharSequence + ")start: " + start + ",count: " + count + ",after: " + after);
for (int i = 0; i < count; ++i) { for (int i = 0; i < count; ++i) {
PandemoniumLib.key(KeyEvent.KEYCODE_DEL, KeyEvent.KEYCODE_DEL, 0, true); PandemoniumLib.key(0, KeyEvent.KEYCODE_DEL, 0, true);
PandemoniumLib.key(KeyEvent.KEYCODE_DEL, KeyEvent.KEYCODE_DEL, 0, false); PandemoniumLib.key(0, KeyEvent.KEYCODE_DEL, 0, false);
if (mHasSelection) { if (mHasSelection) {
mHasSelection = false; mHasSelection = false;
@ -107,8 +105,6 @@ public class PandemoniumTextInputWrapper implements TextWatcher, OnEditorActionL
@Override @Override
public void onTextChanged(final CharSequence pCharSequence, final int start, final int before, final int count) { public void onTextChanged(final CharSequence pCharSequence, final int start, final int before, final int count) {
//Log.d(TAG, "onTextChanged(" + pCharSequence + ")start: " + start + ",count: " + count + ",before: " + before);
final int[] newChars = new int[count]; final int[] newChars = new int[count];
for (int i = start; i < start + count; ++i) { for (int i = start; i < start + count; ++i) {
newChars[i - start] = pCharSequence.charAt(i); newChars[i - start] = pCharSequence.charAt(i);
@ -119,8 +115,8 @@ public class PandemoniumTextInputWrapper implements TextWatcher, OnEditorActionL
// Return keys are handled through action events // Return keys are handled through action events
continue; continue;
} }
PandemoniumLib.key(0, 0, key, true); PandemoniumLib.key(key, 0, key, true);
PandemoniumLib.key(0, 0, key, false); PandemoniumLib.key(key, 0, key, false);
} }
} }
@ -131,16 +127,16 @@ public class PandemoniumTextInputWrapper implements TextWatcher, OnEditorActionL
for (int i = 0; i < characters.length(); i++) { for (int i = 0; i < characters.length(); i++) {
final int ch = characters.codePointAt(i); final int ch = characters.codePointAt(i);
PandemoniumLib.key(0, 0, ch, true); PandemoniumLib.key(ch, 0, ch, true);
PandemoniumLib.key(0, 0, ch, false); PandemoniumLib.key(ch, 0, ch, false);
} }
} }
if (pActionID == EditorInfo.IME_ACTION_DONE) { if (pActionID == EditorInfo.IME_ACTION_DONE) {
// Enter key has been pressed // Enter key has been pressed
mView.queueEvent(() -> { mView.queueEvent(() -> {
PandemoniumLib.key(KeyEvent.KEYCODE_ENTER, KeyEvent.KEYCODE_ENTER, 0, true); PandemoniumLib.key(0, KeyEvent.KEYCODE_ENTER, 0, true);
PandemoniumLib.key(KeyEvent.KEYCODE_ENTER, KeyEvent.KEYCODE_ENTER, 0, false); PandemoniumLib.key(0, KeyEvent.KEYCODE_ENTER, 0, false);
}); });
mView.requestFocus(); mView.requestFocus();
return true; return true;

View File

@ -403,11 +403,11 @@ JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_
} }
// Called on the UI thread // Called on the UI thread
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_key(JNIEnv *env, jclass clazz, jint p_keycode, jint p_scancode, jint p_unicode_char, jboolean p_pressed) { JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_key(JNIEnv *env, jclass clazz, jint p_scancode, jint p_physical_scancode, jint p_unicode, jboolean p_pressed) {
if (step.get() <= 0) if (step.get() <= 0)
return; return;
input_handler->process_key_event(p_keycode, p_scancode, p_unicode_char, p_pressed); input_handler->process_key_event(p_scancode, p_physical_scancode, p_unicode, p_pressed);
} }
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_accelerometer(JNIEnv *env, jclass clazz, jfloat x, jfloat y, jfloat z) { JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_accelerometer(JNIEnv *env, jclass clazz, jfloat x, jfloat y, jfloat z) {

View File

@ -48,7 +48,7 @@ JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_dispatchTouchEvent(JNIEnv *env, jclass clazz, jint ev, jint pointer, jint pointer_count, jfloatArray positions, jboolean p_double_tap); JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_dispatchTouchEvent(JNIEnv *env, jclass clazz, jint ev, jint pointer, jint pointer_count, jfloatArray positions, jboolean p_double_tap);
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_magnify(JNIEnv *env, jclass clazz, jfloat p_x, jfloat p_y, jfloat p_factor); JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_magnify(JNIEnv *env, jclass clazz, jfloat p_x, jfloat p_y, jfloat p_factor);
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_pan(JNIEnv *env, jclass clazz, jfloat p_x, jfloat p_y, jfloat p_delta_x, jfloat p_delta_y); JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_pan(JNIEnv *env, jclass clazz, jfloat p_x, jfloat p_y, jfloat p_delta_x, jfloat p_delta_y);
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_key(JNIEnv *env, jclass clazz, jint p_keycode, jint p_scancode, jint p_unicode_char, jboolean p_pressed); JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_key(JNIEnv *env, jclass clazz, jint p_scancode, jint p_physical_scancode, jint p_unicode, jboolean p_pressed);
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_joybutton(JNIEnv *env, jclass clazz, jint p_device, jint p_button, jboolean p_pressed); JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_joybutton(JNIEnv *env, jclass clazz, jint p_device, jint p_button, jboolean p_pressed);
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_joyaxis(JNIEnv *env, jclass clazz, jint p_device, jint p_axis, jfloat p_value); JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_joyaxis(JNIEnv *env, jclass clazz, jint p_device, jint p_axis, jfloat p_value);
JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_joyhat(JNIEnv *env, jclass clazz, jint p_device, jint p_hat_x, jint p_hat_y); JNIEXPORT void JNICALL Java_net_relintai_pandemonium_pandemonium_PandemoniumLib_joyhat(JNIEnv *env, jclass clazz, jint p_device, jint p_hat_x, jint p_hat_y);