Skip to content

Commit

Permalink
Fix more occurances of drawPolygon issues on Windows
Browse files Browse the repository at this point in the history
(cherry-picked from 4bcd970)
nyalldawson committed Oct 19, 2016
1 parent 1719933 commit 2d79b42
Showing 2 changed files with 19 additions and 2 deletions.
8 changes: 7 additions & 1 deletion src/core/composer/qgscomposeritem.cpp
Original file line number Diff line number Diff line change
@@ -524,7 +524,13 @@ void QgsComposerItem::drawSelectionBoxes( QPainter* p )
selectedItemPen.setWidth( 0 );
p->setPen( selectedItemPen );
p->setBrush( Qt::NoBrush );
p->drawPolygon( rect() );

// drawPolygon causes issues on windows - corners of path may be missing resulting in triangles being drawn
// instead of rectangles! (Same cause as #13343)
QPainterPath path;
path.addPolygon( rect() );
p->drawPath( path );

p->restore();
}

13 changes: 12 additions & 1 deletion src/gui/qgsmapoverviewcanvas.cpp
Original file line number Diff line number Diff line change
@@ -291,6 +291,11 @@ void QgsPanningWidget::setPolygon( const QPolygon& p )
{
if ( p == mPoly ) return;
mPoly = p;

//ensure polygon is closed
if ( mPoly.at( 0 ) != mPoly.at( mPoly.length() - 1 ) )
mPoly.append( mPoly.at( 0 ) );

setGeometry( p.boundingRect() );
update();
}
@@ -303,7 +308,13 @@ void QgsPanningWidget::paintEvent( QPaintEvent* pe )
p.begin( this );
p.setPen( Qt::red );
QPolygonF t = mPoly.translated( -mPoly.boundingRect().left(), -mPoly.boundingRect().top() );
p.drawConvexPolygon( t );

// drawPolygon causes issues on windows - corners of path may be missing resulting in triangles being drawn
// instead of rectangles! (Same cause as #13343)
QPainterPath path;
path.addPolygon( t );
p.drawPath( path );

p.end();
}

0 comments on commit 2d79b42

Please sign in to comment.