From a69e449782214c6108303af782c8aa321e5b11ea Mon Sep 17 00:00:00 2001 From: Andreas Haas Date: Sun, 19 Mar 2017 09:20:20 +0100 Subject: [PATCH] Input: bind parse_input_event() When using get_tree().input_event(ev), the engine will JUST send the event down the SceneTree. However, you won't get any of the benefits of the Input singleton: - No InputMap actions will be emitted - The internal input state won't be modified, so methods like `Input.get_mouse_pos()` or `Input.is_joy_button_pressed` won't return the expected output after sending the event. This is fixed by using `Input.parse_input_event(ev)` instead. I guess we'll also have to update the docs to reflect that this is the preferred method of sending custom InputEvents. --- core/os/input.cpp | 1 + core/os/input.h | 2 ++ main/input_default.h | 3 ++- 3 files changed, 5 insertions(+), 1 deletion(-) diff --git a/core/os/input.cpp b/core/os/input.cpp index 63efbe4d11b..22ca94d4491 100644 --- a/core/os/input.cpp +++ b/core/os/input.cpp @@ -83,6 +83,7 @@ void Input::_bind_methods() { ClassDB::bind_method(D_METHOD("action_press", "action"), &Input::action_press); ClassDB::bind_method(D_METHOD("action_release", "action"), &Input::action_release); ClassDB::bind_method(D_METHOD("set_custom_mouse_cursor", "image:Texture", "hotspot"), &Input::set_custom_mouse_cursor, DEFVAL(Vector2())); + ClassDB::bind_method(D_METHOD("parse_input_event", "event"), &Input::parse_input_event); BIND_CONSTANT(MOUSE_MODE_VISIBLE); BIND_CONSTANT(MOUSE_MODE_HIDDEN); diff --git a/core/os/input.h b/core/os/input.h index 86755e632cc..2f6359632e3 100644 --- a/core/os/input.h +++ b/core/os/input.h @@ -102,6 +102,8 @@ public: virtual int get_joy_button_index_from_string(String p_button) = 0; virtual int get_joy_axis_index_from_string(String p_axis) = 0; + virtual void parse_input_event(const InputEvent &p_event) = 0; + Input(); }; diff --git a/main/input_default.h b/main/input_default.h index a1a055366c3..fecdb215d7c 100644 --- a/main/input_default.h +++ b/main/input_default.h @@ -201,7 +201,8 @@ public: virtual void warp_mouse_pos(const Vector2 &p_to); - void parse_input_event(const InputEvent &p_event); + virtual void parse_input_event(const InputEvent &p_event); + void set_gravity(const Vector3 &p_gravity); void set_accelerometer(const Vector3 &p_accel); void set_magnetometer(const Vector3 &p_magnetometer);