Merge pull request #74976 from smix8/navagent_fix_debug_path_duplicates_4.x

Fix NavigationAgent3D debug path duplicated points
This commit is contained in:
Yuri Sizov 2023-03-16 11:45:10 +01:00 committed by GitHub
commit 44cc6e5c86
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -135,7 +135,7 @@ void NavigationAgent3D::_bind_methods() {
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "debug_enabled"), "set_debug_enabled", "get_debug_enabled"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "debug_enabled"), "set_debug_enabled", "get_debug_enabled");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "debug_use_custom"), "set_debug_use_custom", "get_debug_use_custom"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "debug_use_custom"), "set_debug_use_custom", "get_debug_use_custom");
ADD_PROPERTY(PropertyInfo(Variant::COLOR, "debug_path_custom_color"), "set_debug_path_custom_color", "get_debug_path_custom_color"); ADD_PROPERTY(PropertyInfo(Variant::COLOR, "debug_path_custom_color"), "set_debug_path_custom_color", "get_debug_path_custom_color");
ADD_PROPERTY(PropertyInfo(Variant::FLOAT, "debug_path_custom_point_size", PROPERTY_HINT_RANGE, "1,50,1,suffix:px"), "set_debug_path_custom_point_size", "get_debug_path_custom_point_size"); ADD_PROPERTY(PropertyInfo(Variant::FLOAT, "debug_path_custom_point_size", PROPERTY_HINT_RANGE, "0,50,0.01,or_greater,suffix:px"), "set_debug_path_custom_point_size", "get_debug_path_custom_point_size");
} }
void NavigationAgent3D::_notification(int p_what) { void NavigationAgent3D::_notification(int p_what) {
@ -760,7 +760,7 @@ void NavigationAgent3D::set_debug_path_custom_point_size(float p_point_size) {
return; return;
} }
debug_path_custom_point_size = p_point_size; debug_path_custom_point_size = MAX(0.0, p_point_size);
debug_path_dirty = true; debug_path_dirty = true;
#endif // DEBUG_ENABLED #endif // DEBUG_ENABLED
} }
@ -828,6 +828,7 @@ void NavigationAgent3D::_update_debug_path() {
debug_path_mesh->surface_set_material(0, debug_agent_path_line_material); debug_path_mesh->surface_set_material(0, debug_agent_path_line_material);
} }
if (debug_path_custom_point_size > 0.0) {
Vector<Vector3> debug_path_points_vertex_array; Vector<Vector3> debug_path_points_vertex_array;
for (int i = 0; i < navigation_path.size(); i++) { for (int i = 0; i < navigation_path.size(); i++) {
@ -836,7 +837,7 @@ void NavigationAgent3D::_update_debug_path() {
Array debug_path_points_mesh_array; Array debug_path_points_mesh_array;
debug_path_points_mesh_array.resize(Mesh::ARRAY_MAX); debug_path_points_mesh_array.resize(Mesh::ARRAY_MAX);
debug_path_points_mesh_array[Mesh::ARRAY_VERTEX] = debug_path_lines_vertex_array; debug_path_points_mesh_array[Mesh::ARRAY_VERTEX] = debug_path_points_vertex_array;
debug_path_mesh->add_surface_from_arrays(Mesh::PRIMITIVE_POINTS, debug_path_points_mesh_array); debug_path_mesh->add_surface_from_arrays(Mesh::PRIMITIVE_POINTS, debug_path_points_mesh_array);
@ -851,6 +852,7 @@ void NavigationAgent3D::_update_debug_path() {
} else { } else {
debug_path_mesh->surface_set_material(1, debug_agent_path_point_material); debug_path_mesh->surface_set_material(1, debug_agent_path_point_material);
} }
}
RS::get_singleton()->instance_set_base(debug_path_instance, debug_path_mesh->get_rid()); RS::get_singleton()->instance_set_base(debug_path_instance, debug_path_mesh->get_rid());
RS::get_singleton()->instance_set_scenario(debug_path_instance, agent_parent->get_world_3d()->get_scenario()); RS::get_singleton()->instance_set_scenario(debug_path_instance, agent_parent->get_world_3d()->get_scenario());