Merge pull request #78857 from smix8/navagent_pos_fix_4.x
Fix NavigationAgent position not always updating
This commit is contained in:
commit
813ff4b460
|
@ -258,11 +258,13 @@ void NavigationAgent2D::_notification(int p_what) {
|
|||
} break;
|
||||
|
||||
case NOTIFICATION_INTERNAL_PHYSICS_PROCESS: {
|
||||
if (agent_parent && avoidance_enabled) {
|
||||
NavigationServer2D::get_singleton()->agent_set_position(agent, agent_parent->get_global_position());
|
||||
}
|
||||
if (agent_parent && target_position_submitted) {
|
||||
if (velocity_submitted) {
|
||||
velocity_submitted = false;
|
||||
if (avoidance_enabled) {
|
||||
NavigationServer2D::get_singleton()->agent_set_position(agent, agent_parent->get_global_position());
|
||||
NavigationServer2D::get_singleton()->agent_set_velocity(agent, velocity);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -273,11 +273,13 @@ void NavigationAgent3D::_notification(int p_what) {
|
|||
} break;
|
||||
|
||||
case NOTIFICATION_INTERNAL_PHYSICS_PROCESS: {
|
||||
if (agent_parent && avoidance_enabled) {
|
||||
NavigationServer3D::get_singleton()->agent_set_position(agent, agent_parent->get_global_position());
|
||||
}
|
||||
if (agent_parent && target_position_submitted) {
|
||||
if (velocity_submitted) {
|
||||
velocity_submitted = false;
|
||||
if (avoidance_enabled) {
|
||||
NavigationServer3D::get_singleton()->agent_set_position(agent, agent_parent->get_global_transform().origin);
|
||||
if (!use_3d_avoidance) {
|
||||
stored_y_velocity = velocity.y;
|
||||
velocity.y = 0.0;
|
||||
|
|
Loading…
Reference in New Issue