Merge pull request #94421 from lawnjelly/fix_action_press_tick
[3.x] Fix physics tick count in `Input.action_press` and `Input.action_rele…
This commit is contained in:
commit
49339fd9ec
1 changed files with 4 additions and 2 deletions
|
@ -646,7 +646,8 @@ void InputDefault::action_press(const StringName &p_action, float p_strength) {
|
||||||
// Create or retrieve existing action.
|
// Create or retrieve existing action.
|
||||||
Action &action = action_state[p_action];
|
Action &action = action_state[p_action];
|
||||||
|
|
||||||
action.pressed_physics_frame = Engine::get_singleton()->get_physics_frames();
|
// As input may come in part way through a physics tick, the earliest we can react to it is the next physics tick.
|
||||||
|
action.pressed_physics_frame = Engine::get_singleton()->get_physics_frames() + 1;
|
||||||
action.pressed_idle_frame = Engine::get_singleton()->get_idle_frames();
|
action.pressed_idle_frame = Engine::get_singleton()->get_idle_frames();
|
||||||
action.pressed = true;
|
action.pressed = true;
|
||||||
action.exact = true;
|
action.exact = true;
|
||||||
|
@ -658,7 +659,8 @@ void InputDefault::action_release(const StringName &p_action) {
|
||||||
// Create or retrieve existing action.
|
// Create or retrieve existing action.
|
||||||
Action &action = action_state[p_action];
|
Action &action = action_state[p_action];
|
||||||
|
|
||||||
action.released_physics_frame = Engine::get_singleton()->get_physics_frames();
|
// As input may come in part way through a physics tick, the earliest we can react to it is the next physics tick.
|
||||||
|
action.released_physics_frame = Engine::get_singleton()->get_physics_frames() + 1;
|
||||||
action.released_idle_frame = Engine::get_singleton()->get_idle_frames();
|
action.released_idle_frame = Engine::get_singleton()->get_idle_frames();
|
||||||
action.pressed = false;
|
action.pressed = false;
|
||||||
action.exact = true;
|
action.exact = true;
|
||||||
|
|
Loading…
Reference in a new issue