forked from qt-creator/qt-creator
Show animated images in ImageView with QMovie.
Change-Id: I108190595deb710a83249bfd017f5393b27850b6 Reviewed-by: Eike Ziller <eike.ziller@nokia.com>
This commit is contained in:
committed by
Eike Ziller
parent
ce7113619f
commit
6bfb167c3b
BIN
src/plugins/imageviewer/images/pause-small.png
Normal file
BIN
src/plugins/imageviewer/images/pause-small.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 3.0 KiB |
BIN
src/plugins/imageviewer/images/play-small.png
Normal file
BIN
src/plugins/imageviewer/images/play-small.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 3.3 KiB |
@@ -45,6 +45,7 @@
|
|||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QWheelEvent>
|
#include <QWheelEvent>
|
||||||
#include <QMouseEvent>
|
#include <QMouseEvent>
|
||||||
|
#include <QMovie>
|
||||||
#include <QGraphicsRectItem>
|
#include <QGraphicsRectItem>
|
||||||
#include <QPixmap>
|
#include <QPixmap>
|
||||||
#ifndef QT_NO_SVG
|
#ifndef QT_NO_SVG
|
||||||
@@ -53,7 +54,6 @@
|
|||||||
#include <QImageReader>
|
#include <QImageReader>
|
||||||
#include <qmath.h>
|
#include <qmath.h>
|
||||||
|
|
||||||
|
|
||||||
namespace ImageViewer {
|
namespace ImageViewer {
|
||||||
namespace Constants {
|
namespace Constants {
|
||||||
const qreal DEFAULT_SCALE_FACTOR = 1.2;
|
const qreal DEFAULT_SCALE_FACTOR = 1.2;
|
||||||
@@ -61,13 +61,40 @@ namespace Constants {
|
|||||||
|
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
|
|
||||||
|
class MovieItem : public QGraphicsPixmapItem
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
MovieItem(QMovie *movie)
|
||||||
|
: m_movie(movie)
|
||||||
|
{
|
||||||
|
setPixmap(m_movie->currentPixmap());
|
||||||
|
}
|
||||||
|
|
||||||
|
void paint(QPainter *painter, const QStyleOptionGraphicsItem *, QWidget *)
|
||||||
|
{
|
||||||
|
painter->setRenderHint(QPainter::SmoothPixmapTransform, true);
|
||||||
|
painter->drawPixmap(offset(), m_movie->currentPixmap());
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
QMovie *m_movie;
|
||||||
|
};
|
||||||
|
|
||||||
struct ImageViewPrivate
|
struct ImageViewPrivate
|
||||||
{
|
{
|
||||||
ImageViewPrivate() : imageItem(0), backgroundItem(0), outlineItem(0) {}
|
ImageViewPrivate()
|
||||||
|
: imageItem(0)
|
||||||
|
, backgroundItem(0)
|
||||||
|
, outlineItem(0)
|
||||||
|
, movie(0)
|
||||||
|
, moviePaused(true)
|
||||||
|
{}
|
||||||
|
|
||||||
QGraphicsItem *imageItem;
|
QGraphicsItem *imageItem;
|
||||||
QGraphicsRectItem *backgroundItem;
|
QGraphicsRectItem *backgroundItem;
|
||||||
QGraphicsRectItem *outlineItem;
|
QGraphicsRectItem *outlineItem;
|
||||||
QSize naturalSize;
|
QMovie *movie;
|
||||||
|
bool moviePaused;
|
||||||
};
|
};
|
||||||
|
|
||||||
ImageView::ImageView(QWidget *parent)
|
ImageView::ImageView(QWidget *parent)
|
||||||
@@ -121,7 +148,6 @@ bool ImageView::openFile(QString fileName)
|
|||||||
if (format.startsWith("svg"))
|
if (format.startsWith("svg"))
|
||||||
isSvg = true;
|
isSvg = true;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
QGraphicsScene *s = scene();
|
QGraphicsScene *s = scene();
|
||||||
|
|
||||||
bool drawBackground = (d->backgroundItem ? d->backgroundItem->isVisible() : false);
|
bool drawBackground = (d->backgroundItem ? d->backgroundItem->isVisible() : false);
|
||||||
@@ -129,20 +155,31 @@ bool ImageView::openFile(QString fileName)
|
|||||||
|
|
||||||
s->clear();
|
s->clear();
|
||||||
resetTransform();
|
resetTransform();
|
||||||
|
delete d->movie;
|
||||||
|
d->movie = 0;
|
||||||
|
|
||||||
// image
|
// image
|
||||||
#ifndef QT_NO_SVG
|
#ifndef QT_NO_SVG
|
||||||
if (isSvg) {
|
if (isSvg) {
|
||||||
d->imageItem = new QGraphicsSvgItem(fileName);
|
d->imageItem = new QGraphicsSvgItem(fileName);
|
||||||
d->naturalSize = QSize();
|
emit imageSizeChanged(QSize());
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
{
|
if (QMovie::supportedFormats().contains(format)) {
|
||||||
|
d->movie = new QMovie(fileName, QByteArray(), this);
|
||||||
|
d->movie->setCacheMode(QMovie::CacheAll);
|
||||||
|
connect(d->movie, SIGNAL(finished()), d->movie, SLOT(start()));
|
||||||
|
connect(d->movie, SIGNAL(updated(QRect)), this, SLOT(updatePixmap(QRect)));
|
||||||
|
connect(d->movie, SIGNAL(resized(QSize)), this, SLOT(pixmapResized(QSize)));
|
||||||
|
d->movie->start();
|
||||||
|
d->moviePaused = false;
|
||||||
|
d->imageItem = new MovieItem(d->movie);
|
||||||
|
} else {
|
||||||
QPixmap pixmap(fileName);
|
QPixmap pixmap(fileName);
|
||||||
QGraphicsPixmapItem *pixmapItem = new QGraphicsPixmapItem(pixmap);
|
QGraphicsPixmapItem *pixmapItem = new QGraphicsPixmapItem(pixmap);
|
||||||
pixmapItem->setTransformationMode(Qt::SmoothTransformation);
|
pixmapItem->setTransformationMode(Qt::SmoothTransformation);
|
||||||
d->imageItem = pixmapItem;
|
d->imageItem = pixmapItem;
|
||||||
d->naturalSize = pixmap.size();
|
emit imageSizeChanged(pixmap.size());
|
||||||
}
|
}
|
||||||
d->imageItem->setCacheMode(QGraphicsItem::NoCache);
|
d->imageItem->setCacheMode(QGraphicsItem::NoCache);
|
||||||
d->imageItem->setZValue(0);
|
d->imageItem->setZValue(0);
|
||||||
@@ -175,9 +212,23 @@ bool ImageView::openFile(QString fileName)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
QSize ImageView::imageSize() const
|
bool ImageView::isAnimated() const
|
||||||
{
|
{
|
||||||
return d->naturalSize;
|
return d->movie;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ImageView::isPaused() const
|
||||||
|
{
|
||||||
|
return d->moviePaused;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImageView::setPaused(bool paused)
|
||||||
|
{
|
||||||
|
if (!d->movie)
|
||||||
|
return;
|
||||||
|
|
||||||
|
d->movie->setPaused(paused);
|
||||||
|
d->moviePaused = paused;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageView::setViewBackground(bool enable)
|
void ImageView::setViewBackground(bool enable)
|
||||||
@@ -211,6 +262,17 @@ void ImageView::doScale(qreal factor)
|
|||||||
emitScaleFactor();
|
emitScaleFactor();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ImageView::updatePixmap(const QRect &rect)
|
||||||
|
{
|
||||||
|
if (d->imageItem)
|
||||||
|
d->imageItem->update(rect);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImageView::pixmapResized(const QSize &size)
|
||||||
|
{
|
||||||
|
emit imageSizeChanged(size);
|
||||||
|
}
|
||||||
|
|
||||||
void ImageView::wheelEvent(QWheelEvent *event)
|
void ImageView::wheelEvent(QWheelEvent *event)
|
||||||
{
|
{
|
||||||
qreal factor = qPow(Constants::DEFAULT_SCALE_FACTOR, event->delta() / 240.0);
|
qreal factor = qPow(Constants::DEFAULT_SCALE_FACTOR, event->delta() / 240.0);
|
||||||
@@ -247,5 +309,21 @@ void ImageView::emitScaleFactor()
|
|||||||
emit scaleFactorChanged(factor);
|
emit scaleFactorChanged(factor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ImageView::showEvent(QShowEvent *)
|
||||||
|
{
|
||||||
|
if (!d->movie)
|
||||||
|
return;
|
||||||
|
|
||||||
|
d->movie->setPaused(d->moviePaused);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImageView::hideEvent(QHideEvent *)
|
||||||
|
{
|
||||||
|
if (!d->movie)
|
||||||
|
return;
|
||||||
|
|
||||||
|
d->movie->setPaused(true);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
} // namespace ImageView
|
} // namespace ImageView
|
||||||
|
|||||||
@@ -44,7 +44,6 @@
|
|||||||
#define IMAGEVIEW_H
|
#define IMAGEVIEW_H
|
||||||
|
|
||||||
#include <QGraphicsView>
|
#include <QGraphicsView>
|
||||||
#include <QScopedPointer>
|
|
||||||
|
|
||||||
namespace ImageViewer {
|
namespace ImageViewer {
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
@@ -58,10 +57,13 @@ public:
|
|||||||
~ImageView();
|
~ImageView();
|
||||||
|
|
||||||
bool openFile(QString fileName);
|
bool openFile(QString fileName);
|
||||||
QSize imageSize() const;
|
bool isAnimated() const;
|
||||||
|
bool isPaused() const;
|
||||||
|
void setPaused(bool paused);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void scaleFactorChanged(qreal factor);
|
void scaleFactorChanged(qreal factor);
|
||||||
|
void imageSizeChanged(const QSize &size);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void setViewBackground(bool enable);
|
void setViewBackground(bool enable);
|
||||||
@@ -74,9 +76,13 @@ public slots:
|
|||||||
private slots:
|
private slots:
|
||||||
void emitScaleFactor();
|
void emitScaleFactor();
|
||||||
void doScale(qreal factor);
|
void doScale(qreal factor);
|
||||||
|
void updatePixmap(const QRect &rect);
|
||||||
|
void pixmapResized(const QSize &size);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void drawBackground(QPainter *p, const QRectF &rect);
|
void drawBackground(QPainter *p, const QRectF &rect);
|
||||||
|
void hideEvent(QHideEvent *event);
|
||||||
|
void showEvent(QShowEvent *event);
|
||||||
void wheelEvent(QWheelEvent *event);
|
void wheelEvent(QWheelEvent *event);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|||||||
@@ -101,6 +101,10 @@ ImageViewer::ImageViewer(QWidget *parent)
|
|||||||
d->imageView, SLOT(setViewBackground(bool)));
|
d->imageView, SLOT(setViewBackground(bool)));
|
||||||
connect(d->ui_toolbar.toolButtonOutline, SIGNAL(toggled(bool)),
|
connect(d->ui_toolbar.toolButtonOutline, SIGNAL(toggled(bool)),
|
||||||
d->imageView, SLOT(setViewOutline(bool)));
|
d->imageView, SLOT(setViewOutline(bool)));
|
||||||
|
connect(d->ui_toolbar.toolButtonPlayPause, SIGNAL(clicked()),
|
||||||
|
this, SLOT(playToggled()));
|
||||||
|
connect(d->imageView, SIGNAL(imageSizeChanged(QSize)),
|
||||||
|
this, SLOT(imageSizeUpdated(QSize)));
|
||||||
connect(d->imageView, SIGNAL(scaleFactorChanged(qreal)),
|
connect(d->imageView, SIGNAL(scaleFactorChanged(qreal)),
|
||||||
this, SLOT(scaleFactorUpdate(qreal)));
|
this, SLOT(scaleFactorUpdate(qreal)));
|
||||||
}
|
}
|
||||||
@@ -126,11 +130,8 @@ bool ImageViewer::open(QString *errorString, const QString &fileName, const QStr
|
|||||||
}
|
}
|
||||||
setDisplayName(QFileInfo(fileName).fileName());
|
setDisplayName(QFileInfo(fileName).fileName());
|
||||||
d->file->setFileName(fileName);
|
d->file->setFileName(fileName);
|
||||||
const QSize imageSize = d->imageView->imageSize();
|
d->ui_toolbar.toolButtonPlayPause->setVisible(d->imageView->isAnimated());
|
||||||
QString imageSizeText;
|
setPaused(!d->imageView->isAnimated());
|
||||||
if (imageSize.isValid())
|
|
||||||
imageSizeText = QString::fromLatin1("%1x%2").arg(imageSize.width()).arg(imageSize.height());
|
|
||||||
d->ui_toolbar.labelImageSize->setText(imageSizeText);
|
|
||||||
// d_ptr->file->setMimeType
|
// d_ptr->file->setMimeType
|
||||||
emit changed();
|
emit changed();
|
||||||
return true;
|
return true;
|
||||||
@@ -199,6 +200,14 @@ QWidget *ImageViewer::toolBar()
|
|||||||
return d->toolbar;
|
return d->toolbar;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ImageViewer::imageSizeUpdated(const QSize &size)
|
||||||
|
{
|
||||||
|
QString imageSizeText;
|
||||||
|
if (size.isValid())
|
||||||
|
imageSizeText = QString::fromLatin1("%1x%2").arg(size.width()).arg(size.height());
|
||||||
|
d->ui_toolbar.labelImageSize->setText(imageSizeText);
|
||||||
|
}
|
||||||
|
|
||||||
void ImageViewer::scaleFactorUpdate(qreal factor)
|
void ImageViewer::scaleFactorUpdate(qreal factor)
|
||||||
{
|
{
|
||||||
const QString info = QString::number(factor * 100, 'f', 2) + QLatin1Char('%');
|
const QString info = QString::number(factor * 100, 'f', 2) + QLatin1Char('%');
|
||||||
@@ -248,5 +257,28 @@ void ImageViewer::fitToScreen()
|
|||||||
d->ui_toolbar.toolButtonFitToScreen->click();
|
d->ui_toolbar.toolButtonFitToScreen->click();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ImageViewer::togglePlay()
|
||||||
|
{
|
||||||
|
d->ui_toolbar.toolButtonPlayPause->click();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImageViewer::playToggled()
|
||||||
|
{
|
||||||
|
bool paused = d->imageView->isPaused();
|
||||||
|
setPaused(!paused);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImageViewer::setPaused(bool paused)
|
||||||
|
{
|
||||||
|
d->imageView->setPaused(paused);
|
||||||
|
if (paused) {
|
||||||
|
d->ui_toolbar.toolButtonPlayPause->setToolTip(tr("Play Animation"));
|
||||||
|
d->ui_toolbar.toolButtonPlayPause->setIcon(QPixmap(QLatin1String(":/imageviewer/images/play-small.png")));
|
||||||
|
} else {
|
||||||
|
d->ui_toolbar.toolButtonPlayPause->setToolTip(tr("Pause Animation"));
|
||||||
|
d->ui_toolbar.toolButtonPlayPause->setIcon(QPixmap(QLatin1String(":/imageviewer/images/pause-small.png")));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
} // namespace ImageViewer
|
} // namespace ImageViewer
|
||||||
|
|||||||
@@ -78,6 +78,7 @@ public:
|
|||||||
QWidget *toolBar();
|
QWidget *toolBar();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
void imageSizeUpdated(const QSize &size);
|
||||||
void scaleFactorUpdate(qreal factor);
|
void scaleFactorUpdate(qreal factor);
|
||||||
|
|
||||||
void switchViewBackground();
|
void switchViewBackground();
|
||||||
@@ -86,6 +87,10 @@ public slots:
|
|||||||
void zoomOut();
|
void zoomOut();
|
||||||
void resetToOriginalSize();
|
void resetToOriginalSize();
|
||||||
void fitToScreen();
|
void fitToScreen();
|
||||||
|
void togglePlay();
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void playToggled();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/*!
|
/*!
|
||||||
@@ -95,6 +100,7 @@ private:
|
|||||||
\return true if icon is updated, false otherwise
|
\return true if icon is updated, false otherwise
|
||||||
*/
|
*/
|
||||||
bool updateButtonIconByTheme(QAbstractButton *button, const QString &name);
|
bool updateButtonIconByTheme(QAbstractButton *button, const QString &name);
|
||||||
|
void setPaused(bool paused);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
struct ImageViewerPrivate *d;
|
struct ImageViewerPrivate *d;
|
||||||
|
|||||||
@@ -7,5 +7,7 @@
|
|||||||
<file>images/fitinscreen.png</file>
|
<file>images/fitinscreen.png</file>
|
||||||
<file>images/originalsize.png</file>
|
<file>images/originalsize.png</file>
|
||||||
<file>images/background.png</file>
|
<file>images/background.png</file>
|
||||||
|
<file>images/pause-small.png</file>
|
||||||
|
<file>images/play-small.png</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
|||||||
@@ -104,6 +104,13 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QToolButton" name="toolButtonPlayPause">
|
||||||
|
<property name="toolTip">
|
||||||
|
<string>Pause Animation</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="Utils::StyledSeparator" name="widgetToolbarSeparator" native="true"/>
|
<widget class="Utils::StyledSeparator" name="widgetToolbarSeparator" native="true"/>
|
||||||
</item>
|
</item>
|
||||||
@@ -144,6 +151,7 @@
|
|||||||
</customwidgets>
|
</customwidgets>
|
||||||
<resources>
|
<resources>
|
||||||
<include location="imageviewer.qrc"/>
|
<include location="imageviewer.qrc"/>
|
||||||
|
<include location="../coreplugin/core.qrc"/>
|
||||||
</resources>
|
</resources>
|
||||||
<connections/>
|
<connections/>
|
||||||
</ui>
|
</ui>
|
||||||
|
|||||||
Reference in New Issue
Block a user