diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2024-07-07 21:58:55 +0200 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2024-07-07 21:58:55 +0200 |
commit | 307b4e30919ae9762ed12fafbe9b04c90bd105ab (patch) | |
tree | 4e21fa8f0b7ff8ab9f5818dad3af6983d6454a7e /core/input/input.cpp | |
parent | aec5c85acb7e052c64588b708c8ee6d22b3a6489 (diff) | |
parent | 23521635d2f68525a6e41dde17bf34a53225e3e1 (diff) | |
download | redot-engine-307b4e30919ae9762ed12fafbe9b04c90bd105ab.tar.gz |
Merge pull request #94039 from rburing/fix_physics_tickcounter
Fix physics tick counter
Diffstat (limited to 'core/input/input.cpp')
-rw-r--r-- | core/input/input.cpp | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/core/input/input.cpp b/core/input/input.cpp index 56f616fac4..ec0303df06 100644 --- a/core/input/input.cpp +++ b/core/input/input.cpp @@ -758,12 +758,13 @@ void Input::_parse_input_event_impl(const Ref<InputEvent> &p_event, bool p_is_em bool was_pressed = action_state.cache.pressed; _update_action_cache(E.key, action_state); + // As input may come in part way through a physics tick, the earliest we can react to it is the next physics tick. if (action_state.cache.pressed && !was_pressed) { - action_state.pressed_physics_frame = Engine::get_singleton()->get_physics_frames(); + action_state.pressed_physics_frame = Engine::get_singleton()->get_physics_frames() + 1; action_state.pressed_process_frame = Engine::get_singleton()->get_process_frames(); } if (!action_state.cache.pressed && was_pressed) { - action_state.released_physics_frame = Engine::get_singleton()->get_physics_frames(); + action_state.released_physics_frame = Engine::get_singleton()->get_physics_frames() + 1; action_state.released_process_frame = Engine::get_singleton()->get_process_frames(); } } |