2009-08-30 23:17:52 +02:00
|
|
|
/***************************************************************************
|
|
|
|
* Copyright 2009 by Alessandro Diaferia <alediaferia@gmail.com> *
|
|
|
|
* Copyright 2009 by Marco Martin <notmart@gmail.com> *
|
|
|
|
* *
|
|
|
|
* 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 ITEMBACKGROUND_H
|
|
|
|
#define ITEMBACKGROUND_H
|
|
|
|
|
|
|
|
#include <QGraphicsWidget>
|
|
|
|
|
2009-08-31 01:11:04 +02:00
|
|
|
#include <plasma/plasma_export.h>
|
2009-08-30 23:17:52 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @class ItemBackground plasma/widgets/itembackground.h
|
|
|
|
*
|
|
|
|
* @short a background for QGraphicsWidget based item views with animation effects
|
|
|
|
*
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
2009-08-31 00:44:47 +02:00
|
|
|
namespace Plasma {
|
|
|
|
|
|
|
|
class FrameSvg;
|
2009-08-30 23:41:06 +02:00
|
|
|
class ItemBackgroundPrivate;
|
|
|
|
|
2009-08-31 01:11:04 +02:00
|
|
|
class PLASMA_EXPORT ItemBackground : public QGraphicsWidget
|
2009-08-30 23:17:52 +02:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
2009-10-05 20:00:06 +02:00
|
|
|
Q_PROPERTY(QRectF target READ target WRITE setTarget)
|
2009-10-05 20:59:21 +02:00
|
|
|
Q_PROPERTY(QGraphicsItem* targetItem READ targetItem WRITE setTargetItem)
|
2009-10-05 20:00:06 +02:00
|
|
|
|
2009-08-30 23:17:52 +02:00
|
|
|
public:
|
|
|
|
ItemBackground(QGraphicsWidget *parent = 0);
|
|
|
|
~ItemBackground();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets a new target geometry we want at the end of animation
|
|
|
|
*
|
|
|
|
* @arg newGeometry the final geometry target
|
|
|
|
*/
|
|
|
|
void setTarget(const QRectF &newGeometry);
|
2009-08-31 11:19:00 +02:00
|
|
|
|
2009-10-05 20:00:06 +02:00
|
|
|
/**
|
|
|
|
* @return the current target rect; may be empty if there is no target currently set
|
|
|
|
*/
|
|
|
|
QRectF target() const;
|
|
|
|
|
2009-08-30 23:17:52 +02:00
|
|
|
/**
|
|
|
|
* set the ItemBackground geometry to be the target geometry, plus the ItemBackground margins
|
|
|
|
*/
|
|
|
|
void setTargetItem(QGraphicsItem *target);
|
2009-08-31 11:19:00 +02:00
|
|
|
|
2009-10-05 20:59:21 +02:00
|
|
|
/**
|
|
|
|
* @return the target item, if any
|
|
|
|
*/
|
|
|
|
QGraphicsItem *targetItem() const;
|
|
|
|
|
2009-08-31 11:19:00 +02:00
|
|
|
/**
|
|
|
|
* @reimp from QGraphicsWidget
|
|
|
|
*/
|
2009-08-30 23:17:52 +02:00
|
|
|
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget);
|
|
|
|
|
2009-08-31 14:14:47 +02:00
|
|
|
Q_SIGNALS:
|
|
|
|
/**
|
|
|
|
* Emitted when the visual layout and appearance changes. Useful for syncronizing
|
|
|
|
* content margins.
|
|
|
|
*/
|
|
|
|
void appearanceChanged();
|
|
|
|
|
2009-10-02 21:06:14 +02:00
|
|
|
/**
|
|
|
|
* Emitted at each animation frame. Useful for synchronizing item animations
|
|
|
|
*/
|
|
|
|
void animationStep(qreal progress);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Emitted when the target has been reached. Useful to consider this instead of
|
|
|
|
* the corresponding hoverEnterEvent;
|
|
|
|
*/
|
2009-10-05 20:00:06 +02:00
|
|
|
void targetReached(QRectF);
|
2009-10-02 21:06:14 +02:00
|
|
|
|
2009-10-05 20:00:06 +02:00
|
|
|
/**
|
|
|
|
* Emitted when the target has been reached. Useful to consider this instead of
|
|
|
|
* the corresponding hoverEnterEvent;
|
|
|
|
*/
|
2009-10-06 18:44:23 +02:00
|
|
|
void targetItemReached(QGraphicsItem *);
|
2009-10-02 21:06:14 +02:00
|
|
|
|
2009-08-30 23:17:52 +02:00
|
|
|
protected:
|
2009-08-31 11:19:00 +02:00
|
|
|
/**
|
|
|
|
* @reimp from QGraphicsWidget
|
|
|
|
*/
|
2009-08-30 23:17:52 +02:00
|
|
|
QVariant itemChange(GraphicsItemChange change, const QVariant &value);
|
|
|
|
|
2009-09-23 22:29:56 +02:00
|
|
|
/**
|
|
|
|
* @reimp from QObject
|
|
|
|
*/
|
|
|
|
bool eventFilter(QObject *watched, QEvent *event);
|
|
|
|
|
2009-08-31 12:04:17 +02:00
|
|
|
/**
|
|
|
|
* @reimp from QGraphicsItem
|
|
|
|
*/
|
|
|
|
bool sceneEventFilter(QGraphicsItem *watched, QEvent *event);
|
|
|
|
|
2009-08-31 13:35:37 +02:00
|
|
|
/**
|
|
|
|
* @reimp from QGraphicsItem
|
|
|
|
*/
|
|
|
|
void resizeEvent(QGraphicsSceneResizeEvent *);
|
|
|
|
|
2009-08-30 23:17:52 +02:00
|
|
|
private:
|
2009-08-31 11:19:00 +02:00
|
|
|
Q_PRIVATE_SLOT(d, void animationUpdate(qreal progress))
|
2009-08-31 12:13:44 +02:00
|
|
|
Q_PRIVATE_SLOT(d, void targetDestroyed(QObject*))
|
2009-08-31 14:14:47 +02:00
|
|
|
Q_PRIVATE_SLOT(d, void frameSvgChanged())
|
2009-10-02 21:08:36 +02:00
|
|
|
Q_PRIVATE_SLOT(d, void refreshCurrentTarget())
|
2009-08-31 12:13:44 +02:00
|
|
|
|
2009-08-31 14:14:47 +02:00
|
|
|
friend class ItemBackgroundPrivate;
|
2009-08-31 12:13:44 +02:00
|
|
|
ItemBackgroundPrivate * const d;
|
2009-08-30 23:17:52 +02:00
|
|
|
};
|
2009-08-30 23:41:06 +02:00
|
|
|
}
|
2009-08-30 23:17:52 +02:00
|
|
|
|
|
|
|
#endif
|