2008-11-11 09:30:05 +00:00
|
|
|
/*
|
2008-11-11 12:52:25 +00:00
|
|
|
* Copyright 2008 Marco Martin <notmart@gmail.com>
|
2008-11-11 09:30:05 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Library General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2, 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 Library 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 PLASMA_TOOLBUTTON_H
|
|
|
|
#define PLASMA_TOOLBUTTON_H
|
|
|
|
|
|
|
|
#include <QtGui/QGraphicsProxyWidget>
|
|
|
|
|
|
|
|
class QToolButton;
|
|
|
|
|
|
|
|
#include <plasma/plasma_export.h>
|
|
|
|
|
|
|
|
namespace Plasma
|
|
|
|
{
|
|
|
|
|
|
|
|
class ToolButtonPrivate;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class ToolButton plasma/widgets/pushbutton.h <Plasma/Widgets/ToolButton>
|
|
|
|
*
|
|
|
|
* @short Provides a plasma-themed QToolButton.
|
|
|
|
*/
|
|
|
|
class PLASMA_EXPORT ToolButton : public QGraphicsProxyWidget
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
Q_PROPERTY(QGraphicsWidget *parentWidget READ parentWidget)
|
|
|
|
Q_PROPERTY(QString text READ text WRITE setText)
|
2008-11-11 12:50:42 +00:00
|
|
|
Q_PROPERTY(bool autoRaise READ autoRaise WRITE setAutoRaise)
|
2008-11-11 09:30:05 +00:00
|
|
|
Q_PROPERTY(QString image READ image WRITE setImage)
|
2010-01-19 21:23:05 +00:00
|
|
|
Q_PROPERTY(QString styleSheet READ styleSheet WRITE setStyleSheet)
|
2008-11-11 09:30:05 +00:00
|
|
|
Q_PROPERTY(QToolButton *nativeWidget READ nativeWidget)
|
2009-04-24 07:40:52 +00:00
|
|
|
Q_PROPERTY(QAction *action READ action WRITE setAction)
|
2010-01-19 22:28:49 +00:00
|
|
|
Q_PROPERTY(bool down READ isDown WRITE setDown)
|
2008-11-11 09:30:05 +00:00
|
|
|
|
2010-01-20 20:27:41 +00:00
|
|
|
Q_PROPERTY(qreal animationUpdate READ animationUpdate WRITE setAnimationUpdate)
|
|
|
|
|
2008-11-11 09:30:05 +00:00
|
|
|
public:
|
|
|
|
explicit ToolButton(QGraphicsWidget *parent = 0);
|
|
|
|
~ToolButton();
|
|
|
|
|
2008-11-11 12:50:42 +00:00
|
|
|
/**
|
|
|
|
* Sets if the toolbutton has an autoraise behaviour
|
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param raise
|
2008-11-11 12:50:42 +00:00
|
|
|
*/
|
|
|
|
void setAutoRaise(bool raise);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return true if the toolbutton has an autoraise behaviour
|
|
|
|
*/
|
|
|
|
bool autoRaise() const;
|
|
|
|
|
2008-11-11 09:30:05 +00:00
|
|
|
/**
|
|
|
|
* Sets the display text for this ToolButton
|
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param text the text to display; should be translated.
|
2008-11-11 09:30:05 +00:00
|
|
|
*/
|
|
|
|
void setText(const QString &text);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the display text
|
|
|
|
*/
|
|
|
|
QString text() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the path to an image to display.
|
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param path the path to the image; if a relative path, then a themed image will be loaded.
|
2008-11-11 09:30:05 +00:00
|
|
|
*/
|
|
|
|
void setImage(const QString &path);
|
|
|
|
|
2009-07-16 18:03:22 +00:00
|
|
|
/**
|
|
|
|
* Sets the path to an svg image to display and the id of the used svg element, if necessary.
|
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param path the path to the image; if a relative path, then a themed image will be loaded.
|
|
|
|
* @param elementid the id of a svg element.
|
2009-07-16 18:03:22 +00:00
|
|
|
*
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
void setImage(const QString &path, const QString &elementid);
|
|
|
|
|
2008-11-11 09:30:05 +00:00
|
|
|
/**
|
|
|
|
* @return the image path being displayed currently, or an empty string if none.
|
|
|
|
*/
|
|
|
|
QString image() const;
|
|
|
|
|
2010-01-19 16:20:41 +00:00
|
|
|
/**
|
|
|
|
* Sets the status of the button to pressed
|
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param down
|
2010-01-19 16:20:41 +00:00
|
|
|
* @since 4.5
|
|
|
|
*/
|
|
|
|
void setDown(bool down);
|
|
|
|
|
2009-10-05 17:16:09 +00:00
|
|
|
/**
|
|
|
|
* @return true if the button is pressed down
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
bool isDown() const;
|
|
|
|
|
2008-11-11 09:30:05 +00:00
|
|
|
/**
|
|
|
|
* Sets the stylesheet used to control the visual display of this ToolButton
|
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param stylesheet a CSS string
|
2008-11-11 09:30:05 +00:00
|
|
|
*/
|
|
|
|
void setStyleSheet(const QString &stylesheet);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the stylesheet currently used with this widget
|
|
|
|
*/
|
|
|
|
QString styleSheet();
|
|
|
|
|
|
|
|
/**
|
2009-04-24 07:40:52 +00:00
|
|
|
* Associate an action with this IconWidget
|
|
|
|
* this makes the button follow the state of the action, using its icon, text, etc.
|
|
|
|
* when the button is clicked, it will also trigger the action.
|
|
|
|
*
|
|
|
|
* @since 4.3
|
2008-11-11 09:30:05 +00:00
|
|
|
*/
|
2009-04-24 07:40:52 +00:00
|
|
|
void setAction(QAction *action);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the currently associated action, if any.
|
|
|
|
*
|
|
|
|
* @since 4.3
|
|
|
|
*/
|
|
|
|
QAction *action() const;
|
2008-11-11 09:30:05 +00:00
|
|
|
|
2009-01-18 17:28:04 +00:00
|
|
|
/**
|
|
|
|
* sets the icon for this toolbutton
|
2009-05-31 12:20:57 +00:00
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param icon the icon we want to use
|
2009-05-31 12:20:57 +00:00
|
|
|
*
|
|
|
|
* @since 4.3
|
2009-01-18 17:28:04 +00:00
|
|
|
*/
|
|
|
|
void setIcon(const QIcon &icon);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the icon of this button
|
2009-05-31 12:20:57 +00:00
|
|
|
*
|
|
|
|
* @since 4.3
|
2009-01-18 17:28:04 +00:00
|
|
|
*/
|
|
|
|
QIcon icon() const;
|
|
|
|
|
2009-04-24 07:40:52 +00:00
|
|
|
/**
|
|
|
|
* @return the native widget wrapped by this ToolButton
|
|
|
|
*/
|
|
|
|
QToolButton *nativeWidget() const;
|
|
|
|
|
2008-11-11 09:30:05 +00:00
|
|
|
Q_SIGNALS:
|
|
|
|
void clicked();
|
2009-10-05 17:20:05 +00:00
|
|
|
/**
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
void pressed();
|
2009-10-13 15:29:23 +00:00
|
|
|
/**
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
void released();
|
2008-11-11 09:30:05 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
void paint(QPainter *painter,
|
|
|
|
const QStyleOptionGraphicsItem *option,
|
|
|
|
QWidget *widget = 0);
|
|
|
|
void resizeEvent(QGraphicsSceneResizeEvent *event);
|
|
|
|
void hoverEnterEvent(QGraphicsSceneHoverEvent *event);
|
|
|
|
void hoverLeaveEvent(QGraphicsSceneHoverEvent *event);
|
2009-09-13 13:13:55 +00:00
|
|
|
void changeEvent(QEvent *event);
|
2010-07-07 14:24:38 +00:00
|
|
|
QVariant itemChange(GraphicsItemChange change, const QVariant &value);
|
2010-01-07 12:44:20 +00:00
|
|
|
QSizeF sizeHint(Qt::SizeHint which, const QSizeF & constraint) const;
|
2008-11-11 09:30:05 +00:00
|
|
|
|
2010-01-20 20:27:41 +00:00
|
|
|
private slots:
|
|
|
|
void setAnimationUpdate(qreal progress);
|
|
|
|
qreal animationUpdate() const;
|
|
|
|
|
2008-11-11 09:30:05 +00:00
|
|
|
private:
|
|
|
|
Q_PRIVATE_SLOT(d, void syncBorders())
|
2009-04-24 07:40:52 +00:00
|
|
|
Q_PRIVATE_SLOT(d, void syncToAction())
|
|
|
|
Q_PRIVATE_SLOT(d, void clearAction())
|
2009-09-13 17:13:55 +00:00
|
|
|
Q_PRIVATE_SLOT(d, void setPixmap())
|
2010-10-23 01:37:21 +00:00
|
|
|
Q_PRIVATE_SLOT(d, void setPalette())
|
2009-09-13 17:13:55 +00:00
|
|
|
|
|
|
|
friend class ToolButtonPrivate;
|
|
|
|
ToolButtonPrivate *const d;
|
2008-11-11 09:30:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Plasma
|
|
|
|
|
|
|
|
#endif // multiple inclusion guard
|