Merge pull request #18020 from bruvzg/input_fix_non_latin_and_add_hw_scancodes

Fix non-latin layout scancodes on Linux, adds access to physical scancodes.
This commit is contained in:
Rémi Verschelde 2020-03-01 23:00:42 +01:00 committed by GitHub
commit e2b66cacf7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
78 changed files with 736 additions and 299 deletions

View File

@ -1134,15 +1134,17 @@ String _OS::get_system_dir(SystemDir p_dir) const {
return OS::get_singleton()->get_system_dir(OS::SystemDir(p_dir)); return OS::get_singleton()->get_system_dir(OS::SystemDir(p_dir));
} }
String _OS::get_scancode_string(uint32_t p_code) const { String _OS::get_keycode_string(uint32_t p_code) const {
return keycode_get_string(p_code); return keycode_get_string(p_code);
} }
bool _OS::is_scancode_unicode(uint32_t p_unicode) const {
bool _OS::is_keycode_unicode(uint32_t p_unicode) const {
return keycode_has_unicode(p_unicode); return keycode_has_unicode(p_unicode);
} }
int _OS::find_scancode_from_string(const String &p_code) const {
int _OS::find_keycode_from_string(const String &p_code) const {
return find_keycode(p_code); return find_keycode(p_code);
} }
@ -1333,9 +1335,9 @@ void _OS::_bind_methods() {
ClassDB::bind_method(D_METHOD("native_video_pause"), &_OS::native_video_pause); ClassDB::bind_method(D_METHOD("native_video_pause"), &_OS::native_video_pause);
ClassDB::bind_method(D_METHOD("native_video_unpause"), &_OS::native_video_unpause); ClassDB::bind_method(D_METHOD("native_video_unpause"), &_OS::native_video_unpause);
ClassDB::bind_method(D_METHOD("get_scancode_string", "code"), &_OS::get_scancode_string); ClassDB::bind_method(D_METHOD("get_keycode_string", "code"), &_OS::get_keycode_string);
ClassDB::bind_method(D_METHOD("is_scancode_unicode", "code"), &_OS::is_scancode_unicode); ClassDB::bind_method(D_METHOD("is_keycode_unicode", "code"), &_OS::is_keycode_unicode);
ClassDB::bind_method(D_METHOD("find_scancode_from_string", "string"), &_OS::find_scancode_from_string); ClassDB::bind_method(D_METHOD("find_keycode_from_string", "string"), &_OS::find_keycode_from_string);
ClassDB::bind_method(D_METHOD("set_use_file_access_save_and_swap", "enabled"), &_OS::set_use_file_access_save_and_swap); ClassDB::bind_method(D_METHOD("set_use_file_access_save_and_swap", "enabled"), &_OS::set_use_file_access_save_and_swap);

View File

@ -266,9 +266,9 @@ public:
String get_unique_id() const; String get_unique_id() const;
String get_scancode_string(uint32_t p_code) const; String get_keycode_string(uint32_t p_code) const;
bool is_scancode_unicode(uint32_t p_unicode) const; bool is_keycode_unicode(uint32_t p_unicode) const;
int find_scancode_from_string(const String &p_code) const; int find_keycode_from_string(const String &p_code) const;
void set_use_file_access_save_and_swap(bool p_enable); void set_use_file_access_save_and_swap(bool p_enable);

View File

@ -256,76 +256,76 @@ void InputMap::load_default() {
add_action("ui_accept"); add_action("ui_accept");
key.instance(); key.instance();
key->set_scancode(KEY_ENTER); key->set_keycode(KEY_ENTER);
action_add_event("ui_accept", key); action_add_event("ui_accept", key);
key.instance(); key.instance();
key->set_scancode(KEY_KP_ENTER); key->set_keycode(KEY_KP_ENTER);
action_add_event("ui_accept", key); action_add_event("ui_accept", key);
key.instance(); key.instance();
key->set_scancode(KEY_SPACE); key->set_keycode(KEY_SPACE);
action_add_event("ui_accept", key); action_add_event("ui_accept", key);
add_action("ui_select"); add_action("ui_select");
key.instance(); key.instance();
key->set_scancode(KEY_SPACE); key->set_keycode(KEY_SPACE);
action_add_event("ui_select", key); action_add_event("ui_select", key);
add_action("ui_cancel"); add_action("ui_cancel");
key.instance(); key.instance();
key->set_scancode(KEY_ESCAPE); key->set_keycode(KEY_ESCAPE);
action_add_event("ui_cancel", key); action_add_event("ui_cancel", key);
add_action("ui_focus_next"); add_action("ui_focus_next");
key.instance(); key.instance();
key->set_scancode(KEY_TAB); key->set_keycode(KEY_TAB);
action_add_event("ui_focus_next", key); action_add_event("ui_focus_next", key);
add_action("ui_focus_prev"); add_action("ui_focus_prev");
key.instance(); key.instance();
key->set_scancode(KEY_TAB); key->set_keycode(KEY_TAB);
key->set_shift(true); key->set_shift(true);
action_add_event("ui_focus_prev", key); action_add_event("ui_focus_prev", key);
add_action("ui_left"); add_action("ui_left");
key.instance(); key.instance();
key->set_scancode(KEY_LEFT); key->set_keycode(KEY_LEFT);
action_add_event("ui_left", key); action_add_event("ui_left", key);
add_action("ui_right"); add_action("ui_right");
key.instance(); key.instance();
key->set_scancode(KEY_RIGHT); key->set_keycode(KEY_RIGHT);
action_add_event("ui_right", key); action_add_event("ui_right", key);
add_action("ui_up"); add_action("ui_up");
key.instance(); key.instance();
key->set_scancode(KEY_UP); key->set_keycode(KEY_UP);
action_add_event("ui_up", key); action_add_event("ui_up", key);
add_action("ui_down"); add_action("ui_down");
key.instance(); key.instance();
key->set_scancode(KEY_DOWN); key->set_keycode(KEY_DOWN);
action_add_event("ui_down", key); action_add_event("ui_down", key);
add_action("ui_page_up"); add_action("ui_page_up");
key.instance(); key.instance();
key->set_scancode(KEY_PAGEUP); key->set_keycode(KEY_PAGEUP);
action_add_event("ui_page_up", key); action_add_event("ui_page_up", key);
add_action("ui_page_down"); add_action("ui_page_down");
key.instance(); key.instance();
key->set_scancode(KEY_PAGEDOWN); key->set_keycode(KEY_PAGEDOWN);
action_add_event("ui_page_down", key); action_add_event("ui_page_down", key);
add_action("ui_home"); add_action("ui_home");
key.instance(); key.instance();
key->set_scancode(KEY_HOME); key->set_keycode(KEY_HOME);
action_add_event("ui_home", key); action_add_event("ui_home", key);
add_action("ui_end"); add_action("ui_end");
key.instance(); key.instance();
key->set_scancode(KEY_END); key->set_keycode(KEY_END);
action_add_event("ui_end", key); action_add_event("ui_end", key);
//set("display/window/handheld/orientation", "landscape"); //set("display/window/handheld/orientation", "landscape");

View File

@ -57,7 +57,7 @@ Input::MouseMode Input::get_mouse_mode() const {
void Input::_bind_methods() { void Input::_bind_methods() {
ClassDB::bind_method(D_METHOD("is_key_pressed", "scancode"), &Input::is_key_pressed); ClassDB::bind_method(D_METHOD("is_key_pressed", "keycode"), &Input::is_key_pressed);
ClassDB::bind_method(D_METHOD("is_mouse_button_pressed", "button"), &Input::is_mouse_button_pressed); ClassDB::bind_method(D_METHOD("is_mouse_button_pressed", "button"), &Input::is_mouse_button_pressed);
ClassDB::bind_method(D_METHOD("is_joy_button_pressed", "device", "button"), &Input::is_joy_button_pressed); ClassDB::bind_method(D_METHOD("is_joy_button_pressed", "device", "button"), &Input::is_joy_button_pressed);
ClassDB::bind_method(D_METHOD("is_action_pressed", "action"), &Input::is_action_pressed); ClassDB::bind_method(D_METHOD("is_action_pressed", "action"), &Input::is_action_pressed);

View File

@ -79,7 +79,7 @@ public:
static Input *get_singleton(); static Input *get_singleton();
virtual bool is_key_pressed(int p_scancode) const = 0; virtual bool is_key_pressed(int p_keycode) const = 0;
virtual bool is_mouse_button_pressed(int p_button) const = 0; virtual bool is_mouse_button_pressed(int p_button) const = 0;
virtual bool is_joy_button_pressed(int p_device, int p_button) const = 0; virtual bool is_joy_button_pressed(int p_device, int p_button) const = 0;
virtual bool is_action_pressed(const StringName &p_action) const = 0; virtual bool is_action_pressed(const StringName &p_action) const = 0;

View File

@ -237,19 +237,31 @@ bool InputEventKey::is_pressed() const {
return pressed; return pressed;
} }
void InputEventKey::set_scancode(uint32_t p_scancode) { void InputEventKey::set_keycode(uint32_t p_keycode) {
scancode = p_scancode; keycode = p_keycode;
} }
uint32_t InputEventKey::get_scancode() const {
return scancode; uint32_t InputEventKey::get_keycode() const {
return keycode;
}
void InputEventKey::set_physical_keycode(uint32_t p_keycode) {
physical_keycode = p_keycode;
}
uint32_t InputEventKey::get_physical_keycode() const {
return physical_keycode;
} }
void InputEventKey::set_unicode(uint32_t p_unicode) { void InputEventKey::set_unicode(uint32_t p_unicode) {
unicode = p_unicode; unicode = p_unicode;
} }
uint32_t InputEventKey::get_unicode() const { uint32_t InputEventKey::get_unicode() const {
return unicode; return unicode;
@ -259,14 +271,30 @@ void InputEventKey::set_echo(bool p_enable) {
echo = p_enable; echo = p_enable;
} }
bool InputEventKey::is_echo() const { bool InputEventKey::is_echo() const {
return echo; return echo;
} }
uint32_t InputEventKey::get_scancode_with_modifiers() const { uint32_t InputEventKey::get_keycode_with_modifiers() const {
uint32_t sc = scancode; uint32_t sc = keycode;
if (get_control())
sc |= KEY_MASK_CTRL;
if (get_alt())
sc |= KEY_MASK_ALT;
if (get_shift())
sc |= KEY_MASK_SHIFT;
if (get_metakey())
sc |= KEY_MASK_META;
return sc;
}
uint32_t InputEventKey::get_physical_keycode_with_modifiers() const {
uint32_t sc = physical_keycode;
if (get_control()) if (get_control())
sc |= KEY_MASK_CTRL; sc |= KEY_MASK_CTRL;
if (get_alt()) if (get_alt())
@ -281,7 +309,7 @@ uint32_t InputEventKey::get_scancode_with_modifiers() const {
String InputEventKey::as_text() const { String InputEventKey::as_text() const {
String kc = keycode_get_string(scancode); String kc = keycode_get_string(keycode);
if (kc == String()) if (kc == String())
return kc; return kc;
@ -306,10 +334,18 @@ bool InputEventKey::action_match(const Ref<InputEvent> &p_event, bool *p_pressed
if (key.is_null()) if (key.is_null())
return false; return false;
uint32_t code = get_scancode_with_modifiers(); bool match = false;
uint32_t event_code = key->get_scancode_with_modifiers(); if (get_keycode() == 0) {
uint32_t code = get_physical_keycode_with_modifiers();
uint32_t event_code = key->get_physical_keycode_with_modifiers();
bool match = get_scancode() == key->get_scancode() && (!key->is_pressed() || (code & event_code) == code); match = get_physical_keycode() == key->get_physical_keycode() && (!key->is_pressed() || (code & event_code) == code);
} else {
uint32_t code = get_keycode_with_modifiers();
uint32_t event_code = key->get_keycode_with_modifiers();
match = get_keycode() == key->get_keycode() && (!key->is_pressed() || (code & event_code) == code);
}
if (match) { if (match) {
if (p_pressed != NULL) if (p_pressed != NULL)
*p_pressed = key->is_pressed(); *p_pressed = key->is_pressed();
@ -325,8 +361,8 @@ bool InputEventKey::shortcut_match(const Ref<InputEvent> &p_event) const {
if (key.is_null()) if (key.is_null())
return false; return false;
uint32_t code = get_scancode_with_modifiers(); uint32_t code = get_keycode_with_modifiers();
uint32_t event_code = key->get_scancode_with_modifiers(); uint32_t event_code = key->get_keycode_with_modifiers();
return code == event_code; return code == event_code;
} }
@ -335,18 +371,23 @@ void InputEventKey::_bind_methods() {
ClassDB::bind_method(D_METHOD("set_pressed", "pressed"), &InputEventKey::set_pressed); ClassDB::bind_method(D_METHOD("set_pressed", "pressed"), &InputEventKey::set_pressed);
ClassDB::bind_method(D_METHOD("set_scancode", "scancode"), &InputEventKey::set_scancode); ClassDB::bind_method(D_METHOD("set_keycode", "keycode"), &InputEventKey::set_keycode);
ClassDB::bind_method(D_METHOD("get_scancode"), &InputEventKey::get_scancode); ClassDB::bind_method(D_METHOD("get_keycode"), &InputEventKey::get_keycode);
ClassDB::bind_method(D_METHOD("set_physical_keycode", "physical_keycode"), &InputEventKey::set_physical_keycode);
ClassDB::bind_method(D_METHOD("get_physical_keycode"), &InputEventKey::get_physical_keycode);
ClassDB::bind_method(D_METHOD("set_unicode", "unicode"), &InputEventKey::set_unicode); ClassDB::bind_method(D_METHOD("set_unicode", "unicode"), &InputEventKey::set_unicode);
ClassDB::bind_method(D_METHOD("get_unicode"), &InputEventKey::get_unicode); ClassDB::bind_method(D_METHOD("get_unicode"), &InputEventKey::get_unicode);
ClassDB::bind_method(D_METHOD("set_echo", "echo"), &InputEventKey::set_echo); ClassDB::bind_method(D_METHOD("set_echo", "echo"), &InputEventKey::set_echo);
ClassDB::bind_method(D_METHOD("get_scancode_with_modifiers"), &InputEventKey::get_scancode_with_modifiers); ClassDB::bind_method(D_METHOD("get_keycode_with_modifiers"), &InputEventKey::get_keycode_with_modifiers);
ClassDB::bind_method(D_METHOD("get_physical_keycode_with_modifiers"), &InputEventKey::get_physical_keycode_with_modifiers);
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "pressed"), "set_pressed", "is_pressed"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "pressed"), "set_pressed", "is_pressed");
ADD_PROPERTY(PropertyInfo(Variant::INT, "scancode"), "set_scancode", "get_scancode"); ADD_PROPERTY(PropertyInfo(Variant::INT, "keycode"), "set_keycode", "get_keycode");
ADD_PROPERTY(PropertyInfo(Variant::INT, "physical_keycode"), "set_physical_keycode", "get_physical_keycode");
ADD_PROPERTY(PropertyInfo(Variant::INT, "unicode"), "set_unicode", "get_unicode"); ADD_PROPERTY(PropertyInfo(Variant::INT, "unicode"), "set_unicode", "get_unicode");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "echo"), "set_echo", "is_echo"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "echo"), "set_echo", "is_echo");
} }
@ -354,7 +395,8 @@ void InputEventKey::_bind_methods() {
InputEventKey::InputEventKey() { InputEventKey::InputEventKey() {
pressed = false; pressed = false;
scancode = 0; keycode = 0;
physical_keycode = 0;
unicode = 0; ///unicode unicode = 0; ///unicode
echo = false; echo = false;
} }

View File

@ -256,7 +256,8 @@ class InputEventKey : public InputEventWithModifiers {
bool pressed; /// otherwise release bool pressed; /// otherwise release
uint32_t scancode; ///< check keyboard.h , KeyCode enum, without modifier masks uint32_t keycode; ///< check keyboard.h , KeyCode enum, without modifier masks
uint32_t physical_keycode;
uint32_t unicode; ///unicode uint32_t unicode; ///unicode
bool echo; /// true if this is an echo key bool echo; /// true if this is an echo key
@ -268,8 +269,11 @@ public:
void set_pressed(bool p_pressed); void set_pressed(bool p_pressed);
virtual bool is_pressed() const; virtual bool is_pressed() const;
void set_scancode(uint32_t p_scancode); void set_keycode(uint32_t p_keycode);
uint32_t get_scancode() const; uint32_t get_keycode() const;
void set_physical_keycode(uint32_t p_keycode);
uint32_t get_physical_keycode() const;
void set_unicode(uint32_t p_unicode); void set_unicode(uint32_t p_unicode);
uint32_t get_unicode() const; uint32_t get_unicode() const;
@ -277,7 +281,8 @@ public:
void set_echo(bool p_enable); void set_echo(bool p_enable);
virtual bool is_echo() const; virtual bool is_echo() const;
uint32_t get_scancode_with_modifiers() const; uint32_t get_keycode_with_modifiers() const;
uint32_t get_physical_keycode_with_modifiers() const;
virtual bool action_match(const Ref<InputEvent> &p_event, bool *p_pressed, float *p_strength, float p_deadzone) const; virtual bool action_match(const Ref<InputEvent> &p_event, bool *p_pressed, float *p_strength, float p_deadzone) const;
virtual bool shortcut_match(const Ref<InputEvent> &p_event) const; virtual bool shortcut_match(const Ref<InputEvent> &p_event) const;

View File

@ -1039,13 +1039,13 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_ENTER); key->set_keycode(KEY_ENTER);
events.push_back(key); events.push_back(key);
key.instance(); key.instance();
key->set_scancode(KEY_KP_ENTER); key->set_keycode(KEY_KP_ENTER);
events.push_back(key); events.push_back(key);
key.instance(); key.instance();
key->set_scancode(KEY_SPACE); key->set_keycode(KEY_SPACE);
events.push_back(key); events.push_back(key);
joyb.instance(); joyb.instance();
joyb->set_button_index(JOY_BUTTON_0); joyb->set_button_index(JOY_BUTTON_0);
@ -1058,7 +1058,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_SPACE); key->set_keycode(KEY_SPACE);
events.push_back(key); events.push_back(key);
joyb.instance(); joyb.instance();
joyb->set_button_index(JOY_BUTTON_3); joyb->set_button_index(JOY_BUTTON_3);
@ -1071,7 +1071,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_ESCAPE); key->set_keycode(KEY_ESCAPE);
events.push_back(key); events.push_back(key);
joyb.instance(); joyb.instance();
joyb->set_button_index(JOY_BUTTON_1); joyb->set_button_index(JOY_BUTTON_1);
@ -1084,7 +1084,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_TAB); key->set_keycode(KEY_TAB);
events.push_back(key); events.push_back(key);
action["events"] = events; action["events"] = events;
GLOBAL_DEF("input/ui_focus_next", action); GLOBAL_DEF("input/ui_focus_next", action);
@ -1094,7 +1094,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_TAB); key->set_keycode(KEY_TAB);
key->set_shift(true); key->set_shift(true);
events.push_back(key); events.push_back(key);
action["events"] = events; action["events"] = events;
@ -1105,7 +1105,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_LEFT); key->set_keycode(KEY_LEFT);
events.push_back(key); events.push_back(key);
joyb.instance(); joyb.instance();
joyb->set_button_index(JOY_DPAD_LEFT); joyb->set_button_index(JOY_DPAD_LEFT);
@ -1118,7 +1118,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_RIGHT); key->set_keycode(KEY_RIGHT);
events.push_back(key); events.push_back(key);
joyb.instance(); joyb.instance();
joyb->set_button_index(JOY_DPAD_RIGHT); joyb->set_button_index(JOY_DPAD_RIGHT);
@ -1131,7 +1131,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_UP); key->set_keycode(KEY_UP);
events.push_back(key); events.push_back(key);
joyb.instance(); joyb.instance();
joyb->set_button_index(JOY_DPAD_UP); joyb->set_button_index(JOY_DPAD_UP);
@ -1144,7 +1144,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_DOWN); key->set_keycode(KEY_DOWN);
events.push_back(key); events.push_back(key);
joyb.instance(); joyb.instance();
joyb->set_button_index(JOY_DPAD_DOWN); joyb->set_button_index(JOY_DPAD_DOWN);
@ -1157,7 +1157,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_PAGEUP); key->set_keycode(KEY_PAGEUP);
events.push_back(key); events.push_back(key);
action["events"] = events; action["events"] = events;
GLOBAL_DEF("input/ui_page_up", action); GLOBAL_DEF("input/ui_page_up", action);
@ -1167,7 +1167,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_PAGEDOWN); key->set_keycode(KEY_PAGEDOWN);
events.push_back(key); events.push_back(key);
action["events"] = events; action["events"] = events;
GLOBAL_DEF("input/ui_page_down", action); GLOBAL_DEF("input/ui_page_down", action);
@ -1177,7 +1177,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_HOME); key->set_keycode(KEY_HOME);
events.push_back(key); events.push_back(key);
action["events"] = events; action["events"] = events;
GLOBAL_DEF("input/ui_home", action); GLOBAL_DEF("input/ui_home", action);
@ -1187,7 +1187,7 @@ ProjectSettings::ProjectSettings() {
action["deadzone"] = Variant(0.5f); action["deadzone"] = Variant(0.5f);
events = Array(); events = Array();
key.instance(); key.instance();
key->set_scancode(KEY_END); key->set_keycode(KEY_END);
events.push_back(key); events.push_back(key);
action["events"] = events; action["events"] = events;
GLOBAL_DEF("input/ui_end", action); GLOBAL_DEF("input/ui_end", action);

View File

@ -4,7 +4,7 @@
Global scope constants and variables. Global scope constants and variables.
</brief_description> </brief_description>
<description> <description>
Global scope constants and variables. This is all that resides in the globals, constants regarding error codes, scancodes, property hints, etc. Global scope constants and variables. This is all that resides in the globals, constants regarding error codes, keycodes, property hints, etc.
Singletons are also documented here, since they can be accessed from anywhere. Singletons are also documented here, since they can be accessed from anywhere.
</description> </description>
<tutorials> <tutorials>
@ -146,7 +146,7 @@
Vertical bottom alignment, usually for text-derived classes. Vertical bottom alignment, usually for text-derived classes.
</constant> </constant>
<constant name="SPKEY" value="16777216"> <constant name="SPKEY" value="16777216">
Scancodes with this bit applied are non-printable. Keycodes with this bit applied are non-printable.
</constant> </constant>
<constant name="KEY_ESCAPE" value="16777217" enum="KeyList"> <constant name="KEY_ESCAPE" value="16777217" enum="KeyList">
Escape key. Escape key.

View File

@ -250,10 +250,10 @@
<method name="is_key_pressed" qualifiers="const"> <method name="is_key_pressed" qualifiers="const">
<return type="bool"> <return type="bool">
</return> </return>
<argument index="0" name="scancode" type="int"> <argument index="0" name="keycode" type="int">
</argument> </argument>
<description> <description>
Returns [code]true[/code] if you are pressing the key. You can pass a [enum KeyList] constant. Returns [code]true[/code] if you are pressing the key in the current keyboard layout. You can pass a [enum KeyList] constant.
</description> </description>
</method> </method>
<method name="is_mouse_button_pressed" qualifiers="const"> <method name="is_mouse_button_pressed" qualifiers="const">

View File

@ -10,12 +10,20 @@
<link>https://docs.godotengine.org/en/latest/tutorials/inputs/inputevent.html</link> <link>https://docs.godotengine.org/en/latest/tutorials/inputs/inputevent.html</link>
</tutorials> </tutorials>
<methods> <methods>
<method name="get_scancode_with_modifiers" qualifiers="const"> <method name="get_keycode_with_modifiers" qualifiers="const">
<return type="int"> <return type="int">
</return> </return>
<description> <description>
Returns the scancode combined with modifier keys such as [code]Shift[/code] or [code]Alt[/code]. See also [InputEventWithModifiers]. Returns the keycode combined with modifier keys such as [code]Shift[/code] or [code]Alt[/code]. See also [InputEventWithModifiers].
To get a human-readable representation of the [InputEventKey] with modifiers, use [code]OS.get_scancode_string(event.get_scancode_with_modifiers())[/code] where [code]event[/code] is the [InputEventKey]. To get a human-readable representation of the [InputEventKey] with modifiers, use [code]OS.get_keycode_string(event.get_keycode_with_modifiers())[/code] where [code]event[/code] is the [InputEventKey].
</description>
</method>
<method name="get_physical_keycode_with_modifiers" qualifiers="const">
<return type="int">
</return>
<description>
Returns the physical keycode combined with modifier keys such as [code]Shift[/code] or [code]Alt[/code]. See also [InputEventWithModifiers].
To get a human-readable representation of the [InputEventKey] with modifiers, use [code]OS.get_keycode_string(event.get_physical_keycode_with_modifiers())[/code] where [code]event[/code] is the [InputEventKey].
</description> </description>
</method> </method>
</methods> </methods>
@ -26,9 +34,13 @@
<member name="pressed" type="bool" setter="set_pressed" getter="is_pressed" default="false"> <member name="pressed" type="bool" setter="set_pressed" getter="is_pressed" default="false">
If [code]true[/code], the key's state is pressed. If [code]false[/code], the key's state is released. If [code]true[/code], the key's state is pressed. If [code]false[/code], the key's state is released.
</member> </member>
<member name="scancode" type="int" setter="set_scancode" getter="get_scancode" default="0"> <member name="keycode" type="int" setter="set_keycode" getter="get_keycode" default="0">
The key scancode, which corresponds to one of the [enum KeyList] constants. The key keycode, which corresponds to one of the [enum KeyList] constants. Represent key in the current keyboard layout.
To get a human-readable representation of the [InputEventKey], use [code]OS.get_scancode_string(event.scancode)[/code] where [code]event[/code] is the [InputEventKey]. To get a human-readable representation of the [InputEventKey], use [code]OS.get_keycode_string(event.keycode)[/code] where [code]event[/code] is the [InputEventKey].
</member>
<member name="physical_keycode" type="int" setter="set_physical_keycode" getter="get_physical_keycode" default="0">
Key physical keycode, which corresponds to one of the [enum KeyList] constants. Represent the physical location of a key on the 101/102-key US QWERTY keyboard.
To get a human-readable representation of the [InputEventKey], use [code]OS.get_keycode_string(event.keycode)[/code] where [code]event[/code] is the [InputEventKey].
</member> </member>
<member name="unicode" type="int" setter="set_unicode" getter="get_unicode" default="0"> <member name="unicode" type="int" setter="set_unicode" getter="get_unicode" default="0">
The key Unicode identifier (when relevant). Unicode identifiers for the composite characters and complex scripts may not be available unless IME input mode is active. See [method OS.set_ime_active] for more information. The key Unicode identifier (when relevant). Unicode identifiers for the composite characters and complex scripts may not be available unless IME input mode is active. See [method OS.set_ime_active] for more information.

View File

@ -26,9 +26,9 @@
func _input_event(event): func _input_event(event):
# Record keys. # Record keys.
if event is InputEventKey and event.pressed and !event.echo: if event is InputEventKey and event.pressed and !event.echo:
keys_typed.append(OS.get_scancode_string(event.scancode)) keys_typed.append(OS.get_keycode_string(event.keycode))
# Quit on Escape press. # Quit on Escape press.
if event.scancode == KEY_ESCAPE: if event.keycode == KEY_ESCAPE:
quit = true quit = true
# Quit on any mouse click. # Quit on any mouse click.
if event is InputEventMouseButton: if event is InputEventMouseButton:

View File

@ -124,13 +124,13 @@
[b]Note:[/b] This method is implemented on Android, iOS, Linux, macOS and Windows. [b]Note:[/b] This method is implemented on Android, iOS, Linux, macOS and Windows.
</description> </description>
</method> </method>
<method name="find_scancode_from_string" qualifiers="const"> <method name="find_keycode_from_string" qualifiers="const">
<return type="int"> <return type="int">
</return> </return>
<argument index="0" name="string" type="String"> <argument index="0" name="string" type="String">
</argument> </argument>
<description> <description>
Returns the scancode of the given string (e.g. "Escape"). Returns the keycode of the given string (e.g. "Escape").
</description> </description>
</method> </method>
<method name="get_audio_driver_count" qualifiers="const"> <method name="get_audio_driver_count" qualifiers="const">
@ -295,14 +295,14 @@
Returns the window size including decorations like window borders. Returns the window size including decorations like window borders.
</description> </description>
</method> </method>
<method name="get_scancode_string" qualifiers="const"> <method name="get_keycode_string" qualifiers="const">
<return type="String"> <return type="String">
</return> </return>
<argument index="0" name="code" type="int"> <argument index="0" name="code" type="int">
</argument> </argument>
<description> <description>
Returns the given scancode as a string (e.g. Return values: [code]"Escape"[/code], [code]"Shift+Escape"[/code]). Returns the given keycode as a string (e.g. Return values: [code]"Escape"[/code], [code]"Shift+Escape"[/code]).
See also [member InputEventKey.scancode] and [method InputEventKey.get_scancode_with_modifiers]. See also [member InputEventKey.keycode] and [method InputEventKey.get_keycode_with_modifiers].
</description> </description>
</method> </method>
<method name="get_screen_count" qualifiers="const"> <method name="get_screen_count" qualifiers="const">
@ -595,13 +595,13 @@
Returns [code]true[/code] if the [b]OK[/b] button should appear on the left and [b]Cancel[/b] on the right. Returns [code]true[/code] if the [b]OK[/b] button should appear on the left and [b]Cancel[/b] on the right.
</description> </description>
</method> </method>
<method name="is_scancode_unicode" qualifiers="const"> <method name="is_keycode_unicode" qualifiers="const">
<return type="bool"> <return type="bool">
</return> </return>
<argument index="0" name="code" type="int"> <argument index="0" name="code" type="int">
</argument> </argument>
<description> <description>
Returns [code]true[/code] if the input scancode corresponds to a Unicode character. Returns [code]true[/code] if the input keycode corresponds to a Unicode character.
</description> </description>
</method> </method>
<method name="is_stdout_verbose" qualifiers="const"> <method name="is_stdout_verbose" qualifiers="const">

View File

@ -122,7 +122,7 @@ void FindReplaceBar::_unhandled_input(const Ref<InputEvent> &p_event) {
bool accepted = true; bool accepted = true;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_ESCAPE: { case KEY_ESCAPE: {

View File

@ -127,10 +127,10 @@ void CreateDialog::_text_changed(const String &p_newtext) {
void CreateDialog::_sbox_input(const Ref<InputEvent> &p_ie) { void CreateDialog::_sbox_input(const Ref<InputEvent> &p_ie) {
Ref<InputEventKey> k = p_ie; Ref<InputEventKey> k = p_ie;
if (k.is_valid() && (k->get_scancode() == KEY_UP || if (k.is_valid() && (k->get_keycode() == KEY_UP ||
k->get_scancode() == KEY_DOWN || k->get_keycode() == KEY_DOWN ||
k->get_scancode() == KEY_PAGEUP || k->get_keycode() == KEY_PAGEUP ||
k->get_scancode() == KEY_PAGEDOWN)) { k->get_keycode() == KEY_PAGEDOWN)) {
search_options->call("_gui_input", k); search_options->call("_gui_input", k);
search_box->accept_event(); search_box->accept_event();

View File

@ -549,7 +549,7 @@ void EditorAudioBus::_effect_add(int p_which) {
void EditorAudioBus::_gui_input(const Ref<InputEvent> &p_event) { void EditorAudioBus::_gui_input(const Ref<InputEvent> &p_event) {
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (k.is_valid() && k->is_pressed() && k->get_scancode() == KEY_DELETE && !k->is_echo()) { if (k.is_valid() && k->is_pressed() && k->get_keycode() == KEY_DELETE && !k->is_echo()) {
accept_event(); accept_event();
emit_signal("delete_request"); emit_signal("delete_request");
} }

View File

@ -66,7 +66,7 @@ void EditorHelp::_unhandled_key_input(const Ref<InputEvent> &p_ev) {
Ref<InputEventKey> k = p_ev; Ref<InputEventKey> k = p_ev;
if (k.is_valid() && k->get_control() && k->get_scancode() == KEY_F) { if (k.is_valid() && k->get_control() && k->get_keycode() == KEY_F) {
search->grab_focus(); search->grab_focus();
search->select_all(); search->select_all();
@ -1803,7 +1803,7 @@ void FindBar::_unhandled_input(const Ref<InputEvent> &p_event) {
bool accepted = true; bool accepted = true;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_ESCAPE: { case KEY_ESCAPE: {

View File

@ -66,7 +66,7 @@ void EditorHelpSearch::_search_box_gui_input(const Ref<InputEvent> &p_event) {
// Redirect up and down navigational key events to the results list. // Redirect up and down navigational key events to the results list.
Ref<InputEventKey> key = p_event; Ref<InputEventKey> key = p_event;
if (key.is_valid()) { if (key.is_valid()) {
switch (key->get_scancode()) { switch (key->get_keycode()) {
case KEY_UP: case KEY_UP:
case KEY_DOWN: case KEY_DOWN:
case KEY_PAGEUP: case KEY_PAGEUP:

View File

@ -45,7 +45,7 @@ void EditorLayoutsDialog::_line_gui_input(const Ref<InputEvent> &p_event) {
if (!k->is_pressed()) if (!k->is_pressed())
return; return;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_KP_ENTER: case KEY_KP_ENTER:
case KEY_ENTER: { case KEY_ENTER: {

View File

@ -1531,7 +1531,7 @@ Ref<ShortCut> ED_SHORTCUT(const String &p_path, const String &p_name, uint32_t p
ie.instance(); ie.instance();
ie->set_unicode(p_keycode & KEY_CODE_MASK); ie->set_unicode(p_keycode & KEY_CODE_MASK);
ie->set_scancode(p_keycode & KEY_CODE_MASK); ie->set_keycode(p_keycode & KEY_CODE_MASK);
ie->set_shift(bool(p_keycode & KEY_MASK_SHIFT)); ie->set_shift(bool(p_keycode & KEY_MASK_SHIFT));
ie->set_alt(bool(p_keycode & KEY_MASK_ALT)); ie->set_alt(bool(p_keycode & KEY_MASK_ALT));
ie->set_control(bool(p_keycode & KEY_MASK_CTRL)); ie->set_control(bool(p_keycode & KEY_MASK_CTRL));

View File

@ -1 +1 @@
<svg height="16" viewBox="0 0 16 16" width="16" xmlns="http://www.w3.org/2000/svg"><g fill-opacity=".99608" transform="translate(0 -1036.4)"><path d="m4 2a1 1 0 0 0 -1 1v9.084a1 .91667 0 0 0 1 .91602h8a1 .91667 0 0 0 1-.91602v-9.084a1 1 0 0 0 -1-1zm-3 2v9a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2v-9h-1v9a.99998.99998 0 0 1 -1 1h-10a1 1 0 0 1 -1-1v-9zm4 0h2v3l2-3h2l-2 3 2 4h-2l-2-4v4h-2z" fill="#e0e0e0" transform="translate(0 1036.4)"/><path d="m27 1038.4h7v14h-7z" fill="#fff"/></g></svg> <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M4 2a1 1 0 0 0-1 1v9.084c0 .506.448.916 1 .916h8c.552 0 1-.41 1-.916V3a1 1 0 0 0-1-1H4zm1.543 1.139h1.393L8.77 7.338h1.295v.437c.708.052 1.246.239 1.61.559.368.316.55.747.55 1.295 0 .552-.182.99-.55 1.314-.368.32-.906.505-1.61.553v.467H8.771v-.473c-.708-.06-1.247-.248-1.615-.564-.364-.316-.545-.75-.545-1.297 0-.548.181-.977.545-1.29.368-.315.907-.504 1.615-.564v-.437H7.307l-.282-.733H5.43l-.284.733H3.707l1.836-4.2zm.684 1.39l-.409 1.057h.817l-.408-1.057zm3.84 4.338v1.526c.28-.04.483-.12.607-.24.124-.125.185-.302.185-.53 0-.224-.063-.396-.191-.516-.124-.12-.326-.2-.602-.24zm-1.296.006c-.284.04-.487.12-.61.24-.12.116-.182.288-.182.516 0 .22.065.392.193.512.132.12.331.202.6.246V8.873z" fill="#e0e0e0" fill-opacity=".996"/><path d="M27 2h7v14h-7z" fill="#fff" fill-opacity=".996"/><path fill="#e0e0e0" fill-opacity=".996" d="M1 4v9a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-1v9a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V4z"/></svg>

Before

Width:  |  Height:  |  Size: 481 B

After

Width:  |  Height:  |  Size: 988 B

View File

@ -0,0 +1 @@
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M4 2a1 1 0 0 0-1 1v9.084c0 .506.448.916 1 .916h8c.552 0 1-.41 1-.916V3a1 1 0 0 0-1-1zm2.762 1.768h2.476l3.264 7.464H9.898l-.502-1.3H6.561l-.502 1.3H3.498zm1.217 2.474L7.254 8.12h1.45z" fill="#e0e0e0" fill-opacity=".996"/><path d="M27 2h7v14h-7z" fill="#fff" fill-opacity=".996"/><path fill="#e0e0e0" fill-opacity=".996" d="M1 4v9a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V4h-1v9a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V4z"/></svg>

After

Width:  |  Height:  |  Size: 481 B

View File

@ -533,7 +533,7 @@ bool AbstractPolygon2DEditor::forward_gui_input(const Ref<InputEvent> &p_event)
if (k.is_valid() && k->is_pressed()) { if (k.is_valid() && k->is_pressed()) {
if (k->get_scancode() == KEY_DELETE || k->get_scancode() == KEY_BACKSPACE) { if (k->get_keycode() == KEY_DELETE || k->get_keycode() == KEY_BACKSPACE) {
if (wip_active && selected_point.polygon == -1) { if (wip_active && selected_point.polygon == -1) {
@ -555,10 +555,10 @@ bool AbstractPolygon2DEditor::forward_gui_input(const Ref<InputEvent> &p_event)
return true; return true;
} }
} }
} else if (wip_active && k->get_scancode() == KEY_ENTER) { } else if (wip_active && k->get_keycode() == KEY_ENTER) {
_wip_close(); _wip_close();
} else if (wip_active && k->get_scancode() == KEY_ESCAPE) { } else if (wip_active && k->get_keycode() == KEY_ESCAPE) {
_wip_cancel(); _wip_cancel();
} }
} }

View File

@ -42,7 +42,7 @@ StringName AnimationNodeBlendSpace1DEditor::get_blend_position_path() const {
void AnimationNodeBlendSpace1DEditor::_blend_space_gui_input(const Ref<InputEvent> &p_event) { void AnimationNodeBlendSpace1DEditor::_blend_space_gui_input(const Ref<InputEvent> &p_event) {
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (tool_select->is_pressed() && k.is_valid() && k->is_pressed() && k->get_scancode() == KEY_DELETE && !k->is_echo()) { if (tool_select->is_pressed() && k.is_valid() && k->is_pressed() && k->get_keycode() == KEY_DELETE && !k->is_echo()) {
if (selected_point != -1) { if (selected_point != -1) {
_erase_selected(); _erase_selected();
accept_event(); accept_event();

View File

@ -73,7 +73,7 @@ StringName AnimationNodeBlendSpace2DEditor::get_blend_position_path() const {
void AnimationNodeBlendSpace2DEditor::_blend_space_gui_input(const Ref<InputEvent> &p_event) { void AnimationNodeBlendSpace2DEditor::_blend_space_gui_input(const Ref<InputEvent> &p_event) {
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (tool_select->is_pressed() && k.is_valid() && k->is_pressed() && k->get_scancode() == KEY_DELETE && !k->is_echo()) { if (tool_select->is_pressed() && k.is_valid() && k->is_pressed() && k->get_keycode() == KEY_DELETE && !k->is_echo()) {
if (selected_point != -1 || selected_triangle != -1) { if (selected_point != -1 || selected_triangle != -1) {
_erase_selected(); _erase_selected();
accept_event(); accept_event();

View File

@ -1268,7 +1268,7 @@ void AnimationPlayerEditor::_unhandled_key_input(const Ref<InputEvent> &p_ev) {
Ref<InputEventKey> k = p_ev; Ref<InputEventKey> k = p_ev;
if (is_visible_in_tree() && k.is_valid() && k->is_pressed() && !k->is_echo() && !k->get_alt() && !k->get_control() && !k->get_metakey()) { if (is_visible_in_tree() && k.is_valid() && k->is_pressed() && !k->is_echo() && !k->get_alt() && !k->get_control() && !k->get_metakey()) {
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_A: { case KEY_A: {
if (!k->get_shift()) if (!k->get_shift())

View File

@ -69,7 +69,7 @@ void AnimationNodeStateMachineEditor::_state_machine_gui_input(const Ref<InputEv
return; return;
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (tool_select->is_pressed() && k.is_valid() && k->is_pressed() && k->get_scancode() == KEY_DELETE && !k->is_echo()) { if (tool_select->is_pressed() && k.is_valid() && k->is_pressed() && k->get_keycode() == KEY_DELETE && !k->is_echo()) {
if (selected_node != StringName() || selected_transition_to != StringName() || selected_transition_from != StringName()) { if (selected_node != StringName() || selected_transition_to != StringName() || selected_transition_from != StringName()) {
_erase_selected(); _erase_selected();
accept_event(); accept_event();

View File

@ -617,7 +617,7 @@ void EditorAssetLibrary::_unhandled_input(const Ref<InputEvent> &p_event) {
if (key.is_valid() && key->is_pressed()) { if (key.is_valid() && key->is_pressed()) {
if (key->get_scancode_with_modifiers() == (KEY_MASK_CMD | KEY_F) && is_visible_in_tree()) { if (key->get_keycode_with_modifiers() == (KEY_MASK_CMD | KEY_F) && is_visible_in_tree()) {
filter->grab_focus(); filter->grab_focus();
filter->select_all(); filter->select_all();

View File

@ -472,7 +472,7 @@ void CanvasItemEditor::_unhandled_key_input(const Ref<InputEvent> &p_ev) {
if (!is_visible_in_tree() || get_viewport()->gui_has_modal_stack()) if (!is_visible_in_tree() || get_viewport()->gui_has_modal_stack())
return; return;
if (k->get_scancode() == KEY_CONTROL || k->get_scancode() == KEY_ALT || k->get_scancode() == KEY_SHIFT) { if (k->get_keycode() == KEY_CONTROL || k->get_keycode() == KEY_ALT || k->get_keycode() == KEY_SHIFT) {
viewport->update(); viewport->update();
} }
@ -1315,7 +1315,7 @@ bool CanvasItemEditor::_gui_input_pivot(const Ref<InputEvent> &p_event) {
// Drag the pivot (in pivot mode / with V key) // Drag the pivot (in pivot mode / with V key)
if (drag_type == DRAG_NONE) { if (drag_type == DRAG_NONE) {
if ((b.is_valid() && b->is_pressed() && b->get_button_index() == BUTTON_LEFT && tool == TOOL_EDIT_PIVOT) || if ((b.is_valid() && b->is_pressed() && b->get_button_index() == BUTTON_LEFT && tool == TOOL_EDIT_PIVOT) ||
(k.is_valid() && k->is_pressed() && !k->is_echo() && k->get_scancode() == KEY_V)) { (k.is_valid() && k->is_pressed() && !k->is_echo() && k->get_keycode() == KEY_V)) {
List<CanvasItem *> selection = _get_edited_canvas_items(); List<CanvasItem *> selection = _get_edited_canvas_items();
// Filters the selection with nodes that allow setting the pivot // Filters the selection with nodes that allow setting the pivot
@ -1367,7 +1367,7 @@ bool CanvasItemEditor::_gui_input_pivot(const Ref<InputEvent> &p_event) {
// Confirm the pivot move // Confirm the pivot move
if ((b.is_valid() && !b->is_pressed() && b->get_button_index() == BUTTON_LEFT && tool == TOOL_EDIT_PIVOT) || if ((b.is_valid() && !b->is_pressed() && b->get_button_index() == BUTTON_LEFT && tool == TOOL_EDIT_PIVOT) ||
(k.is_valid() && !k->is_pressed() && k->get_scancode() == KEY_V)) { (k.is_valid() && !k->is_pressed() && k->get_keycode() == KEY_V)) {
_commit_canvas_item_state(drag_selection, TTR("Move pivot")); _commit_canvas_item_state(drag_selection, TTR("Move pivot"));
drag_type = DRAG_NONE; drag_type = DRAG_NONE;
return true; return true;
@ -2109,7 +2109,7 @@ bool CanvasItemEditor::_gui_input_move(const Ref<InputEvent> &p_event) {
// Move the canvas items with the arrow keys // Move the canvas items with the arrow keys
if (k.is_valid() && k->is_pressed() && (tool == TOOL_SELECT || tool == TOOL_MOVE) && if (k.is_valid() && k->is_pressed() && (tool == TOOL_SELECT || tool == TOOL_MOVE) &&
(k->get_scancode() == KEY_UP || k->get_scancode() == KEY_DOWN || k->get_scancode() == KEY_LEFT || k->get_scancode() == KEY_RIGHT)) { (k->get_keycode() == KEY_UP || k->get_keycode() == KEY_DOWN || k->get_keycode() == KEY_LEFT || k->get_keycode() == KEY_RIGHT)) {
if (!k->is_echo()) { if (!k->is_echo()) {
// Start moving the canvas items with the keyboard // Start moving the canvas items with the keyboard
drag_selection = _get_edited_canvas_items(); drag_selection = _get_edited_canvas_items();
@ -2135,13 +2135,13 @@ bool CanvasItemEditor::_gui_input_move(const Ref<InputEvent> &p_event) {
bool move_local_base_rotated = k->get_control() || k->get_metakey(); bool move_local_base_rotated = k->get_control() || k->get_metakey();
Vector2 dir; Vector2 dir;
if (k->get_scancode() == KEY_UP) if (k->get_keycode() == KEY_UP)
dir += Vector2(0, -1); dir += Vector2(0, -1);
else if (k->get_scancode() == KEY_DOWN) else if (k->get_keycode() == KEY_DOWN)
dir += Vector2(0, 1); dir += Vector2(0, 1);
else if (k->get_scancode() == KEY_LEFT) else if (k->get_keycode() == KEY_LEFT)
dir += Vector2(-1, 0); dir += Vector2(-1, 0);
else if (k->get_scancode() == KEY_RIGHT) else if (k->get_keycode() == KEY_RIGHT)
dir += Vector2(1, 0); dir += Vector2(1, 0);
if (k->get_shift()) if (k->get_shift())
dir *= grid_step * Math::pow(2.0, grid_step_multiplier); dir *= grid_step * Math::pow(2.0, grid_step_multiplier);
@ -2197,7 +2197,7 @@ bool CanvasItemEditor::_gui_input_move(const Ref<InputEvent> &p_event) {
} }
if (k.is_valid() && !k->is_pressed() && drag_type == DRAG_KEY_MOVE && tool == TOOL_SELECT && if (k.is_valid() && !k->is_pressed() && drag_type == DRAG_KEY_MOVE && tool == TOOL_SELECT &&
(k->get_scancode() == KEY_UP || k->get_scancode() == KEY_DOWN || k->get_scancode() == KEY_LEFT || k->get_scancode() == KEY_RIGHT)) { (k->get_keycode() == KEY_UP || k->get_keycode() == KEY_DOWN || k->get_keycode() == KEY_LEFT || k->get_keycode() == KEY_RIGHT)) {
// Confirm canvas items move by arrow keys // Confirm canvas items move by arrow keys
if ((!Input::get_singleton()->is_key_pressed(KEY_UP)) && if ((!Input::get_singleton()->is_key_pressed(KEY_UP)) &&
(!Input::get_singleton()->is_key_pressed(KEY_DOWN)) && (!Input::get_singleton()->is_key_pressed(KEY_DOWN)) &&
@ -2210,7 +2210,7 @@ bool CanvasItemEditor::_gui_input_move(const Ref<InputEvent> &p_event) {
return true; return true;
} }
return (k.is_valid() && (k->get_scancode() == KEY_UP || k->get_scancode() == KEY_DOWN || k->get_scancode() == KEY_LEFT || k->get_scancode() == KEY_RIGHT)); // Accept the key event in any case return (k.is_valid() && (k->get_keycode() == KEY_UP || k->get_keycode() == KEY_DOWN || k->get_keycode() == KEY_LEFT || k->get_keycode() == KEY_RIGHT)); // Accept the key event in any case
} }
bool CanvasItemEditor::_gui_input_select(const Ref<InputEvent> &p_event) { bool CanvasItemEditor::_gui_input_select(const Ref<InputEvent> &p_event) {
@ -2387,7 +2387,7 @@ bool CanvasItemEditor::_gui_input_select(const Ref<InputEvent> &p_event) {
} }
} }
if (k.is_valid() && k->is_pressed() && k->get_scancode() == KEY_ESCAPE && drag_type == DRAG_NONE && tool == TOOL_SELECT) { if (k.is_valid() && k->is_pressed() && k->get_keycode() == KEY_ESCAPE && drag_type == DRAG_NONE && tool == TOOL_SELECT) {
// Unselect everything // Unselect everything
editor_selection->clear(); editor_selection->clear();
viewport->update(); viewport->update();

View File

@ -238,7 +238,7 @@ void CurveEditor::on_gui_input(const Ref<InputEvent> &p_event) {
const InputEventKey &key = **key_ref; const InputEventKey &key = **key_ref;
if (key.is_pressed() && _selected_point != -1) { if (key.is_pressed() && _selected_point != -1) {
if (key.get_scancode() == KEY_DELETE) if (key.get_keycode() == KEY_DELETE)
remove_point(_selected_point); remove_point(_selected_point);
} }
} }

View File

@ -166,10 +166,10 @@ void ScriptEditorQuickOpen::_sbox_input(const Ref<InputEvent> &p_ie) {
Ref<InputEventKey> k = p_ie; Ref<InputEventKey> k = p_ie;
if (k.is_valid() && (k->get_scancode() == KEY_UP || if (k.is_valid() && (k->get_keycode() == KEY_UP ||
k->get_scancode() == KEY_DOWN || k->get_keycode() == KEY_DOWN ||
k->get_scancode() == KEY_PAGEUP || k->get_keycode() == KEY_PAGEUP ||
k->get_scancode() == KEY_PAGEDOWN)) { k->get_keycode() == KEY_PAGEDOWN)) {
search_options->call("_gui_input", k); search_options->call("_gui_input", k);
search_box->accept_event(); search_box->accept_event();

View File

@ -1600,7 +1600,7 @@ void ScriptTextEditor::_text_edit_gui_input(const Ref<InputEvent> &ev) {
if (mb.is_valid() && mb->get_button_index() == BUTTON_RIGHT && mb->is_pressed()) { if (mb.is_valid() && mb->get_button_index() == BUTTON_RIGHT && mb->is_pressed()) {
local_pos = mb->get_global_position() - tx->get_global_position(); local_pos = mb->get_global_position() - tx->get_global_position();
create_menu = true; create_menu = true;
} else if (k.is_valid() && k->get_scancode() == KEY_MENU) { } else if (k.is_valid() && k->get_keycode() == KEY_MENU) {
local_pos = tx->_get_cursor_pixel_pos(); local_pos = tx->_get_cursor_pixel_pos();
create_menu = true; create_menu = true;
} }

View File

@ -522,7 +522,7 @@ void ShaderEditor::_text_edit_gui_input(const Ref<InputEvent> &ev) {
} }
Ref<InputEventKey> k = ev; Ref<InputEventKey> k = ev;
if (k.is_valid() && k->is_pressed() && k->get_scancode() == KEY_MENU) { if (k.is_valid() && k->is_pressed() && k->get_keycode() == KEY_MENU) {
TextEdit *tx = shader_editor->get_text_edit(); TextEdit *tx = shader_editor->get_text_edit();
_make_context_menu(tx->is_selection_active(), (get_global_transform().inverse() * tx->get_global_transform()).xform(tx->_get_cursor_pixel_pos())); _make_context_menu(tx->is_selection_active(), (get_global_transform().inverse() * tx->get_global_transform()).xform(tx->_get_cursor_pixel_pos()));
context_menu->grab_focus(); context_menu->grab_focus();

View File

@ -1873,11 +1873,11 @@ void SpatialEditorViewport::_sinput(const Ref<InputEvent> &p_event) {
if (!orthogonal && ED_IS_SHORTCUT("spatial_editor/freelook_toggle", p_event)) { if (!orthogonal && ED_IS_SHORTCUT("spatial_editor/freelook_toggle", p_event)) {
set_freelook_active(!is_freelook_active()); set_freelook_active(!is_freelook_active());
} else if (k->get_scancode() == KEY_ESCAPE) { } else if (k->get_keycode() == KEY_ESCAPE) {
set_freelook_active(false); set_freelook_active(false);
} }
if (k->get_scancode() == KEY_SPACE) { if (k->get_keycode() == KEY_SPACE) {
if (!k->is_pressed()) emit_signal("toggle_maximize_view", this); if (!k->is_pressed()) emit_signal("toggle_maximize_view", this);
} }
} }
@ -2074,8 +2074,8 @@ static bool is_shortcut_pressed(const String &p_path) {
return false; return false;
} }
const Input &input = *Input::get_singleton(); const Input &input = *Input::get_singleton();
int scancode = k->get_scancode(); int keycode = k->get_keycode();
return input.is_key_pressed(scancode); return input.is_key_pressed(keycode);
} }
void SpatialEditorViewport::_update_freelook(real_t delta) { void SpatialEditorViewport::_update_freelook(real_t delta) {

View File

@ -582,7 +582,7 @@ void TextEditor::_text_edit_gui_input(const Ref<InputEvent> &ev) {
} }
Ref<InputEventKey> k = ev; Ref<InputEventKey> k = ev;
if (k.is_valid() && k->is_pressed() && k->get_scancode() == KEY_MENU) { if (k.is_valid() && k->is_pressed() && k->get_keycode() == KEY_MENU) {
TextEdit *tx = code_editor->get_text_edit(); TextEdit *tx = code_editor->get_text_edit();
int line = tx->cursor_get_line(); int line = tx->cursor_get_line();
_make_context_menu(tx->is_selection_active(), tx->can_fold(line), tx->is_folded(line), (get_global_transform().inverse() * tx->get_global_transform()).xform(tx->_get_cursor_pixel_pos())); _make_context_menu(tx->is_selection_active(), tx->can_fold(line), tx->is_folded(line), (get_global_transform().inverse() * tx->get_global_transform()).xform(tx->_get_cursor_pixel_pos()));

View File

@ -359,10 +359,10 @@ void TileMapEditor::_sbox_input(const Ref<InputEvent> &p_ie) {
Ref<InputEventKey> k = p_ie; Ref<InputEventKey> k = p_ie;
if (k.is_valid() && (k->get_scancode() == KEY_UP || if (k.is_valid() && (k->get_keycode() == KEY_UP ||
k->get_scancode() == KEY_DOWN || k->get_keycode() == KEY_DOWN ||
k->get_scancode() == KEY_PAGEUP || k->get_keycode() == KEY_PAGEUP ||
k->get_scancode() == KEY_PAGEDOWN)) { k->get_keycode() == KEY_PAGEDOWN)) {
palette->call("_gui_input", k); palette->call("_gui_input", k);
search_box->accept_event(); search_box->accept_event();
@ -1377,7 +1377,7 @@ bool TileMapEditor::forward_gui_input(const Ref<InputEvent> &p_event) {
if (k.is_valid() && k->is_pressed()) { if (k.is_valid() && k->is_pressed()) {
if (last_tool == TOOL_NONE && tool == TOOL_PICKING && k->get_scancode() == KEY_SHIFT && k->get_command()) { if (last_tool == TOOL_NONE && tool == TOOL_PICKING && k->get_keycode() == KEY_SHIFT && k->get_command()) {
// trying to draw a rectangle with the painting tool, so change to the correct tool // trying to draw a rectangle with the painting tool, so change to the correct tool
tool = last_tool; tool = last_tool;
@ -1385,7 +1385,7 @@ bool TileMapEditor::forward_gui_input(const Ref<InputEvent> &p_event) {
_update_button_tool(); _update_button_tool();
} }
if (k->get_scancode() == KEY_ESCAPE) { if (k->get_keycode() == KEY_ESCAPE) {
if (tool == TOOL_PASTING) if (tool == TOOL_PASTING)
copydata.clear(); copydata.clear();
@ -1506,7 +1506,7 @@ bool TileMapEditor::forward_gui_input(const Ref<InputEvent> &p_event) {
if (tool == TOOL_NONE) { if (tool == TOOL_NONE) {
if (k->get_scancode() == KEY_SHIFT && k->get_command()) { if (k->get_keycode() == KEY_SHIFT && k->get_command()) {
tool = TOOL_PICKING; tool = TOOL_PICKING;
_update_button_tool(); _update_button_tool();
@ -1514,9 +1514,9 @@ bool TileMapEditor::forward_gui_input(const Ref<InputEvent> &p_event) {
} else if (tool == TOOL_PICKING) { } else if (tool == TOOL_PICKING) {
#ifdef APPLE_STYLE_KEYS #ifdef APPLE_STYLE_KEYS
if (k->get_scancode() == KEY_META) { if (k->get_keycode() == KEY_META) {
#else #else
if (k->get_scancode() == KEY_CONTROL) { if (k->get_keycode() == KEY_CONTROL) {
#endif #endif
// Go back to that last tool if KEY_CONTROL was released. // Go back to that last tool if KEY_CONTROL was released.
tool = last_tool; tool = last_tool;

View File

@ -1663,10 +1663,10 @@ void VisualShaderEditor::_show_members_dialog(bool at_mouse_pos) {
void VisualShaderEditor::_sbox_input(const Ref<InputEvent> &p_ie) { void VisualShaderEditor::_sbox_input(const Ref<InputEvent> &p_ie) {
Ref<InputEventKey> ie = p_ie; Ref<InputEventKey> ie = p_ie;
if (ie.is_valid() && (ie->get_scancode() == KEY_UP || if (ie.is_valid() && (ie->get_keycode() == KEY_UP ||
ie->get_scancode() == KEY_DOWN || ie->get_keycode() == KEY_DOWN ||
ie->get_scancode() == KEY_ENTER || ie->get_keycode() == KEY_ENTER ||
ie->get_scancode() == KEY_KP_ENTER)) { ie->get_keycode() == KEY_KP_ENTER)) {
members->call("_gui_input", ie); members->call("_gui_input", ie);
node_filter->accept_event(); node_filter->accept_event();

View File

@ -1899,7 +1899,7 @@ void ProjectManager::_unhandled_input(const Ref<InputEvent> &p_ev) {
// This is handled by the platform implementation on macOS, // This is handled by the platform implementation on macOS,
// so only define the shortcut on other platforms // so only define the shortcut on other platforms
#ifndef OSX_ENABLED #ifndef OSX_ENABLED
if (k->get_scancode_with_modifiers() == (KEY_MASK_CMD | KEY_Q)) { if (k->get_keycode_with_modifiers() == (KEY_MASK_CMD | KEY_Q)) {
_dim_window(); _dim_window();
get_tree()->quit(); get_tree()->quit();
} }
@ -1908,9 +1908,9 @@ void ProjectManager::_unhandled_input(const Ref<InputEvent> &p_ev) {
if (tabs->get_current_tab() != 0) if (tabs->get_current_tab() != 0)
return; return;
bool scancode_handled = true; bool keycode_handled = true;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_ENTER: { case KEY_ENTER: {
@ -1967,14 +1967,14 @@ void ProjectManager::_unhandled_input(const Ref<InputEvent> &p_ev) {
if (k->get_command()) if (k->get_command())
this->project_filter->search_box->grab_focus(); this->project_filter->search_box->grab_focus();
else else
scancode_handled = false; keycode_handled = false;
} break; } break;
default: { default: {
scancode_handled = false; keycode_handled = false;
} break; } break;
} }
if (scancode_handled) { if (keycode_handled) {
accept_event(); accept_event();
} }
} }

View File

@ -82,7 +82,7 @@ void ProjectSettingsEditor::_unhandled_input(const Ref<InputEvent> &p_event) {
if (k.is_valid() && is_window_modal_on_top() && k->is_pressed()) { if (k.is_valid() && is_window_modal_on_top() && k->is_pressed()) {
if (k->get_scancode_with_modifiers() == (KEY_MASK_CMD | KEY_F)) { if (k->get_keycode_with_modifiers() == (KEY_MASK_CMD | KEY_F)) {
if (search_button->is_pressed()) { if (search_button->is_pressed()) {
search_box->grab_focus(); search_box->grab_focus();
search_box->select_all(); search_box->select_all();
@ -110,7 +110,8 @@ void ProjectSettingsEditor::_notification(int p_what) {
translation_list->connect("button_pressed", callable_mp(this, &ProjectSettingsEditor::_translation_delete)); translation_list->connect("button_pressed", callable_mp(this, &ProjectSettingsEditor::_translation_delete));
_update_actions(); _update_actions();
popup_add->add_icon_item(get_icon("Keyboard", "EditorIcons"), TTR("Key "), INPUT_KEY); //"Key " - because the word 'key' has already been used as a key animation popup_add->add_icon_item(get_icon("Keyboard", "EditorIcons"), TTR("Key"), INPUT_KEY); //"Key " - because the word 'key' has already been used as a key animation
popup_add->add_icon_item(get_icon("KeyboardPhysical", "EditorIcons"), TTR("Physical Key"), INPUT_KEY_PHYSICAL);
popup_add->add_icon_item(get_icon("JoyButton", "EditorIcons"), TTR("Joy Button"), INPUT_JOY_BUTTON); popup_add->add_icon_item(get_icon("JoyButton", "EditorIcons"), TTR("Joy Button"), INPUT_JOY_BUTTON);
popup_add->add_icon_item(get_icon("JoyAxis", "EditorIcons"), TTR("Joy Axis"), INPUT_JOY_MOTION); popup_add->add_icon_item(get_icon("JoyAxis", "EditorIcons"), TTR("Joy Axis"), INPUT_JOY_MOTION);
popup_add->add_icon_item(get_icon("Mouse", "EditorIcons"), TTR("Mouse Button"), INPUT_MOUSE_BUTTON); popup_add->add_icon_item(get_icon("Mouse", "EditorIcons"), TTR("Mouse Button"), INPUT_MOUSE_BUTTON);
@ -146,6 +147,7 @@ void ProjectSettingsEditor::_notification(int p_what) {
search_box->set_clear_button_enabled(true); search_box->set_clear_button_enabled(true);
action_add_error->add_color_override("font_color", get_color("error_color", "Editor")); action_add_error->add_color_override("font_color", get_color("error_color", "Editor"));
popup_add->set_item_icon(popup_add->get_item_index(INPUT_KEY), get_icon("Keyboard", "EditorIcons")); popup_add->set_item_icon(popup_add->get_item_index(INPUT_KEY), get_icon("Keyboard", "EditorIcons"));
popup_add->set_item_icon(popup_add->get_item_index(INPUT_KEY_PHYSICAL), get_icon("KeyboardPhysical", "EditorIcons"));
popup_add->set_item_icon(popup_add->get_item_index(INPUT_JOY_BUTTON), get_icon("JoyButton", "EditorIcons")); popup_add->set_item_icon(popup_add->get_item_index(INPUT_JOY_BUTTON), get_icon("JoyButton", "EditorIcons"));
popup_add->set_item_icon(popup_add->get_item_index(INPUT_JOY_MOTION), get_icon("JoyAxis", "EditorIcons")); popup_add->set_item_icon(popup_add->get_item_index(INPUT_JOY_MOTION), get_icon("JoyAxis", "EditorIcons"));
popup_add->set_item_icon(popup_add->get_item_index(INPUT_MOUSE_BUTTON), get_icon("Mouse", "EditorIcons")); popup_add->set_item_icon(popup_add->get_item_index(INPUT_MOUSE_BUTTON), get_icon("Mouse", "EditorIcons"));
@ -361,7 +363,13 @@ void ProjectSettingsEditor::_press_a_key_confirm() {
Ref<InputEventKey> ie; Ref<InputEventKey> ie;
ie.instance(); ie.instance();
ie->set_scancode(last_wait_for_key->get_scancode()); if (press_a_key_physical) {
ie->set_physical_keycode(last_wait_for_key->get_physical_keycode());
ie->set_keycode(0);
} else {
ie->set_physical_keycode(0);
ie->set_keycode(last_wait_for_key->get_keycode());
}
ie->set_shift(last_wait_for_key->get_shift()); ie->set_shift(last_wait_for_key->get_shift());
ie->set_alt(last_wait_for_key->get_alt()); ie->set_alt(last_wait_for_key->get_alt());
ie->set_control(last_wait_for_key->get_control()); ie->set_control(last_wait_for_key->get_control());
@ -379,8 +387,14 @@ void ProjectSettingsEditor::_press_a_key_confirm() {
Ref<InputEventKey> aie = events[i]; Ref<InputEventKey> aie = events[i];
if (aie.is_null()) if (aie.is_null())
continue; continue;
if (aie->get_scancode_with_modifiers() == ie->get_scancode_with_modifiers()) { if (!press_a_key_physical) {
return; if (aie->get_keycode_with_modifiers() == ie->get_keycode_with_modifiers()) {
return;
}
} else {
if (aie->get_physical_keycode_with_modifiers() == ie->get_physical_keycode_with_modifiers()) {
return;
}
} }
} }
@ -441,10 +455,10 @@ void ProjectSettingsEditor::_wait_for_key(const Ref<InputEvent> &p_event) {
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (k.is_valid() && k->is_pressed() && k->get_scancode() != 0) { if (k.is_valid() && k->is_pressed() && k->get_keycode() != 0) {
last_wait_for_key = p_event; last_wait_for_key = p_event;
const String str = keycode_get_string(k->get_scancode_with_modifiers()); const String str = (press_a_key_physical) ? keycode_get_string(k->get_physical_keycode_with_modifiers()) + TTR(" (Physical)") : keycode_get_string(k->get_keycode_with_modifiers());
press_a_key_label->set_text(str); press_a_key_label->set_text(str);
press_a_key->get_ok()->set_disabled(false); press_a_key->get_ok()->set_disabled(false);
@ -460,12 +474,23 @@ void ProjectSettingsEditor::_add_item(int p_item, Ref<InputEvent> p_exiting_even
case INPUT_KEY: { case INPUT_KEY: {
press_a_key_physical = false;
press_a_key_label->set_text(TTR("Press a Key...")); press_a_key_label->set_text(TTR("Press a Key..."));
press_a_key->get_ok()->set_disabled(true); press_a_key->get_ok()->set_disabled(true);
last_wait_for_key = Ref<InputEvent>(); last_wait_for_key = Ref<InputEvent>();
press_a_key->popup_centered(Size2(250, 80) * EDSCALE); press_a_key->popup_centered(Size2(250, 80) * EDSCALE);
press_a_key->grab_focus(); press_a_key->grab_focus();
} break;
case INPUT_KEY_PHYSICAL: {
press_a_key_physical = true;
press_a_key_label->set_text(TTR("Press a Key..."));
last_wait_for_key = Ref<InputEvent>();
press_a_key->popup_centered(Size2(250, 80) * EDSCALE);
press_a_key->grab_focus();
} break; } break;
case INPUT_MOUSE_BUTTON: { case INPUT_MOUSE_BUTTON: {
@ -547,7 +572,11 @@ void ProjectSettingsEditor::_edit_item(Ref<InputEvent> p_exiting_event) {
InputType ie_type; InputType ie_type;
if ((Ref<InputEventKey>(p_exiting_event)).is_valid()) { if ((Ref<InputEventKey>(p_exiting_event)).is_valid()) {
ie_type = INPUT_KEY; if ((Ref<InputEventKey>(p_exiting_event))->get_keycode() != 0) {
ie_type = INPUT_KEY;
} else {
ie_type = INPUT_KEY_PHYSICAL;
}
} else if ((Ref<InputEventJoypadButton>(p_exiting_event)).is_valid()) { } else if ((Ref<InputEventJoypadButton>(p_exiting_event)).is_valid()) {
ie_type = INPUT_JOY_BUTTON; ie_type = INPUT_JOY_BUTTON;
@ -745,10 +774,14 @@ void ProjectSettingsEditor::_update_actions() {
Ref<InputEventKey> k = event; Ref<InputEventKey> k = event;
if (k.is_valid()) { if (k.is_valid()) {
const String str = keycode_get_string(k->get_scancode_with_modifiers()); const String str = (k->get_keycode() == 0) ? keycode_get_string(k->get_physical_keycode_with_modifiers()) + TTR(" (Physical)") : keycode_get_string(k->get_keycode_with_modifiers());
action2->set_text(0, str); action2->set_text(0, str);
action2->set_icon(0, get_icon("Keyboard", "EditorIcons")); if ((k->get_keycode() != 0)) {
action2->set_icon(0, get_icon("Keyboard", "EditorIcons"));
} else {
action2->set_icon(0, get_icon("KeyboardPhysical", "EditorIcons"));
}
} }
Ref<InputEventJoypadButton> jb = event; Ref<InputEventJoypadButton> jb = event;
@ -1924,6 +1957,8 @@ ProjectSettingsEditor::ProjectSettingsEditor(EditorData *p_data) {
add_child(popup_add); add_child(popup_add);
popup_add->connect("id_pressed", callable_mp(this, &ProjectSettingsEditor::_add_item), make_binds(Ref<InputEvent>())); popup_add->connect("id_pressed", callable_mp(this, &ProjectSettingsEditor::_add_item), make_binds(Ref<InputEvent>()));
press_a_key_physical = false;
press_a_key = memnew(ConfirmationDialog); press_a_key = memnew(ConfirmationDialog);
press_a_key->set_focus_mode(FOCUS_ALL); press_a_key->set_focus_mode(FOCUS_ALL);
add_child(press_a_key); add_child(press_a_key);

View File

@ -45,6 +45,7 @@ class ProjectSettingsEditor : public AcceptDialog {
enum InputType { enum InputType {
INPUT_KEY, INPUT_KEY,
INPUT_KEY_PHYSICAL,
INPUT_JOY_BUTTON, INPUT_JOY_BUTTON,
INPUT_JOY_MOTION, INPUT_JOY_MOTION,
INPUT_MOUSE_BUTTON INPUT_MOUSE_BUTTON
@ -77,6 +78,7 @@ class ProjectSettingsEditor : public AcceptDialog {
OptionButton *type; OptionButton *type;
PopupMenu *popup_add; PopupMenu *popup_add;
ConfirmationDialog *press_a_key; ConfirmationDialog *press_a_key;
bool press_a_key_physical;
Label *press_a_key_label; Label *press_a_key_label;
ConfirmationDialog *device_input; ConfirmationDialog *device_input;
OptionButton *device_id; OptionButton *device_id;

View File

@ -45,7 +45,7 @@ void PropertySelector::_sbox_input(const Ref<InputEvent> &p_ie) {
if (k.is_valid()) { if (k.is_valid()) {
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_UP: case KEY_UP:
case KEY_DOWN: case KEY_DOWN:
case KEY_PAGEUP: case KEY_PAGEUP:

View File

@ -83,7 +83,7 @@ void EditorQuickOpen::_sbox_input(const Ref<InputEvent> &p_ie) {
Ref<InputEventKey> k = p_ie; Ref<InputEventKey> k = p_ie;
if (k.is_valid()) { if (k.is_valid()) {
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_UP: case KEY_UP:
case KEY_DOWN: case KEY_DOWN:
case KEY_PAGEUP: case KEY_PAGEUP:

View File

@ -163,7 +163,7 @@ void EditorSettingsDialog::_unhandled_input(const Ref<InputEvent> &p_event) {
handled = true; handled = true;
} }
if (k->get_scancode_with_modifiers() == (KEY_MASK_CMD | KEY_F)) { if (k->get_keycode_with_modifiers() == (KEY_MASK_CMD | KEY_F)) {
_focus_current_search_box(); _focus_current_search_box();
handled = true; handled = true;
} }
@ -317,10 +317,10 @@ void EditorSettingsDialog::_wait_for_key(const Ref<InputEvent> &p_event) {
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (k.is_valid() && k->is_pressed() && k->get_scancode() != 0) { if (k.is_valid() && k->is_pressed() && k->get_keycode() != 0) {
last_wait_for_key = k; last_wait_for_key = k;
const String str = keycode_get_string(k->get_scancode_with_modifiers()); const String str = keycode_get_string(k->get_keycode_with_modifiers());
press_a_key_label->set_text(str); press_a_key_label->set_text(str);
press_a_key->accept_event(); press_a_key->accept_event();
@ -334,7 +334,7 @@ void EditorSettingsDialog::_press_a_key_confirm() {
Ref<InputEventKey> ie; Ref<InputEventKey> ie;
ie.instance(); ie.instance();
ie->set_scancode(last_wait_for_key->get_scancode()); ie->set_keycode(last_wait_for_key->get_keycode());
ie->set_shift(last_wait_for_key->get_shift()); ie->set_shift(last_wait_for_key->get_shift());
ie->set_control(last_wait_for_key->get_control()); ie->set_control(last_wait_for_key->get_control());
ie->set_alt(last_wait_for_key->get_alt()); ie->set_alt(last_wait_for_key->get_alt());

View File

@ -73,10 +73,10 @@ InputDefault::SpeedTrack::SpeedTrack() {
reset(); reset();
} }
bool InputDefault::is_key_pressed(int p_scancode) const { bool InputDefault::is_key_pressed(int p_keycode) const {
_THREAD_SAFE_METHOD_ _THREAD_SAFE_METHOD_
return keys_pressed.has(p_scancode); return keys_pressed.has(p_keycode);
} }
bool InputDefault::is_mouse_button_pressed(int p_button) const { bool InputDefault::is_mouse_button_pressed(int p_button) const {
@ -271,11 +271,11 @@ void InputDefault::_parse_input_event_impl(const Ref<InputEvent> &p_event, bool
_THREAD_SAFE_METHOD_ _THREAD_SAFE_METHOD_
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (k.is_valid() && !k->is_echo() && k->get_scancode() != 0) { if (k.is_valid() && !k->is_echo() && k->get_keycode() != 0) {
if (k->is_pressed()) if (k->is_pressed())
keys_pressed.insert(k->get_scancode()); keys_pressed.insert(k->get_keycode());
else else
keys_pressed.erase(k->get_scancode()); keys_pressed.erase(k->get_keycode());
} }
Ref<InputEventMouseButton> mb = p_event; Ref<InputEventMouseButton> mb = p_event;

View File

@ -187,7 +187,7 @@ private:
bool use_accumulated_input; bool use_accumulated_input;
public: public:
virtual bool is_key_pressed(int p_scancode) const; virtual bool is_key_pressed(int p_keycode) const;
virtual bool is_mouse_button_pressed(int p_button) const; virtual bool is_mouse_button_pressed(int p_button) const;
virtual bool is_joy_button_pressed(int p_device, int p_button) const; virtual bool is_joy_button_pressed(int p_device, int p_button) const;
virtual bool is_action_pressed(const StringName &p_action) const; virtual bool is_action_pressed(const StringName &p_action) const;

View File

@ -752,7 +752,7 @@ bool GridMapEditor::forward_spatial_input_event(Camera *p_camera, const Ref<Inpu
if (k.is_valid()) { if (k.is_valid()) {
if (k->is_pressed()) { if (k->is_pressed()) {
if (k->get_scancode() == KEY_ESCAPE) { if (k->get_keycode() == KEY_ESCAPE) {
if (input_action == INPUT_PASTE) { if (input_action == INPUT_PASTE) {
_clear_clipboard_data(); _clear_clipboard_data();
@ -773,12 +773,12 @@ bool GridMapEditor::forward_spatial_input_event(Camera *p_camera, const Ref<Inpu
if (k->get_shift() && selection.active && input_action != INPUT_PASTE) { if (k->get_shift() && selection.active && input_action != INPUT_PASTE) {
if (k->get_scancode() == options->get_popup()->get_item_accelerator(options->get_popup()->get_item_index(MENU_OPTION_PREV_LEVEL))) { if (k->get_keycode() == options->get_popup()->get_item_accelerator(options->get_popup()->get_item_index(MENU_OPTION_PREV_LEVEL))) {
selection.click[edit_axis]--; selection.click[edit_axis]--;
_validate_selection(); _validate_selection();
return true; return true;
} }
if (k->get_scancode() == options->get_popup()->get_item_accelerator(options->get_popup()->get_item_index(MENU_OPTION_NEXT_LEVEL))) { if (k->get_keycode() == options->get_popup()->get_item_accelerator(options->get_popup()->get_item_index(MENU_OPTION_NEXT_LEVEL))) {
selection.click[edit_axis]++; selection.click[edit_axis]++;
_validate_selection(); _validate_selection();
return true; return true;
@ -842,7 +842,7 @@ void GridMapEditor::_sbox_input(const Ref<InputEvent> &p_ie) {
const Ref<InputEventKey> k = p_ie; const Ref<InputEventKey> k = p_ie;
if (k.is_valid() && (k->get_scancode() == KEY_UP || k->get_scancode() == KEY_DOWN || k->get_scancode() == KEY_PAGEUP || k->get_scancode() == KEY_PAGEDOWN)) { if (k.is_valid() && (k->get_keycode() == KEY_UP || k->get_keycode() == KEY_DOWN || k->get_keycode() == KEY_PAGEUP || k->get_keycode() == KEY_PAGEDOWN)) {
// Forward the key input to the ItemList so it can be scrolled // Forward the key input to the ItemList so it can be scrolled
mesh_library_palette->call("_gui_input", k); mesh_library_palette->call("_gui_input", k);

View File

@ -1832,7 +1832,7 @@ void VisualScriptEditor::_fn_name_box_input(const Ref<InputEvent> &p_event) {
return; return;
Ref<InputEventKey> key = p_event; Ref<InputEventKey> key = p_event;
if (key.is_valid() && key->is_pressed() && key->get_scancode() == KEY_ENTER) { if (key.is_valid() && key->is_pressed() && key->get_keycode() == KEY_ENTER) {
function_name_edit->hide(); function_name_edit->hide();
_rename_function(selected, function_name_box->get_text()); _rename_function(selected, function_name_box->get_text());
function_name_box->clear(); function_name_box->clear();

View File

@ -51,7 +51,7 @@ void VisualScriptPropertySelector::_sbox_input(const Ref<InputEvent> &p_ie) {
if (k.is_valid()) { if (k.is_valid()) {
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_UP: case KEY_UP:
case KEY_DOWN: case KEY_DOWN:
case KEY_PAGEUP: case KEY_PAGEUP:

View File

@ -990,8 +990,8 @@ public abstract class Godot extends Activity implements SensorEventListener, IDo
int keyCode; int keyCode;
if ((keyCode = cc[i]) != 0) { if ((keyCode = cc[i]) != 0) {
// Simulate key down and up... // Simulate key down and up...
GodotLib.key(0, keyCode, true); GodotLib.key(0, 0, keyCode, true);
GodotLib.key(0, keyCode, false); GodotLib.key(0, 0, keyCode, false);
} }
} }
} }

View File

@ -136,7 +136,7 @@ public class GodotLib {
/** /**
* Forward regular key events from the main thread to the GL thread. * Forward regular key events from the main thread to the GL thread.
*/ */
public static native void key(int p_scancode, int p_unicode_char, boolean p_pressed); public static native void key(int p_keycode, int p_scancode, int p_unicode_char, boolean p_pressed);
/** /**
* Forward game device's key events from the main thread to the GL thread. * Forward game device's key events from the main thread to the GL thread.

View File

@ -98,11 +98,12 @@ public class GodotInputHandler implements InputDeviceListener {
}); });
} }
} else { } else {
final int scanCode = event.getScanCode();
final int chr = event.getUnicodeChar(0); final int chr = event.getUnicodeChar(0);
queueEvent(new Runnable() { queueEvent(new Runnable() {
@Override @Override
public void run() { public void run() {
GodotLib.key(keyCode, chr, false); GodotLib.key(keyCode, scanCode, chr, false);
} }
}); });
}; };
@ -143,11 +144,12 @@ public class GodotInputHandler implements InputDeviceListener {
}); });
} }
} else { } else {
final int scanCode = event.getScanCode();
final int chr = event.getUnicodeChar(0); final int chr = event.getUnicodeChar(0);
queueEvent(new Runnable() { queueEvent(new Runnable() {
@Override @Override
public void run() { public void run() {
GodotLib.key(keyCode, chr, true); GodotLib.key(keyCode, scanCode, chr, true);
} }
}); });
}; };

View File

@ -91,8 +91,8 @@ public class GodotTextInputWrapper implements TextWatcher, OnEditorActionListene
@Override @Override
public void run() { public void run() {
for (int i = 0; i < count; ++i) { for (int i = 0; i < count; ++i) {
GodotLib.key(KeyEvent.KEYCODE_DEL, 0, true); GodotLib.key(KeyEvent.KEYCODE_DEL, KeyEvent.KEYCODE_DEL, 0, true);
GodotLib.key(KeyEvent.KEYCODE_DEL, 0, false); GodotLib.key(KeyEvent.KEYCODE_DEL, KeyEvent.KEYCODE_DEL, 0, false);
} }
} }
}); });
@ -110,8 +110,8 @@ public class GodotTextInputWrapper implements TextWatcher, OnEditorActionListene
@Override @Override
public void run() { public void run() {
for (int i = 0; i < count; ++i) { for (int i = 0; i < count; ++i) {
GodotLib.key(0, newChars[i], true); GodotLib.key(0, 0, newChars[i], true);
GodotLib.key(0, newChars[i], false); GodotLib.key(0, 0, newChars[i], false);
} }
} }
}); });
@ -127,8 +127,8 @@ public class GodotTextInputWrapper implements TextWatcher, OnEditorActionListene
public void run() { public void run() {
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);
GodotLib.key(0, ch, true); GodotLib.key(0, 0, ch, true);
GodotLib.key(0, ch, false); GodotLib.key(0, 0, ch, false);
} }
} }
}); });

View File

@ -1167,28 +1167,29 @@ JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_joyconnectionchanged(
} }
} }
JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_key(JNIEnv *env, jobject obj, jint p_scancode, jint p_unicode_char, jboolean p_pressed) { JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_key(JNIEnv *env, jobject obj, jint p_keycode, jint p_scancode, jint p_unicode_char, jboolean p_pressed) {
if (step == 0) if (step == 0)
return; return;
Ref<InputEventKey> ievent; Ref<InputEventKey> ievent;
ievent.instance(); ievent.instance();
int val = p_unicode_char; int val = p_unicode_char;
int scancode = android_get_keysym(p_scancode); int keycode = android_get_keysym(p_keycode);
ievent->set_scancode(scancode); int phy_keycode = android_get_keysym(p_scancode);
ievent->set_keycode(keycode);
ievent->set_physical_keycode(phy_keycode);
ievent->set_unicode(val); ievent->set_unicode(val);
ievent->set_pressed(p_pressed); ievent->set_pressed(p_pressed);
if (val == '\n') { if (val == '\n') {
ievent->set_scancode(KEY_ENTER); ievent->set_keycode(KEY_ENTER);
} else if (val == 61448) { } else if (val == 61448) {
ievent->set_scancode(KEY_BACKSPACE); ievent->set_keycode(KEY_BACKSPACE);
ievent->set_unicode(KEY_BACKSPACE); ievent->set_unicode(KEY_BACKSPACE);
} else if (val == 61453) { } else if (val == 61453) {
ievent->set_scancode(KEY_ENTER); ievent->set_keycode(KEY_ENTER);
ievent->set_unicode(KEY_ENTER); ievent->set_unicode(KEY_ENTER);
} else if (p_scancode == 4) { } else if (p_keycode == 4) {
os_android->main_loop_request_go_back(); os_android->main_loop_request_go_back();
} }

View File

@ -48,7 +48,7 @@ JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_touch(JNIEnv *env, jo
JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_hover(JNIEnv *env, jobject obj, jint p_type, jint p_x, jint p_y); JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_hover(JNIEnv *env, jobject obj, jint p_type, jint p_x, jint p_y);
JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_doubletap(JNIEnv *env, jobject obj, jint p_x, jint p_y); JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_doubletap(JNIEnv *env, jobject obj, jint p_x, jint p_y);
JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_scroll(JNIEnv *env, jobject obj, jint p_x, jint p_y); JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_scroll(JNIEnv *env, jobject obj, jint p_x, jint p_y);
JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_key(JNIEnv *env, jobject obj, jint p_scancode, jint p_unicode_char, jboolean p_pressed); JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_key(JNIEnv *env, jobject obj, jint p_keycode, jint p_scancode, jint p_unicode_char, jboolean p_pressed);
JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_joybutton(JNIEnv *env, jobject obj, jint p_device, jint p_button, jboolean p_pressed); JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_joybutton(JNIEnv *env, jobject obj, jint p_device, jint p_button, jboolean p_pressed);
JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_joyaxis(JNIEnv *env, jobject obj, jint p_device, jint p_axis, jfloat p_value); JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_joyaxis(JNIEnv *env, jobject obj, jint p_device, jint p_axis, jfloat p_value);
JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_joyhat(JNIEnv *env, jobject obj, jint p_device, jint p_hat_x, jint p_hat_y); JNIEXPORT void JNICALL Java_org_godotengine_godot_GodotLib_joyhat(JNIEnv *env, jobject obj, jint p_device, jint p_hat_x, jint p_hat_y);

View File

@ -273,7 +273,8 @@ void HaikuDirectWindow::HandleKeyboardEvent(BMessage *message) {
event.instance(); event.instance();
GetKeyModifierState(event, modifiers); GetKeyModifierState(event, modifiers);
event->set_pressed(message->what == B_KEY_DOWN); event->set_pressed(message->what == B_KEY_DOWN);
event->set_scancode(KeyMappingHaiku::get_keysym(raw_char, key)); event->set_keycode(KeyMappingHaiku::get_keysym(raw_char, key));
event->set_physical_keycode(KeyMappingHaiku::get_keysym(raw_char, key));
event->set_echo(message->HasInt32("be:key_repeat")); event->set_echo(message->HasInt32("be:key_repeat"));
event->set_unicode(0); event->set_unicode(0);
@ -283,8 +284,9 @@ void HaikuDirectWindow::HandleKeyboardEvent(BMessage *message) {
} }
//make it consistent across platforms. //make it consistent across platforms.
if (event->get_scancode() == KEY_BACKTAB) { if (event->get_keycode() == KEY_BACKTAB) {
event->set_scancode(KEY_TAB); event->set_keycode(KEY_TAB);
event->set_physical_keycode(KEY_TAB);
event->set_shift(true); event->set_shift(true);
} }

View File

@ -135,7 +135,6 @@ Error OSIPhone::initialize(const VideoMode &p_desired, int p_video_driver, int p
RasterizerRD::make_current(); RasterizerRD::make_current();
#endif #endif
visual_server = memnew(VisualServerRaster); visual_server = memnew(VisualServerRaster);
// FIXME: Reimplement threaded rendering // FIXME: Reimplement threaded rendering
if (get_render_thread_mode() != RENDER_THREAD_UNSAFE) { if (get_render_thread_mode() != RENDER_THREAD_UNSAFE) {
@ -212,7 +211,8 @@ void OSIPhone::key(uint32_t p_key, bool p_pressed) {
ev.instance(); ev.instance();
ev->set_echo(false); ev->set_echo(false);
ev->set_pressed(p_pressed); ev->set_pressed(p_pressed);
ev->set_scancode(p_key); ev->set_keycode(p_key);
ev->set_physical_keycode(p_key);
ev->set_unicode(p_key); ev->set_unicode(p_key);
queue_event(ev); queue_event(ev);
}; };

View File

@ -218,7 +218,7 @@
#define DOM_VK_PA1 0xFD #define DOM_VK_PA1 0xFD
#define DOM_VK_WIN_OEM_CLEAR 0xFE #define DOM_VK_WIN_OEM_CLEAR 0xFE
int dom2godot_scancode(int dom_keycode) { int dom2godot_keycode(int dom_keycode) {
if (DOM_VK_0 <= dom_keycode && dom_keycode <= DOM_VK_Z) { if (DOM_VK_0 <= dom_keycode && dom_keycode <= DOM_VK_Z) {
// ASCII intersection // ASCII intersection

View File

@ -250,7 +250,8 @@ static Ref<InputEventKey> setup_key_event(const EmscriptenKeyboardEvent *emscrip
ev.instance(); ev.instance();
ev->set_echo(emscripten_event->repeat); ev->set_echo(emscripten_event->repeat);
dom2godot_mod(emscripten_event, ev); dom2godot_mod(emscripten_event, ev);
ev->set_scancode(dom2godot_scancode(emscripten_event->keyCode)); ev->set_keycode(dom2godot_keycode(emscripten_event->keyCode));
ev->set_physical_keycode(dom2godot_keycode(emscripten_event->keyCode));
String unicode = String::utf8(emscripten_event->key); String unicode = String::utf8(emscripten_event->key);
// Check if empty or multi-character (e.g. `CapsLock`). // Check if empty or multi-character (e.g. `CapsLock`).
@ -270,7 +271,7 @@ EM_BOOL OS_JavaScript::keydown_callback(int p_event_type, const EmscriptenKeyboa
OS_JavaScript *os = get_singleton(); OS_JavaScript *os = get_singleton();
Ref<InputEventKey> ev = setup_key_event(p_event); Ref<InputEventKey> ev = setup_key_event(p_event);
ev->set_pressed(true); ev->set_pressed(true);
if (ev->get_unicode() == 0 && keycode_has_unicode(ev->get_scancode())) { if (ev->get_unicode() == 0 && keycode_has_unicode(ev->get_keycode())) {
// Defer to keypress event for legacy unicode retrieval. // Defer to keypress event for legacy unicode retrieval.
os->deferred_key_event = ev; os->deferred_key_event = ev;
// Do not suppress keypress event. // Do not suppress keypress event.
@ -295,7 +296,7 @@ EM_BOOL OS_JavaScript::keyup_callback(int p_event_type, const EmscriptenKeyboard
Ref<InputEventKey> ev = setup_key_event(p_event); Ref<InputEventKey> ev = setup_key_event(p_event);
ev->set_pressed(false); ev->set_pressed(false);
get_singleton()->input->parse_input_event(ev); get_singleton()->input->parse_input_event(ev);
return ev->get_scancode() != KEY_UNKNOWN && ev->get_scancode() != 0; return ev->get_keycode() != KEY_UNKNOWN && ev->get_keycode() != 0;
} }
// Mouse // Mouse

View File

@ -69,7 +69,8 @@ public:
bool pressed; bool pressed;
bool echo; bool echo;
bool raw; bool raw;
uint32_t scancode; uint32_t keycode;
uint32_t physical_keycode;
uint32_t unicode; uint32_t unicode;
}; };

View File

@ -157,7 +157,8 @@ static NSCursor *cursorFromSelector(SEL selector, SEL fallback = nil) {
get_key_modifier_state([event modifierFlags], k); get_key_modifier_state([event modifierFlags], k);
k->set_pressed(true); k->set_pressed(true);
k->set_scancode(KEY_PERIOD); k->set_keycode(KEY_PERIOD);
k->set_physical_keycode(KEY_PERIOD);
k->set_echo([event isARepeat]); k->set_echo([event isARepeat]);
OS_OSX::singleton->push_input(k); OS_OSX::singleton->push_input(k);
@ -635,7 +636,8 @@ static const NSRange kEmptyRange = { NSNotFound, 0 };
ke.pressed = true; ke.pressed = true;
ke.echo = false; ke.echo = false;
ke.raw = false; // IME input event ke.raw = false; // IME input event
ke.scancode = 0; ke.keycode = 0;
ke.physical_keycode = 0;
ke.unicode = codepoint; ke.unicode = codepoint;
push_to_key_event_buffer(ke); push_to_key_event_buffer(ke);
@ -1158,7 +1160,8 @@ static int remapKey(unsigned int key, unsigned int state) {
ke.osx_state = [event modifierFlags]; ke.osx_state = [event modifierFlags];
ke.pressed = true; ke.pressed = true;
ke.echo = [event isARepeat]; ke.echo = [event isARepeat];
ke.scancode = remapKey([event keyCode], [event modifierFlags]); ke.keycode = remapKey([event keyCode], [event modifierFlags]);
ke.physical_keycode = translateKey([event keyCode]);
ke.raw = true; ke.raw = true;
ke.unicode = [characters characterAtIndex:i]; ke.unicode = [characters characterAtIndex:i];
@ -1170,7 +1173,8 @@ static int remapKey(unsigned int key, unsigned int state) {
ke.osx_state = [event modifierFlags]; ke.osx_state = [event modifierFlags];
ke.pressed = true; ke.pressed = true;
ke.echo = [event isARepeat]; ke.echo = [event isARepeat];
ke.scancode = remapKey([event keyCode], [event modifierFlags]); ke.keycode = remapKey([event keyCode], [event modifierFlags]);
ke.physical_keycode = translateKey([event keyCode]);
ke.raw = false; ke.raw = false;
ke.unicode = 0; ke.unicode = 0;
@ -1228,7 +1232,8 @@ static int remapKey(unsigned int key, unsigned int state) {
} }
ke.osx_state = mod; ke.osx_state = mod;
ke.scancode = remapKey(key, mod); ke.keycode = remapKey(key, mod);
ke.physical_keycode = translateKey(key);
ke.unicode = 0; ke.unicode = 0;
push_to_key_event_buffer(ke); push_to_key_event_buffer(ke);
@ -1250,7 +1255,8 @@ static int remapKey(unsigned int key, unsigned int state) {
ke.osx_state = [event modifierFlags]; ke.osx_state = [event modifierFlags];
ke.pressed = false; ke.pressed = false;
ke.echo = [event isARepeat]; ke.echo = [event isARepeat];
ke.scancode = remapKey([event keyCode], [event modifierFlags]); ke.keycode = remapKey([event keyCode], [event modifierFlags]);
ke.physical_keycode = translateKey([event keyCode]);
ke.raw = true; ke.raw = true;
ke.unicode = [characters characterAtIndex:i]; ke.unicode = [characters characterAtIndex:i];
@ -1262,7 +1268,8 @@ static int remapKey(unsigned int key, unsigned int state) {
ke.osx_state = [event modifierFlags]; ke.osx_state = [event modifierFlags];
ke.pressed = false; ke.pressed = false;
ke.echo = [event isARepeat]; ke.echo = [event isARepeat];
ke.scancode = remapKey([event keyCode], [event modifierFlags]); ke.keycode = remapKey([event keyCode], [event modifierFlags]);
ke.physical_keycode = translateKey([event keyCode]);
ke.raw = true; ke.raw = true;
ke.unicode = 0; ke.unicode = 0;
@ -2845,32 +2852,35 @@ void OS_OSX::process_key_events() {
get_key_modifier_state(ke.osx_state, k); get_key_modifier_state(ke.osx_state, k);
k->set_pressed(ke.pressed); k->set_pressed(ke.pressed);
k->set_echo(ke.echo); k->set_echo(ke.echo);
k->set_scancode(ke.scancode); k->set_keycode(ke.keycode);
k->set_physical_keycode(ke.physical_keycode);
k->set_unicode(ke.unicode); k->set_unicode(ke.unicode);
push_input(k); push_input(k);
} else { } else {
// IME input // IME input
if ((i == 0 && ke.scancode == 0) || (i > 0 && key_event_buffer[i - 1].scancode == 0)) { if ((i == 0 && ke.keycode == 0) || (i > 0 && key_event_buffer[i - 1].keycode == 0)) {
k.instance(); k.instance();
get_key_modifier_state(ke.osx_state, k); get_key_modifier_state(ke.osx_state, k);
k->set_pressed(ke.pressed); k->set_pressed(ke.pressed);
k->set_echo(ke.echo); k->set_echo(ke.echo);
k->set_scancode(0); k->set_keycode(0);
k->set_physical_keycode(0);
k->set_unicode(ke.unicode); k->set_unicode(ke.unicode);
push_input(k); push_input(k);
} }
if (ke.scancode != 0) { if (ke.keycode != 0) {
k.instance(); k.instance();
get_key_modifier_state(ke.osx_state, k); get_key_modifier_state(ke.osx_state, k);
k->set_pressed(ke.pressed); k->set_pressed(ke.pressed);
k->set_echo(ke.echo); k->set_echo(ke.echo);
k->set_scancode(ke.scancode); k->set_keycode(ke.keycode);
k->set_physical_keycode(ke.physical_keycode);
if (i + 1 < key_event_pos && key_event_buffer[i + 1].scancode == 0) { if (i + 1 < key_event_pos && key_event_buffer[i + 1].keycode == 0) {
k->set_unicode(key_event_buffer[i + 1].unicode); k->set_unicode(key_event_buffer[i + 1].unicode);
} }

View File

@ -410,14 +410,16 @@ void App::key_event(Windows::UI::Core::CoreWindow ^ sender, bool p_pressed, Wind
ke.type = OS_UWP::KeyEvent::MessageType::KEY_EVENT_MESSAGE; ke.type = OS_UWP::KeyEvent::MessageType::KEY_EVENT_MESSAGE;
ke.unicode = 0; ke.unicode = 0;
ke.scancode = KeyMappingWindows::get_keysym((unsigned int)key_args->VirtualKey); ke.keycode = KeyMappingWindows::get_keysym((unsigned int)key_args->VirtualKey);
ke.physical_keycode = KeyMappingWindows::get_scansym((unsigned int)key_args->KeyStatus.ScanCode);
ke.echo = (!p_pressed && !key_args->KeyStatus.IsKeyReleased) || (p_pressed && key_args->KeyStatus.WasKeyDown); ke.echo = (!p_pressed && !key_args->KeyStatus.IsKeyReleased) || (p_pressed && key_args->KeyStatus.WasKeyDown);
} else { } else {
ke.type = OS_UWP::KeyEvent::MessageType::CHAR_EVENT_MESSAGE; ke.type = OS_UWP::KeyEvent::MessageType::CHAR_EVENT_MESSAGE;
ke.unicode = char_args->KeyCode; ke.unicode = char_args->KeyCode;
ke.scancode = 0; ke.keycode = 0;
ke.physical_keycode = 0;
ke.echo = (!p_pressed && !char_args->KeyStatus.IsKeyReleased) || (p_pressed && char_args->KeyStatus.WasKeyDown); ke.echo = (!p_pressed && !char_args->KeyStatus.IsKeyReleased) || (p_pressed && char_args->KeyStatus.WasKeyDown);
} }

View File

@ -605,7 +605,8 @@ void OS_UWP::process_key_events() {
key_event->set_shift(kev.shift); key_event->set_shift(kev.shift);
key_event->set_control(kev.control); key_event->set_control(kev.control);
key_event->set_echo(kev.echo); key_event->set_echo(kev.echo);
key_event->set_scancode(kev.scancode); key_event->set_keycode(kev.keycode);
key_event->set_physical_keycode(kev.physical_keycode);
key_event->set_unicode(kev.unicode); key_event->set_unicode(kev.unicode);
key_event->set_pressed(kev.pressed); key_event->set_pressed(kev.pressed);

View File

@ -61,7 +61,8 @@ public:
bool alt, shift, control; bool alt, shift, control;
MessageType type; MessageType type;
bool pressed; bool pressed;
unsigned int scancode; unsigned int keycode;
unsigned int physical_keycode;
unsigned int unicode; unsigned int unicode;
bool echo; bool echo;
CorePhysicalKeyStatus status; CorePhysicalKeyStatus status;

View File

@ -238,6 +238,104 @@ VK_PA1 (0xFD)
VK_OEM_CLEAR (0xFE) VK_OEM_CLEAR (0xFE)
*/ */
static _WinTranslatePair _scancode_to_keycode[] = {
{ KEY_ESCAPE, 0x01 },
{ KEY_1, 0x02 },
{ KEY_2, 0x03 },
{ KEY_3, 0x04 },
{ KEY_4, 0x05 },
{ KEY_5, 0x06 },
{ KEY_6, 0x07 },
{ KEY_7, 0x08 },
{ KEY_8, 0x09 },
{ KEY_9, 0x0A },
{ KEY_0, 0x0B },
{ KEY_MINUS, 0x0C },
{ KEY_EQUAL, 0x0D },
{ KEY_BACKSPACE, 0x0E },
{ KEY_TAB, 0x0F },
{ KEY_Q, 0x10 },
{ KEY_W, 0x11 },
{ KEY_E, 0x12 },
{ KEY_R, 0x13 },
{ KEY_T, 0x14 },
{ KEY_Y, 0x15 },
{ KEY_U, 0x16 },
{ KEY_I, 0x17 },
{ KEY_O, 0x18 },
{ KEY_P, 0x19 },
{ KEY_BRACELEFT, 0x1A },
{ KEY_BRACERIGHT, 0x1B },
{ KEY_ENTER, 0x1C },
{ KEY_CONTROL, 0x1D },
{ KEY_A, 0x1E },
{ KEY_S, 0x1F },
{ KEY_D, 0x20 },
{ KEY_F, 0x21 },
{ KEY_G, 0x22 },
{ KEY_H, 0x23 },
{ KEY_J, 0x24 },
{ KEY_K, 0x25 },
{ KEY_L, 0x26 },
{ KEY_SEMICOLON, 0x27 },
{ KEY_APOSTROPHE, 0x28 },
{ KEY_QUOTELEFT, 0x29 },
{ KEY_SHIFT, 0x2A },
{ KEY_BACKSLASH, 0x2B },
{ KEY_Z, 0x2C },
{ KEY_X, 0x2D },
{ KEY_C, 0x2E },
{ KEY_V, 0x2F },
{ KEY_B, 0x30 },
{ KEY_N, 0x31 },
{ KEY_M, 0x32 },
{ KEY_COMMA, 0x33 },
{ KEY_PERIOD, 0x34 },
{ KEY_SLASH, 0x35 },
{ KEY_SHIFT, 0x36 },
{ KEY_PRINT, 0x37 },
{ KEY_ALT, 0x38 },
{ KEY_SPACE, 0x39 },
{ KEY_CAPSLOCK, 0x3A },
{ KEY_F1, 0x3B },
{ KEY_F2, 0x3C },
{ KEY_F3, 0x3D },
{ KEY_F4, 0x3E },
{ KEY_F5, 0x3F },
{ KEY_F6, 0x40 },
{ KEY_F7, 0x41 },
{ KEY_F8, 0x42 },
{ KEY_F9, 0x43 },
{ KEY_F10, 0x44 },
{ KEY_NUMLOCK, 0x45 },
{ KEY_SCROLLLOCK, 0x46 },
{ KEY_HOME, 0x47 },
{ KEY_UP, 0x48 },
{ KEY_PAGEUP, 0x49 },
{ KEY_KP_SUBTRACT, 0x4A },
{ KEY_LEFT, 0x4B },
{ KEY_KP_5, 0x4C },
{ KEY_RIGHT, 0x4D },
{ KEY_KP_ADD, 0x4E },
{ KEY_END, 0x4F },
{ KEY_DOWN, 0x50 },
{ KEY_PAGEDOWN, 0x51 },
{ KEY_INSERT, 0x52 },
{ KEY_DELETE, 0x53 },
//{ KEY_???, 0x56 }, //NON US BACKSLASH
{ KEY_F11, 0x57 },
{ KEY_F12, 0x58 },
{ KEY_META, 0x5B },
{ KEY_META, 0x5C },
{ KEY_MENU, 0x5D },
{ KEY_F13, 0x64 },
{ KEY_F14, 0x65 },
{ KEY_F15, 0x66 },
{ KEY_F16, 0x67 },
{ KEY_UNKNOWN, 0 }
};
unsigned int KeyMappingWindows::get_keysym(unsigned int p_code) { unsigned int KeyMappingWindows::get_keysym(unsigned int p_code) {
for (int i = 0; _vk_to_keycode[i].keysym != KEY_UNKNOWN; i++) { for (int i = 0; _vk_to_keycode[i].keysym != KEY_UNKNOWN; i++) {
@ -251,3 +349,69 @@ unsigned int KeyMappingWindows::get_keysym(unsigned int p_code) {
return KEY_UNKNOWN; return KEY_UNKNOWN;
} }
unsigned int KeyMappingWindows::get_scansym(unsigned int p_code, bool p_extended) {
unsigned int keycode = KEY_UNKNOWN;
for (int i = 0; _scancode_to_keycode[i].keysym != KEY_UNKNOWN; i++) {
if (_scancode_to_keycode[i].keycode == p_code) {
keycode = _scancode_to_keycode[i].keysym;
break;
}
}
if (p_extended) {
switch (keycode) {
case KEY_ENTER: {
keycode = KEY_KP_ENTER;
} break;
case KEY_SLASH: {
keycode = KEY_KP_DIVIDE;
} break;
case KEY_CAPSLOCK: {
keycode = KEY_KP_ADD;
} break;
}
} else {
switch (keycode) {
case KEY_NUMLOCK: {
keycode = KEY_PAUSE;
} break;
case KEY_HOME: {
keycode = KEY_KP_7;
} break;
case KEY_UP: {
keycode = KEY_KP_8;
} break;
case KEY_PAGEUP: {
keycode = KEY_KP_9;
} break;
case KEY_LEFT: {
keycode = KEY_KP_4;
} break;
case KEY_RIGHT: {
keycode = KEY_KP_6;
} break;
case KEY_END: {
keycode = KEY_KP_1;
} break;
case KEY_DOWN: {
keycode = KEY_KP_2;
} break;
case KEY_PAGEDOWN: {
keycode = KEY_KP_3;
} break;
case KEY_INSERT: {
keycode = KEY_KP_0;
} break;
case KEY_DELETE: {
keycode = KEY_KP_PERIOD;
} break;
case KEY_PRINT: {
keycode = KEY_KP_MULTIPLY;
} break;
}
}
return keycode;
}

View File

@ -43,6 +43,7 @@ class KeyMappingWindows {
public: public:
static unsigned int get_keysym(unsigned int p_code); static unsigned int get_keysym(unsigned int p_code);
static unsigned int get_scansym(unsigned int p_code, bool p_extended);
}; };
#endif // KEY_MAPPING_WINDOWS_H #endif // KEY_MAPPING_WINDOWS_H

View File

@ -1133,7 +1133,8 @@ void OS_Windows::process_key_events() {
k->set_control(ke.control); k->set_control(ke.control);
k->set_metakey(ke.meta); k->set_metakey(ke.meta);
k->set_pressed(true); k->set_pressed(true);
k->set_scancode(KeyMappingWindows::get_keysym(ke.wParam)); k->set_keycode(KeyMappingWindows::get_keysym(ke.wParam));
k->set_physical_keycode(KeyMappingWindows::get_scansym((ke.lParam >> 16) & 0xFF, ke.lParam & (1 << 24)));
k->set_unicode(ke.wParam); k->set_unicode(ke.wParam);
if (k->get_unicode() && gr_mem) { if (k->get_unicode() && gr_mem) {
k->set_alt(false); k->set_alt(false);
@ -1163,11 +1164,13 @@ void OS_Windows::process_key_events() {
if ((ke.lParam & (1 << 24)) && (ke.wParam == VK_RETURN)) { if ((ke.lParam & (1 << 24)) && (ke.wParam == VK_RETURN)) {
// Special case for Numpad Enter key // Special case for Numpad Enter key
k->set_scancode(KEY_KP_ENTER); k->set_keycode(KEY_KP_ENTER);
} else { } else {
k->set_scancode(KeyMappingWindows::get_keysym(ke.wParam)); k->set_keycode(KeyMappingWindows::get_keysym(ke.wParam));
} }
k->set_physical_keycode(KeyMappingWindows::get_scansym((ke.lParam >> 16) & 0xFF, ke.lParam & (1 << 24)));
if (i + 1 < key_event_pos && key_event_buffer[i + 1].uMsg == WM_CHAR) { if (i + 1 < key_event_pos && key_event_buffer[i + 1].uMsg == WM_CHAR) {
k->set_unicode(key_event_buffer[i + 1].wParam); k->set_unicode(key_event_buffer[i + 1].wParam);
} }

View File

@ -180,6 +180,140 @@ static _XTranslatePair _xkeysym_to_keycode[] = {
{ 0, 0 } { 0, 0 }
}; };
struct _TranslatePair {
unsigned int keysym;
unsigned int keycode;
};
static _TranslatePair _scancode_to_keycode[] = {
{ KEY_ESCAPE, 0x09 },
{ KEY_1, 0x0A },
{ KEY_2, 0x0B },
{ KEY_3, 0x0C },
{ KEY_4, 0x0D },
{ KEY_5, 0x0E },
{ KEY_6, 0x0F },
{ KEY_7, 0x10 },
{ KEY_8, 0x11 },
{ KEY_9, 0x12 },
{ KEY_0, 0x13 },
{ KEY_MINUS, 0x14 },
{ KEY_EQUAL, 0x15 },
{ KEY_BACKSPACE, 0x16 },
{ KEY_TAB, 0x17 },
{ KEY_Q, 0x18 },
{ KEY_W, 0x19 },
{ KEY_E, 0x1A },
{ KEY_R, 0x1B },
{ KEY_T, 0x1C },
{ KEY_Y, 0x1D },
{ KEY_U, 0x1E },
{ KEY_I, 0x1F },
{ KEY_O, 0x20 },
{ KEY_P, 0x21 },
{ KEY_BRACELEFT, 0x22 },
{ KEY_BRACERIGHT, 0x23 },
{ KEY_ENTER, 0x24 },
{ KEY_CONTROL, 0x25 },
{ KEY_A, 0x26 },
{ KEY_S, 0x27 },
{ KEY_D, 0x28 },
{ KEY_F, 0x29 },
{ KEY_G, 0x2A },
{ KEY_H, 0x2B },
{ KEY_J, 0x2C },
{ KEY_K, 0x2D },
{ KEY_L, 0x2E },
{ KEY_SEMICOLON, 0x2F },
{ KEY_APOSTROPHE, 0x30 },
{ KEY_QUOTELEFT, 0x31 },
{ KEY_SHIFT, 0x32 },
{ KEY_BACKSLASH, 0x33 },
{ KEY_Z, 0x34 },
{ KEY_X, 0x35 },
{ KEY_C, 0x36 },
{ KEY_V, 0x37 },
{ KEY_B, 0x38 },
{ KEY_N, 0x39 },
{ KEY_M, 0x3A },
{ KEY_COMMA, 0x3B },
{ KEY_PERIOD, 0x3C },
{ KEY_SLASH, 0x3D },
{ KEY_SHIFT, 0x3E },
{ KEY_KP_MULTIPLY, 0x3F },
{ KEY_ALT, 0x40 },
{ KEY_SPACE, 0x41 },
{ KEY_CAPSLOCK, 0x42 },
{ KEY_F1, 0x43 },
{ KEY_F2, 0x44 },
{ KEY_F3, 0x45 },
{ KEY_F4, 0x46 },
{ KEY_F5, 0x47 },
{ KEY_F6, 0x48 },
{ KEY_F7, 0x49 },
{ KEY_F8, 0x4A },
{ KEY_F9, 0x4B },
{ KEY_F10, 0x4C },
{ KEY_NUMLOCK, 0x4D },
{ KEY_SCROLLLOCK, 0x4E },
{ KEY_KP_7, 0x4F },
{ KEY_KP_8, 0x50 },
{ KEY_KP_9, 0x51 },
{ KEY_KP_SUBTRACT, 0x52 },
{ KEY_KP_4, 0x53 },
{ KEY_KP_5, 0x54 },
{ KEY_KP_6, 0x55 },
{ KEY_KP_ADD, 0x56 },
{ KEY_KP_1, 0x57 },
{ KEY_KP_2, 0x58 },
{ KEY_KP_3, 0x59 },
{ KEY_KP_0, 0x5A },
{ KEY_KP_PERIOD, 0x5B },
//{ KEY_???, 0x5E }, //NON US BACKSLASH
{ KEY_F11, 0x5F },
{ KEY_F12, 0x60 },
{ KEY_KP_ENTER, 0x68 },
{ KEY_CONTROL, 0x69 },
{ KEY_KP_DIVIDE, 0x6A },
{ KEY_PRINT, 0x6B },
{ KEY_ALT, 0x6C },
{ KEY_ENTER, 0x6D },
{ KEY_HOME, 0x6E },
{ KEY_UP, 0x6F },
{ KEY_PAGEUP, 0x70 },
{ KEY_LEFT, 0x71 },
{ KEY_RIGHT, 0x72 },
{ KEY_END, 0x73 },
{ KEY_DOWN, 0x74 },
{ KEY_PAGEDOWN, 0x75 },
{ KEY_INSERT, 0x76 },
{ KEY_DELETE, 0x77 },
{ KEY_VOLUMEMUTE, 0x79 },
{ KEY_VOLUMEDOWN, 0x7A },
{ KEY_VOLUMEUP, 0x7B },
{ KEY_PAUSE, 0x7F },
{ KEY_SUPER_L, 0x85 },
{ KEY_SUPER_R, 0x86 },
{ KEY_MENU, 0x87 },
{ KEY_UNKNOWN, 0 }
};
unsigned int KeyMappingX11::get_scancode(unsigned int p_code) {
unsigned int keycode = KEY_UNKNOWN;
for (int i = 0; _scancode_to_keycode[i].keysym != KEY_UNKNOWN; i++) {
if (_scancode_to_keycode[i].keycode == p_code) {
keycode = _scancode_to_keycode[i].keysym;
break;
}
}
return keycode;
}
unsigned int KeyMappingX11::get_keycode(KeySym p_keysym) { unsigned int KeyMappingX11::get_keycode(KeySym p_keysym) {
// kinda bruteforce.. could optimize. // kinda bruteforce.. could optimize.

View File

@ -45,6 +45,7 @@ class KeyMappingX11 {
public: public:
static unsigned int get_keycode(KeySym p_keysym); static unsigned int get_keycode(KeySym p_keysym);
static unsigned int get_scancode(unsigned int p_code);
static KeySym get_keysym(unsigned int p_code); static KeySym get_keysym(unsigned int p_code);
static unsigned int get_unicode_from_keysym(KeySym p_keysym); static unsigned int get_unicode_from_keysym(KeySym p_keysym);
static KeySym get_keysym_from_unicode(unsigned int p_unicode); static KeySym get_keysym_from_unicode(unsigned int p_unicode);

View File

@ -1888,6 +1888,8 @@ void OS_X11::handle_key_event(XKeyEvent *p_event, bool p_echo) {
if (status == XLookupChars) { if (status == XLookupChars) {
bool keypress = xkeyevent->type == KeyPress; bool keypress = xkeyevent->type == KeyPress;
unsigned int keycode = KeyMappingX11::get_keycode(keysym_keycode); unsigned int keycode = KeyMappingX11::get_keycode(keysym_keycode);
unsigned int physical_keycode = KeyMappingX11::get_scancode(xkeyevent->keycode);
if (keycode >= 'a' && keycode <= 'z') if (keycode >= 'a' && keycode <= 'z')
keycode -= 'a' - 'A'; keycode -= 'a' - 'A';
@ -1896,23 +1898,29 @@ void OS_X11::handle_key_event(XKeyEvent *p_event, bool p_echo) {
for (int i = 0; i < tmp.length(); i++) { for (int i = 0; i < tmp.length(); i++) {
Ref<InputEventKey> k; Ref<InputEventKey> k;
k.instance(); k.instance();
if (keycode == 0 && tmp[i] == 0) { if (physical_keycode == 0 && keycode == 0 && tmp[i] == 0) {
continue; continue;
} }
if (keycode == 0)
keycode = physical_keycode;
get_key_modifier_state(xkeyevent->state, k); get_key_modifier_state(xkeyevent->state, k);
k->set_unicode(tmp[i]); k->set_unicode(tmp[i]);
k->set_pressed(keypress); k->set_pressed(keypress);
k->set_scancode(keycode); k->set_keycode(keycode);
k->set_physical_keycode(physical_keycode);
k->set_echo(false); k->set_echo(false);
if (k->get_scancode() == KEY_BACKTAB) { if (k->get_keycode() == KEY_BACKTAB) {
//make it consistent across platforms. //make it consistent across platforms.
k->set_scancode(KEY_TAB); k->set_keycode(KEY_TAB);
k->set_physical_keycode(KEY_TAB);
k->set_shift(true); k->set_shift(true);
} }
@ -1942,6 +1950,7 @@ void OS_X11::handle_key_event(XKeyEvent *p_event, bool p_echo) {
// keysym, so it works in all platforms the same. // keysym, so it works in all platforms the same.
unsigned int keycode = KeyMappingX11::get_keycode(keysym_keycode); unsigned int keycode = KeyMappingX11::get_keycode(keysym_keycode);
unsigned int physical_keycode = KeyMappingX11::get_scancode(xkeyevent->keycode);
/* Phase 3, obtain a unicode character from the keysym */ /* Phase 3, obtain a unicode character from the keysym */
@ -1961,9 +1970,12 @@ void OS_X11::handle_key_event(XKeyEvent *p_event, bool p_echo) {
bool keypress = xkeyevent->type == KeyPress; bool keypress = xkeyevent->type == KeyPress;
if (keycode == 0 && unicode == 0) if (physical_keycode == 0 && keycode == 0 && unicode == 0)
return; return;
if (keycode == 0)
keycode = physical_keycode;
/* Phase 5, determine modifier mask */ /* Phase 5, determine modifier mask */
// No problems here, except I had no way to // No problems here, except I had no way to
@ -2025,37 +2037,39 @@ void OS_X11::handle_key_event(XKeyEvent *p_event, bool p_echo) {
if (keycode >= 'a' && keycode <= 'z') if (keycode >= 'a' && keycode <= 'z')
keycode -= 'a' - 'A'; keycode -= 'a' - 'A';
k->set_scancode(keycode); k->set_keycode(keycode);
k->set_physical_keycode(physical_keycode);
k->set_unicode(unicode); k->set_unicode(unicode);
k->set_echo(p_echo); k->set_echo(p_echo);
if (k->get_scancode() == KEY_BACKTAB) { if (k->get_keycode() == KEY_BACKTAB) {
//make it consistent across platforms. //make it consistent across platforms.
k->set_scancode(KEY_TAB); k->set_keycode(KEY_TAB);
k->set_physical_keycode(KEY_TAB);
k->set_shift(true); k->set_shift(true);
} }
//don't set mod state if modifier keys are released by themselves //don't set mod state if modifier keys are released by themselves
//else event.is_action() will not work correctly here //else event.is_action() will not work correctly here
if (!k->is_pressed()) { if (!k->is_pressed()) {
if (k->get_scancode() == KEY_SHIFT) if (k->get_keycode() == KEY_SHIFT)
k->set_shift(false); k->set_shift(false);
else if (k->get_scancode() == KEY_CONTROL) else if (k->get_keycode() == KEY_CONTROL)
k->set_control(false); k->set_control(false);
else if (k->get_scancode() == KEY_ALT) else if (k->get_keycode() == KEY_ALT)
k->set_alt(false); k->set_alt(false);
else if (k->get_scancode() == KEY_META) else if (k->get_keycode() == KEY_META)
k->set_metakey(false); k->set_metakey(false);
} }
bool last_is_pressed = Input::get_singleton()->is_key_pressed(k->get_scancode()); bool last_is_pressed = Input::get_singleton()->is_key_pressed(k->get_keycode());
if (k->is_pressed()) { if (k->is_pressed()) {
if (last_is_pressed) { if (last_is_pressed) {
k->set_echo(true); k->set_echo(true);
} }
} }
//printf("key: %x\n",k->get_scancode()); //printf("key: %x\n",k->get_keycode());
input->accumulate_input_event(k); input->accumulate_input_event(k);
} }

View File

@ -85,7 +85,7 @@ void FileDialog::_unhandled_input(const Ref<InputEvent> &p_event) {
bool handled = true; bool handled = true;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_H: { case KEY_H: {

View File

@ -96,7 +96,7 @@ void GradientEdit::_gui_input(const Ref<InputEvent> &p_event) {
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (k.is_valid() && k->is_pressed() && k->get_scancode() == KEY_DELETE && grabbed != -1) { if (k.is_valid() && k->is_pressed() && k->get_keycode() == KEY_DELETE && grabbed != -1) {
points.remove(grabbed); points.remove(grabbed);
grabbed = -1; grabbed = -1;

View File

@ -1043,22 +1043,22 @@ void GraphEdit::_gui_input(const Ref<InputEvent> &p_ev) {
if (k.is_valid()) { if (k.is_valid()) {
if (k->get_scancode() == KEY_D && k->is_pressed() && k->get_command()) { if (k->get_keycode() == KEY_D && k->is_pressed() && k->get_command()) {
emit_signal("duplicate_nodes_request"); emit_signal("duplicate_nodes_request");
accept_event(); accept_event();
} }
if (k->get_scancode() == KEY_C && k->is_pressed() && k->get_command()) { if (k->get_keycode() == KEY_C && k->is_pressed() && k->get_command()) {
emit_signal("copy_nodes_request"); emit_signal("copy_nodes_request");
accept_event(); accept_event();
} }
if (k->get_scancode() == KEY_V && k->is_pressed() && k->get_command()) { if (k->get_keycode() == KEY_V && k->is_pressed() && k->get_command()) {
emit_signal("paste_nodes_request"); emit_signal("paste_nodes_request");
accept_event(); accept_event();
} }
if (k->get_scancode() == KEY_DELETE && k->is_pressed()) { if (k->get_keycode() == KEY_DELETE && k->is_pressed()) {
emit_signal("delete_nodes_request"); emit_signal("delete_nodes_request");
accept_event(); accept_event();
} }

View File

@ -165,7 +165,7 @@ void LineEdit::_gui_input(Ref<InputEvent> p_event) {
#ifdef APPLE_STYLE_KEYS #ifdef APPLE_STYLE_KEYS
if (k->get_control() && !k->get_shift() && !k->get_alt() && !k->get_command()) { if (k->get_control() && !k->get_shift() && !k->get_alt() && !k->get_command()) {
uint32_t remap_key = KEY_UNKNOWN; uint32_t remap_key = KEY_UNKNOWN;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_F: { case KEY_F: {
remap_key = KEY_RIGHT; remap_key = KEY_RIGHT;
} break; } break;
@ -193,13 +193,13 @@ void LineEdit::_gui_input(Ref<InputEvent> p_event) {
} }
if (remap_key != KEY_UNKNOWN) { if (remap_key != KEY_UNKNOWN) {
k->set_scancode(remap_key); k->set_keycode(remap_key);
k->set_control(false); k->set_control(false);
} }
} }
#endif #endif
unsigned int code = k->get_scancode(); unsigned int code = k->get_keycode();
if (k->get_command() && is_shortcut_keys_enabled()) { if (k->get_command() && is_shortcut_keys_enabled()) {
@ -571,7 +571,7 @@ void LineEdit::_gui_input(Ref<InputEvent> p_event) {
if (handled) { if (handled) {
accept_event(); accept_event();
} else if (!k->get_command()) { } else if (!k->get_command()) {
if (k->get_unicode() >= 32 && k->get_scancode() != KEY_DELETE) { if (k->get_unicode() >= 32 && k->get_keycode() != KEY_DELETE) {
if (editable) { if (editable) {
selection_delete(); selection_delete();

View File

@ -1075,7 +1075,7 @@ bool PopupMenu::activate_item_by_event(const Ref<InputEvent> &p_event, bool p_fo
Ref<InputEventKey> k = p_event; Ref<InputEventKey> k = p_event;
if (k.is_valid()) { if (k.is_valid()) {
code = k->get_scancode(); code = k->get_keycode();
if (code == 0) if (code == 0)
code = k->get_unicode(); code = k->get_unicode();
if (k->get_control()) if (k->get_control())

View File

@ -1209,7 +1209,7 @@ void RichTextLabel::_gui_input(Ref<InputEvent> p_event) {
if (k.is_valid()) { if (k.is_valid()) {
if (k->is_pressed() && !k->get_alt() && !k->get_shift()) { if (k->is_pressed() && !k->get_alt() && !k->get_shift()) {
bool handled = false; bool handled = false;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_PAGEUP: { case KEY_PAGEUP: {
if (vscroll->is_visible_in_tree()) { if (vscroll->is_visible_in_tree()) {

View File

@ -2564,9 +2564,9 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
k = k->duplicate(); // It will be modified later on. k = k->duplicate(); // It will be modified later on.
#ifdef OSX_ENABLED #ifdef OSX_ENABLED
if (k->get_scancode() == KEY_META) { if (k->get_keycode() == KEY_META) {
#else #else
if (k->get_scancode() == KEY_CONTROL) { if (k->get_keycode() == KEY_CONTROL) {
#endif #endif
if (select_identifiers_enabled) { if (select_identifiers_enabled) {
@ -2597,7 +2597,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
if (valid) { if (valid) {
if (!k->get_alt()) { if (!k->get_alt()) {
if (k->get_scancode() == KEY_UP) { if (k->get_keycode() == KEY_UP) {
if (completion_index > 0) { if (completion_index > 0) {
completion_index--; completion_index--;
@ -2611,7 +2611,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
return; return;
} }
if (k->get_scancode() == KEY_DOWN) { if (k->get_keycode() == KEY_DOWN) {
if (completion_index < completion_options.size() - 1) { if (completion_index < completion_options.size() - 1) {
completion_index++; completion_index++;
@ -2625,7 +2625,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
return; return;
} }
if (k->get_scancode() == KEY_PAGEUP) { if (k->get_keycode() == KEY_PAGEUP) {
completion_index -= get_constant("completion_lines"); completion_index -= get_constant("completion_lines");
if (completion_index < 0) if (completion_index < 0)
@ -2636,7 +2636,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
return; return;
} }
if (k->get_scancode() == KEY_PAGEDOWN) { if (k->get_keycode() == KEY_PAGEDOWN) {
completion_index += get_constant("completion_lines"); completion_index += get_constant("completion_lines");
if (completion_index >= completion_options.size()) if (completion_index >= completion_options.size())
@ -2647,7 +2647,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
return; return;
} }
if (k->get_scancode() == KEY_HOME && completion_index > 0) { if (k->get_keycode() == KEY_HOME && completion_index > 0) {
completion_index = 0; completion_index = 0;
completion_current = completion_options[completion_index]; completion_current = completion_options[completion_index];
@ -2656,7 +2656,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
return; return;
} }
if (k->get_scancode() == KEY_END && completion_index < completion_options.size() - 1) { if (k->get_keycode() == KEY_END && completion_index < completion_options.size() - 1) {
completion_index = completion_options.size() - 1; completion_index = completion_options.size() - 1;
completion_current = completion_options[completion_index]; completion_current = completion_options[completion_index];
@ -2665,14 +2665,14 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
return; return;
} }
if (k->get_scancode() == KEY_KP_ENTER || k->get_scancode() == KEY_ENTER || k->get_scancode() == KEY_TAB) { if (k->get_keycode() == KEY_KP_ENTER || k->get_keycode() == KEY_ENTER || k->get_keycode() == KEY_TAB) {
_confirm_completion(); _confirm_completion();
accept_event(); accept_event();
return; return;
} }
if (k->get_scancode() == KEY_BACKSPACE) { if (k->get_keycode() == KEY_BACKSPACE) {
_reset_caret_blink_timer(); _reset_caret_blink_timer();
@ -2682,7 +2682,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
return; return;
} }
if (k->get_scancode() == KEY_SHIFT) { if (k->get_keycode() == KEY_SHIFT) {
accept_event(); accept_event();
return; return;
} }
@ -2726,20 +2726,20 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
/* TEST CONTROL FIRST! */ /* TEST CONTROL FIRST! */
// Some remaps for duplicate functions. // Some remaps for duplicate functions.
if (k->get_command() && !k->get_shift() && !k->get_alt() && !k->get_metakey() && k->get_scancode() == KEY_INSERT) { if (k->get_command() && !k->get_shift() && !k->get_alt() && !k->get_metakey() && k->get_keycode() == KEY_INSERT) {
k->set_scancode(KEY_C); k->set_keycode(KEY_C);
} }
if (!k->get_command() && k->get_shift() && !k->get_alt() && !k->get_metakey() && k->get_scancode() == KEY_INSERT) { if (!k->get_command() && k->get_shift() && !k->get_alt() && !k->get_metakey() && k->get_keycode() == KEY_INSERT) {
k->set_scancode(KEY_V); k->set_keycode(KEY_V);
k->set_command(true); k->set_command(true);
k->set_shift(false); k->set_shift(false);
} }
#ifdef APPLE_STYLE_KEYS #ifdef APPLE_STYLE_KEYS
if (k->get_control() && !k->get_shift() && !k->get_alt() && !k->get_command()) { if (k->get_control() && !k->get_shift() && !k->get_alt() && !k->get_command()) {
uint32_t remap_key = KEY_UNKNOWN; uint32_t remap_key = KEY_UNKNOWN;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_F: { case KEY_F: {
remap_key = KEY_RIGHT; remap_key = KEY_RIGHT;
} break; } break;
@ -2761,7 +2761,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} }
if (remap_key != KEY_UNKNOWN) { if (remap_key != KEY_UNKNOWN) {
k->set_scancode(remap_key); k->set_keycode(remap_key);
k->set_control(false); k->set_control(false);
} }
} }
@ -2779,7 +2779,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
bool unselect = false; bool unselect = false;
bool dobreak = false; bool dobreak = false;
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_TAB: { case KEY_TAB: {
if (k->get_shift()) { if (k->get_shift()) {
@ -2853,11 +2853,11 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
selection.selecting_text = false; selection.selecting_text = false;
bool scancode_handled = true; bool keycode_handled = true;
// Special scancode test. // Special keycode test.
switch (k->get_scancode()) { switch (k->get_keycode()) {
case KEY_KP_ENTER: case KEY_KP_ENTER:
case KEY_ENTER: { case KEY_ENTER: {
@ -2979,7 +2979,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
completion_hint = ""; completion_hint = "";
update(); update();
} else { } else {
scancode_handled = false; keycode_handled = false;
} }
} break; } break;
case KEY_TAB: { case KEY_TAB: {
@ -3052,7 +3052,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
if (k->get_alt() && cursor.column > 1) { if (k->get_alt() && cursor.column > 1) {
#else #else
if (k->get_alt()) { if (k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} else if (k->get_command() && cursor.column > 1) { } else if (k->get_command() && cursor.column > 1) {
#endif #endif
@ -3109,7 +3109,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} break; } break;
case KEY_KP_4: { case KEY_KP_4: {
if (k->get_unicode() != 0) { if (k->get_unicode() != 0) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
[[fallthrough]]; [[fallthrough]];
@ -3145,7 +3145,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} else if (k->get_alt()) { } else if (k->get_alt()) {
#else #else
if (k->get_alt()) { if (k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} else if (k->get_command()) { } else if (k->get_command()) {
#endif #endif
@ -3185,7 +3185,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} break; } break;
case KEY_KP_6: { case KEY_KP_6: {
if (k->get_unicode() != 0) { if (k->get_unicode() != 0) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
[[fallthrough]]; [[fallthrough]];
@ -3207,7 +3207,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} else if (k->get_alt()) { } else if (k->get_alt()) {
#else #else
if (k->get_alt()) { if (k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} else if (k->get_command()) { } else if (k->get_command()) {
#endif #endif
@ -3246,7 +3246,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} break; } break;
case KEY_KP_8: { case KEY_KP_8: {
if (k->get_unicode() != 0) { if (k->get_unicode() != 0) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
[[fallthrough]]; [[fallthrough]];
@ -3254,7 +3254,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
case KEY_UP: { case KEY_UP: {
if (k->get_alt()) { if (k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
#ifndef APPLE_STYLE_KEYS #ifndef APPLE_STYLE_KEYS
@ -3299,7 +3299,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} break; } break;
case KEY_KP_2: { case KEY_KP_2: {
if (k->get_unicode() != 0) { if (k->get_unicode() != 0) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
[[fallthrough]]; [[fallthrough]];
@ -3307,7 +3307,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
case KEY_DOWN: { case KEY_DOWN: {
if (k->get_alt()) { if (k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
#ifndef APPLE_STYLE_KEYS #ifndef APPLE_STYLE_KEYS
@ -3367,7 +3367,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
if (k->get_alt() && cursor.column < curline_len - 1) { if (k->get_alt() && cursor.column < curline_len - 1) {
#else #else
if (k->get_alt()) { if (k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} else if (k->get_command() && cursor.column < curline_len - 1) { } else if (k->get_command() && cursor.column < curline_len - 1) {
#endif #endif
@ -3422,7 +3422,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} break; } break;
case KEY_KP_7: { case KEY_KP_7: {
if (k->get_unicode() != 0) { if (k->get_unicode() != 0) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
[[fallthrough]]; [[fallthrough]];
@ -3483,7 +3483,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} break; } break;
case KEY_KP_1: { case KEY_KP_1: {
if (k->get_unicode() != 0) { if (k->get_unicode() != 0) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
[[fallthrough]]; [[fallthrough]];
@ -3530,7 +3530,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} break; } break;
case KEY_KP_9: { case KEY_KP_9: {
if (k->get_unicode() != 0) { if (k->get_unicode() != 0) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
[[fallthrough]]; [[fallthrough]];
@ -3553,7 +3553,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} break; } break;
case KEY_KP_3: { case KEY_KP_3: {
if (k->get_unicode() != 0) { if (k->get_unicode() != 0) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
[[fallthrough]]; [[fallthrough]];
@ -3578,7 +3578,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
#ifndef APPLE_STYLE_KEYS #ifndef APPLE_STYLE_KEYS
if (!k->get_control() || k->get_shift() || k->get_alt()) { if (!k->get_control() || k->get_shift() || k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
if (is_shortcut_keys_enabled()) { if (is_shortcut_keys_enabled()) {
@ -3586,7 +3586,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} }
#else #else
if ((!k->get_command() && !k->get_control())) { if ((!k->get_command() && !k->get_control())) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
if (!k->get_shift() && k->get_command() && is_shortcut_keys_enabled()) if (!k->get_shift() && k->get_command() && is_shortcut_keys_enabled())
@ -3617,7 +3617,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
case KEY_E: { case KEY_E: {
if (!k->get_control() || k->get_command() || k->get_alt()) { if (!k->get_control() || k->get_command() || k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
@ -3642,7 +3642,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
break; break;
} }
if (!k->get_command() || k->get_shift() || k->get_alt()) { if (!k->get_command() || k->get_shift() || k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
if (is_shortcut_keys_enabled()) { if (is_shortcut_keys_enabled()) {
@ -3653,7 +3653,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
case KEY_C: { case KEY_C: {
if (!k->get_command() || k->get_shift() || k->get_alt()) { if (!k->get_command() || k->get_shift() || k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
@ -3669,7 +3669,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} }
if (!k->get_command()) { if (!k->get_command()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
@ -3687,7 +3687,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
} }
if (!k->get_command()) { if (!k->get_command()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
@ -3700,7 +3700,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
break; break;
} }
if (!k->get_command() || k->get_shift() || k->get_alt()) { if (!k->get_command() || k->get_shift() || k->get_alt()) {
scancode_handled = false; keycode_handled = false;
break; break;
} }
@ -3717,9 +3717,9 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
#endif #endif
query_code_comple(); query_code_comple();
scancode_handled = true; keycode_handled = true;
} else { } else {
scancode_handled = false; keycode_handled = false;
} }
} break; } break;
@ -3736,20 +3736,20 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
default: { default: {
scancode_handled = false; keycode_handled = false;
} break; } break;
} }
if (scancode_handled) if (keycode_handled)
accept_event(); accept_event();
if (k->get_scancode() == KEY_INSERT) { if (k->get_keycode() == KEY_INSERT) {
set_insert_mode(!insert_mode); set_insert_mode(!insert_mode);
accept_event(); accept_event();
return; return;
} }
if (!scancode_handled && !k->get_command()) { // For German keyboards. if (!keycode_handled && !k->get_command()) { // For German keyboards.
if (k->get_unicode() >= 32) { if (k->get_unicode() >= 32) {

View File

@ -2439,7 +2439,7 @@ void Tree::_gui_input(Ref<InputEvent> p_event) {
return; return;
} else { } else {
if (k->get_scancode() != KEY_SHIFT) if (k->get_keycode() != KEY_SHIFT)
last_keypress = 0; last_keypress = 0;
} }
} }

View File

@ -435,7 +435,7 @@ void SceneTree::input_event(const Ref<InputEvent> &p_event) {
if (ScriptDebugger::get_singleton() && ScriptDebugger::get_singleton()->is_remote()) { if (ScriptDebugger::get_singleton() && ScriptDebugger::get_singleton()->is_remote()) {
//quit from game window using F8 //quit from game window using F8
Ref<InputEventKey> k = ev; Ref<InputEventKey> k = ev;
if (k.is_valid() && k->is_pressed() && !k->is_echo() && k->get_scancode() == KEY_F8) { if (k.is_valid() && k->is_pressed() && !k->is_echo() && k->get_keycode() == KEY_F8) {
ScriptDebugger::get_singleton()->request_quit(); ScriptDebugger::get_singleton()->request_quit();
} }
} }