Tesselation: Only set valid when successful

Tesselation can fail for a number of reasons.  When this happens, we set
the triangulationValid flag to false to prevent using the broken
triangulation.  This will fall back to the slow OpenGL triangulation
when DrawPolygon is called.
This commit is contained in:
Seth Hillbrand 2018-12-18 06:17:01 -07:00
parent 388397f97d
commit 2498da2745
2 changed files with 9 additions and 9 deletions

View File

@ -1869,12 +1869,10 @@ void SHAPE_POLY_SET::CacheTriangulation()
tmpSet.Fracture( PM_FAST ); tmpSet.Fracture( PM_FAST );
m_triangulatedPolys.clear(); m_triangulatedPolys.clear();
m_triangulationValid = true;
for( int i = 0; i < tmpSet.OutlineCount(); i++ ) for( int i = 0; i < tmpSet.OutlineCount(); i++ )
{ {
if( tmpSet.Outline( i ).PointCount() < 3 ) // malformed polygon
continue;
m_triangulatedPolys.push_back( std::make_unique<TRIANGULATED_POLYGON>() ); m_triangulatedPolys.push_back( std::make_unique<TRIANGULATED_POLYGON>() );
PolygonTriangulation tess( *m_triangulatedPolys.back() ); PolygonTriangulation tess( *m_triangulatedPolys.back() );
@ -1883,12 +1881,17 @@ void SHAPE_POLY_SET::CacheTriangulation()
if( !tess.TesselatePolygon( tmpSet.Polygon( i ).front() ) ) if( !tess.TesselatePolygon( tmpSet.Polygon( i ).front() ) )
{ {
tmpSet.Fracture( PM_FAST ); tmpSet.Fracture( PM_FAST );
tess.TesselatePolygon( tmpSet.Polygon( i ).front() );
if( !tess.TesselatePolygon( tmpSet.Polygon( i ).front() ) )
{
m_triangulatedPolys.pop_back();
m_triangulationValid = false;
}
} }
} }
m_triangulationValid = true; if( m_triangulationValid )
m_hash = checksum(); m_hash = checksum();
} }

View File

@ -651,9 +651,6 @@ public:
{ {
ClipperLib::Clipper c; ClipperLib::Clipper c;
if( aPoly.PointCount() < 3 ) // Malformed polygon
return false;
m_bbox = aPoly.BBox(); m_bbox = aPoly.BBox();
m_result.Clear(); m_result.Clear();