Handle cases where Simplify removes all outlines
This could theoretically happen for a fully degenerate polygon
Fixes https://gitlab.com/kicad/code/kicad/issues/12120
(cherry picked from commit 5a37211fdb
)
This commit is contained in:
parent
b72675ba92
commit
b324abefe5
|
@ -503,21 +503,22 @@ void BITMAPCONV_INFO::createOutputData( BMP2CMP_MOD_LAYER aModLayer )
|
||||||
polyset_areas.BooleanSubtract( polyset_holes, SHAPE_POLY_SET::PM_STRICTLY_SIMPLE );
|
polyset_areas.BooleanSubtract( polyset_holes, SHAPE_POLY_SET::PM_STRICTLY_SIMPLE );
|
||||||
|
|
||||||
// Ensure there are no self intersecting polygons
|
// Ensure there are no self intersecting polygons
|
||||||
polyset_areas.NormalizeAreaOutlines();
|
if( 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++ )
|
|
||||||
{
|
{
|
||||||
SHAPE_LINE_CHAIN& poly = polyset_areas.Outline( ii );
|
// Convert polygon with holes to a unique polygon
|
||||||
outputOnePolygon( poly, getBoardLayerName( aModLayer ));
|
polyset_areas.Fracture( SHAPE_POLY_SET::PM_STRICTLY_SIMPLE );
|
||||||
}
|
|
||||||
|
|
||||||
polyset_areas.RemoveAllContours();
|
// Output current resulting polygon(s)
|
||||||
polyset_holes.RemoveAllContours();
|
for( int ii = 0; ii < polyset_areas.OutlineCount(); ii++ )
|
||||||
main_outline = true;
|
{
|
||||||
|
SHAPE_LINE_CHAIN& poly = polyset_areas.Outline( ii );
|
||||||
|
outputOnePolygon( poly, getBoardLayerName( aModLayer ));
|
||||||
|
}
|
||||||
|
|
||||||
|
polyset_areas.RemoveAllContours();
|
||||||
|
polyset_holes.RemoveAllContours();
|
||||||
|
main_outline = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
paths = paths->next;
|
paths = paths->next;
|
||||||
|
|
|
@ -1294,7 +1294,9 @@ int SHAPE_POLY_SET::NormalizeAreaOutlines()
|
||||||
BooleanSubtract( holesBuffer, SHAPE_POLY_SET::PM_STRICTLY_SIMPLE );
|
BooleanSubtract( holesBuffer, SHAPE_POLY_SET::PM_STRICTLY_SIMPLE );
|
||||||
}
|
}
|
||||||
|
|
||||||
RemoveNullSegments();
|
// In degenerate cases, simplify might return no outlines
|
||||||
|
if( OutlineCount() > 0 )
|
||||||
|
RemoveNullSegments();
|
||||||
|
|
||||||
return OutlineCount();
|
return OutlineCount();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue