summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/widgets/itemviews/qstyleditemdelegate.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/src/widgets/itemviews/qstyleditemdelegate.cpp b/src/widgets/itemviews/qstyleditemdelegate.cpp
index e92ccc2455..b121800c31 100644
--- a/src/widgets/itemviews/qstyleditemdelegate.cpp
+++ b/src/widgets/itemviews/qstyleditemdelegate.cpp
@@ -355,7 +355,10 @@ void QStyledItemDelegate::initStyleOption(QStyleOptionViewItem *option,
else
mode = QIcon::Normal;
QIcon::State state = option->state & QStyle::State_Open ? QIcon::On : QIcon::Off;
- option->decorationSize = option->icon.actualSize(option->decorationSize, mode, state);
+ QSize actualSize = option->icon.actualSize(option->decorationSize, mode, state);
+ // For highdpi icons actualSize might be larger than decorationSize, which we don't want. Clamp it to decorationSize.
+ option->decorationSize = QSize(qMin(option->decorationSize.width(), actualSize.width()),
+ qMin(option->decorationSize.height(), actualSize.height()));
break;
}
case QVariant::Color: {
@@ -367,13 +370,13 @@ void QStyledItemDelegate::initStyleOption(QStyleOptionViewItem *option,
case QVariant::Image: {
QImage image = qvariant_cast<QImage>(value);
option->icon = QIcon(QPixmap::fromImage(image));
- option->decorationSize = image.size();
+ option->decorationSize = image.size() / image.devicePixelRatio();
break;
}
case QVariant::Pixmap: {
QPixmap pixmap = qvariant_cast<QPixmap>(value);
option->icon = QIcon(pixmap);
- option->decorationSize = pixmap.size();
+ option->decorationSize = pixmap.size() / pixmap.devicePixelRatio();
break;
}
default: