From 908f62159a705c04c8a403d7d6dfe5ad1d96feec Mon Sep 17 00:00:00 2001 From: Nicolas Werner Date: Wed, 11 May 2022 12:28:27 +0200 Subject: [PATCH] Properly mark image node as dirty on size update --- src/ui/MxcAnimatedImage.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/ui/MxcAnimatedImage.cpp b/src/ui/MxcAnimatedImage.cpp index d4f54a69..8ecea7d9 100644 --- a/src/ui/MxcAnimatedImage.cpp +++ b/src/ui/MxcAnimatedImage.cpp @@ -162,6 +162,8 @@ MxcAnimatedImage::geometryChanged(const QRectF &newGeometry, const QRectF &oldGe QSizeF r = movie.scaledSize(); r.scale(newGeometry.size(), Qt::KeepAspectRatio); movie.setScaledSize(r.toSize()); + imageDirty = true; + update(); } } } @@ -182,7 +184,6 @@ MxcAnimatedImage::updatePaintNode(QSGNode *oldNode, QQuickItem::UpdatePaintNodeD n->setFlags(QSGNode::OwnedByParent); } - // n->setTexture(nullptr); auto img = movie.currentImage(); n->setSourceRect(img.rect()); if (!img.isNull()) @@ -193,8 +194,7 @@ MxcAnimatedImage::updatePaintNode(QSGNode *oldNode, QQuickItem::UpdatePaintNodeD } QSizeF r = img.size(); - if (height() != 0 || width() != 0) - r.scale(size(), Qt::KeepAspectRatio); + r.scale(size(), Qt::KeepAspectRatio); n->setRect((width() - r.width()) / 2, (height() - r.height()) / 2, r.width(), r.height()); n->setFiltering(QSGTexture::Linear);