diff --git a/src/ImageViewer.cpp b/src/ImageViewer.cpp --- a/src/ImageViewer.cpp +++ b/src/ImageViewer.cpp @@ -87,14 +87,19 @@ } d->img = img; - d->scene->setSceneRect(0, 0, img->width(), img->height()); + const auto dpr = devicePixelRatioF(); + d->img->setDevicePixelRatio(dpr); + d->scene->setSceneRect(0, 0, img->width() / dpr, img->height() / dpr); } // ------------------------------------------------------------------------ void ImageViewer::drawBackground(QPainter *painter, const QRectF &rect) { painter->fillRect(rect, QColor(0x70, 0x70, 0x70)); - painter->drawImage(rect, *d->img, rect); + QRectF r = rect & sceneRect(); + const qreal dpr = d->img->devicePixelRatio(); + QRectF srcRect = QRectF(r.topLeft() * dpr, r.size() * dpr); + painter->drawImage(r, *d->img, srcRect); } // ------------------------------------------------------------------------ @@ -118,7 +123,10 @@ // ------------------------------------------------------------------------ void ImageViewer::zoom2Fit() { - fitInView(d->img->rect(), Qt::KeepAspectRatio); + QRectF r = d->img->rect(); + const auto dpr = d->img->devicePixelRatio(); + r = QRectF(r.topLeft() / dpr, r.size() / dpr); + fitInView(r, Qt::KeepAspectRatio); } // ------------------------------------------------------------------------ diff --git a/src/main.cpp b/src/main.cpp --- a/src/main.cpp +++ b/src/main.cpp @@ -34,6 +34,7 @@ int main(int argc, char *argv[]) { + QCoreApplication::setAttribute(Qt::AA_UseHighDpiPixmaps); QApplication app(argc, argv); Kdelibs4ConfigMigrator migrate(QLatin1String("Skanlite"));