dolphin/src/pixmapviewer.h
Peter Penz 74c1d61aa3 Since Qt 4.5 it is possible to have translucient windows. The tooltip approach having a delegate and custom drawing + animation code for transparent tooltips has now been replaced by a translucient window where any kind of (animated) widget can be embedded. Still a lot of finetuning has to be done, but maybe this code can be part of kdelibs in KDE 4.5 (systemsettings currently used the Dolphin tooltips code).
Additionally the tooltip uses now KMetaDataWidget instead of using KMetaInfo. This assures that no blocking of the application will occur even if there is a buggy Strigi analyzer that ignores the maximum size-setting and might block the retrieving of the meta data.

BUG: 182941
BUG: 195878

svn path=/trunk/KDE/kdebase/apps/; revision=1044485
2009-11-03 21:48:27 +00:00

98 lines
3.2 KiB
C++

/***************************************************************************
* Copyright (C) 2006 by Peter Penz <peter.penz@gmx.at> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
#ifndef PIXMAPVIEWER_H
#define PIXMAPVIEWER_H
#include <QWidget>
#include <QPixmap>
#include <QQueue>
#include <QTimeLine>
class QPaintEvent;
/**
* @brief Widget which shows a pixmap centered inside the boundaries.
*
* When the pixmap is changed, a smooth transition is done from the old pixmap
* to the new pixmap.
*/
class PixmapViewer : public QWidget
{
Q_OBJECT
public:
enum Transition
{
/** No transition is done when the pixmap is changed. */
NoTransition,
/**
* The old pixmap is replaced by the new pixmap and the size is
* adjusted smoothly to the size of the new pixmap.
*/
DefaultTransition,
/**
* If the old pixmap and the new pixmap have the same content, but
* a different size it is recommended to use Transition::SizeTransition
* instead of Transition::DefaultTransition. In this case it is assured
* that the larger pixmap is used for downscaling, which leads
* to an improved scaling output.
*/
SizeTransition
};
explicit PixmapViewer(QWidget* parent,
Transition transition = DefaultTransition);
virtual ~PixmapViewer();
void setPixmap(const QPixmap& pixmap);
QPixmap pixmap() const;
/**
* Sets the size hint to \a size and triggers a relayout
* of the parent widget. Per default no size hint is given.
*/
void setSizeHint(const QSize& size);
virtual QSize sizeHint() const;
protected:
virtual void paintEvent(QPaintEvent* event);
private Q_SLOTS:
void checkPendingPixmaps();
private:
QPixmap m_pixmap;
QPixmap m_oldPixmap;
QQueue<QPixmap> m_pendingPixmaps;
QTimeLine m_animation;
Transition m_transition;
int m_animationStep;
QSize m_sizeHint;
};
inline QPixmap PixmapViewer::pixmap() const
{
return m_pixmap;
}
#endif