Create degenerate triangles when inserting an edge into a CSG face.

They will be deleted when the faces are merged, but their edges are
needed for merging faces.
This commit is contained in:
Marcel Admiraal 2020-06-29 16:40:25 +01:00
parent 4599381fad
commit 1a559c9889

View file

@ -1068,15 +1068,6 @@ void CSGBrushOperation::Build2DFaces::_find_edge_intersections(const Vector2 p_s
break; break;
} }
// Don't create degenerate triangles.
Vector2 split_edge1[2] = { vertices[new_vertex_idx].point, edge_points[0] };
Vector2 split_edge2[2] = { vertices[new_vertex_idx].point, edge_points[1] };
Vector2 new_edge[2] = { vertices[new_vertex_idx].point, vertices[opposite_vertex_idx].point };
if (are_segements_parallel(split_edge1, new_edge, vertex_snap2) &&
are_segements_parallel(split_edge2, new_edge, vertex_snap2)) {
break;
}
// If opposite point is on the segemnt, add its index to segment indices too. // If opposite point is on the segemnt, add its index to segment indices too.
Vector2 closest_point = Geometry2D::get_closest_point_to_segment(vertices[opposite_vertex_idx].point, p_segment_points); Vector2 closest_point = Geometry2D::get_closest_point_to_segment(vertices[opposite_vertex_idx].point, p_segment_points);
if ((closest_point - vertices[opposite_vertex_idx].point).length_squared() < vertex_snap2) { if ((closest_point - vertices[opposite_vertex_idx].point).length_squared() < vertex_snap2) {