]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/pixmapviewer.cpp
a bit ugly, but the migration to QList<KFileItem> has to be incremental...
[dolphin.git] / src / pixmapviewer.cpp
index 4fe451a8c6416a869d4dff7c3314edc491f24fa9..e4d417d47171c3d8da2967fc4f9e7a61274435c5 100644 (file)
 #include <QtGui/QPaintEvent>
 
 PixmapViewer::PixmapViewer(QWidget* parent) :
-    QWidget(parent)
+    QWidget(parent),
+    m_animationStep(0)
 {
     setMinimumWidth(K3Icon::SizeEnormous);
     setMinimumWidth(K3Icon::SizeEnormous);
+
+    m_animation.setDuration(300);
+    connect(&m_animation, SIGNAL(valueChanged(qreal)), this, SLOT(update()));
 }
 
 PixmapViewer::~PixmapViewer()
@@ -38,20 +42,35 @@ PixmapViewer::~PixmapViewer()
 
 void PixmapViewer::setPixmap(const QPixmap& pixmap)
 {
+    if (pixmap.isNull()) {
+        return;
+    }
+
+    m_oldPixmap = m_pixmap.isNull() ? pixmap : m_pixmap;
     m_pixmap = pixmap;
-    update();
+
+    m_animation.start();
 }
 
 void PixmapViewer::paintEvent(QPaintEvent* event)
 {
     QWidget::paintEvent(event);
 
-    QPainter painter;
-    painter.begin(this);
-    const int x = (width() - m_pixmap.width()) / 2;
-    const int y = (height() - m_pixmap.height()) / 2;
-    painter.drawPixmap(x, y, m_pixmap);
-    painter.end();
+    QPainter painter(this);
+
+    const float value = m_animation.currentValue();
+
+    const int scaledWidth  = static_cast<int>((m_oldPixmap.width()  * (1.0 - value)) + (m_pixmap.width()  * value));
+    const int scaledHeight = static_cast<int>((m_oldPixmap.height() * (1.0 - value)) + (m_pixmap.height() * value));
+    const int x = (width()  - scaledWidth ) / 2;
+    const int y = (height() - scaledHeight) / 2;
+
+    const QPixmap& largePixmap = (m_oldPixmap.width() > m_pixmap.width()) ? m_oldPixmap : m_pixmap;
+    const QPixmap scaledPixmap = largePixmap.scaled(scaledWidth,
+                                                    scaledHeight,
+                                                    Qt::IgnoreAspectRatio,
+                                                    Qt::SmoothTransformation);
+    painter.drawPixmap(x, y, scaledPixmap);
 }
 
 #include "pixmapviewer.moc"