diff --git a/bitmap2component/bitmap2component.cpp b/bitmap2component/bitmap2component.cpp index e0c5d29c73..de6ff48e42 100644 --- a/bitmap2component/bitmap2component.cpp +++ b/bitmap2component/bitmap2component.cpp @@ -503,21 +503,22 @@ void BITMAPCONV_INFO::createOutputData( BMP2CMP_MOD_LAYER aModLayer ) polyset_areas.BooleanSubtract( polyset_holes, SHAPE_POLY_SET::PM_STRICTLY_SIMPLE ); // Ensure there are no self intersecting polygons - polyset_areas.NormalizeAreaOutlines(); - - // Convert polygon with holes to a unique polygon - polyset_areas.Fracture( SHAPE_POLY_SET::PM_STRICTLY_SIMPLE ); - - // Output current resulting polygon(s) - for( int ii = 0; ii < polyset_areas.OutlineCount(); ii++ ) + if( polyset_areas.NormalizeAreaOutlines() ) { - SHAPE_LINE_CHAIN& poly = polyset_areas.Outline( ii ); - outputOnePolygon( poly, getBoardLayerName( aModLayer )); - } + // Convert polygon with holes to a unique polygon + polyset_areas.Fracture( SHAPE_POLY_SET::PM_STRICTLY_SIMPLE ); - polyset_areas.RemoveAllContours(); - polyset_holes.RemoveAllContours(); - main_outline = true; + // Output current resulting polygon(s) + for( int ii = 0; ii < polyset_areas.OutlineCount(); ii++ ) + { + SHAPE_LINE_CHAIN& poly = polyset_areas.Outline( ii ); + outputOnePolygon( poly, getBoardLayerName( aModLayer )); + } + + polyset_areas.RemoveAllContours(); + polyset_holes.RemoveAllContours(); + main_outline = true; + } } paths = paths->next; diff --git a/libs/kimath/src/geometry/shape_poly_set.cpp b/libs/kimath/src/geometry/shape_poly_set.cpp index c227cfc431..de0d6dc9b1 100644 --- a/libs/kimath/src/geometry/shape_poly_set.cpp +++ b/libs/kimath/src/geometry/shape_poly_set.cpp @@ -1312,7 +1312,9 @@ int SHAPE_POLY_SET::NormalizeAreaOutlines() BooleanSubtract( holesBuffer, SHAPE_POLY_SET::PM_STRICTLY_SIMPLE ); } - RemoveNullSegments(); + // In degenerate cases, simplify might return no outlines + if( OutlineCount() > 0 ) + RemoveNullSegments(); return OutlineCount(); } @@ -1608,7 +1610,7 @@ int SHAPE_POLY_SET::RemoveNullSegments() ITERATOR iterator = IterateWithHoles(); - VECTOR2I contourStart = *iterator; + VECTOR2I contourStart = *NormalizeAreaOutlinesiterator; VECTOR2I segmentStart, segmentEnd; VERTEX_INDEX indexStart;