From 645e17684d95e76f3591617072d66397f3fa7ad1 Mon Sep 17 00:00:00 2001 From: Lorenzo Marcantonio Date: Fri, 16 May 2014 19:43:27 +0200 Subject: [PATCH] Pull unfilled polygon drawing thru the line clipper; GTK mess up even in this case and the sheet border lines glitch on the screen at high zoom otherwise in pcbnew. --- common/gr_basic.cpp | 28 +++++++++++++--------------- 1 file changed, 13 insertions(+), 15 deletions(-) diff --git a/common/gr_basic.cpp b/common/gr_basic.cpp index f46ca2ad17..c97ec7d8dc 100644 --- a/common/gr_basic.cpp +++ b/common/gr_basic.cpp @@ -805,15 +805,11 @@ static void GRSPoly( EDA_RECT* ClipBox, wxDC* DC, int n, wxPoint Points[], } else { - wxPoint endPt = Points[n - 1]; - - GRSetBrush( DC, Color ); - DC->DrawLines( n, Points ); - - // The last point is not drawn by DrawLine and DrawLines - // Add it if the polygon is not closed - if( endPt != Points[0] ) - DC->DrawPoint( endPt.x, endPt.y ); + GRMoveTo( Points[0].x, Points[0].y ); + for( int i = 1; i < n; ++i ) + { + GRLineTo( ClipBox, DC, Points[i].x, Points[i].y, width, Color ); + } } } @@ -841,16 +837,18 @@ static void GRSClosedPoly( EDA_RECT* aClipBox, wxDC* aDC, } else { - GRSetBrush( aDC, aBgColor ); - aDC->DrawLines( aPointCount, aPoints ); + GRMoveTo( aPoints[0].x, aPoints[0].y ); + for( int i = 1; i < aPointCount; ++i ) + { + GRLineTo( aClipBox, aDC, aPoints[i].x, aPoints[i].y, aWidth, aColor ); + } int lastpt = aPointCount - 1; - /* Close the polygon. */ + + // Close the polygon if( aPoints[lastpt] != aPoints[0] ) { - GRLine( aClipBox, aDC, aPoints[0].x, aPoints[0].y, - aPoints[lastpt].x, aPoints[lastpt].y, - aWidth, aColor ); + GRLineTo( aClipBox, aDC, aPoints[lastpt].x, aPoints[lastpt].y, aWidth, aColor ); } } }