Account for pixmap's device pixel ratio when calculating the label size

When determining the size of the QPushButton's label then the device
pixel ratio of the pixmap used to represent the icon needs to be taken
into consideration so it is rendered correctly.

Change-Id: If32760b120d7a749a51e2c30592d621c0e63dace
Reviewed-by: Pierre Rossi <pierre.rossi@theqtcompany.com>
Reviewed-by: Olivier Goffart (Woboq GmbH) <ogoffart@woboq.com>
This commit is contained in:
Andy Shaw 2015-01-12 21:08:13 +01:00
parent 17cce24648
commit 730d07df83

View File

@ -3397,8 +3397,10 @@ void QStyleSheetStyle::drawControl(ControlElement ce, const QStyleOption *opt, Q
state = QIcon::On; state = QIcon::On;
QPixmap pixmap = button->icon.pixmap(button->iconSize, mode, state); QPixmap pixmap = button->icon.pixmap(button->iconSize, mode, state);
int labelWidth = pixmap.width(); int pixmapWidth = pixmap.width() / pixmap.devicePixelRatio();
int labelHeight = pixmap.height(); int pixmapHeight = pixmap.height() / pixmap.devicePixelRatio();
int labelWidth = pixmapWidth;
int labelHeight = pixmapHeight;
int iconSpacing = 4;//### 4 is currently hardcoded in QPushButton::sizeHint() int iconSpacing = 4;//### 4 is currently hardcoded in QPushButton::sizeHint()
int textWidth = button->fontMetrics.boundingRect(opt->rect, tf, button->text).width(); int textWidth = button->fontMetrics.boundingRect(opt->rect, tf, button->text).width();
if (!button->text.isEmpty()) if (!button->text.isEmpty())
@ -3407,15 +3409,15 @@ void QStyleSheetStyle::drawControl(ControlElement ce, const QStyleOption *opt, Q
//Determine label alignment: //Determine label alignment:
if (textAlignment & Qt::AlignLeft) { /*left*/ if (textAlignment & Qt::AlignLeft) { /*left*/
iconRect = QRect(textRect.x(), textRect.y() + (textRect.height() - labelHeight) / 2, iconRect = QRect(textRect.x(), textRect.y() + (textRect.height() - labelHeight) / 2,
pixmap.width(), pixmap.height()); pixmapWidth, pixmapHeight);
} else if (textAlignment & Qt::AlignHCenter) { /* center */ } else if (textAlignment & Qt::AlignHCenter) { /* center */
iconRect = QRect(textRect.x() + (textRect.width() - labelWidth) / 2, iconRect = QRect(textRect.x() + (textRect.width() - labelWidth) / 2,
textRect.y() + (textRect.height() - labelHeight) / 2, textRect.y() + (textRect.height() - labelHeight) / 2,
pixmap.width(), pixmap.height()); pixmapWidth, pixmapHeight);
} else { /*right*/ } else { /*right*/
iconRect = QRect(textRect.x() + textRect.width() - labelWidth, iconRect = QRect(textRect.x() + textRect.width() - labelWidth,
textRect.y() + (textRect.height() - labelHeight) / 2, textRect.y() + (textRect.height() - labelHeight) / 2,
pixmap.width(), pixmap.height()); pixmapWidth, pixmapHeight);
} }
iconRect = visualRect(button->direction, textRect, iconRect); iconRect = visualRect(button->direction, textRect, iconRect);