2008-11-04 00:08:39 +01:00
|
|
|
/*
|
|
|
|
* Copyright 2008 Aaron Seigo <aseigo@kde.org>
|
|
|
|
*
|
|
|
|
* 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_PUSHBUTTON_H
|
|
|
|
#define PLASMA_PUSHBUTTON_H
|
|
|
|
|
2012-02-02 10:35:53 +01:00
|
|
|
#include <QGraphicsProxyWidget>
|
2008-11-04 00:08:39 +01:00
|
|
|
|
2009-09-13 19:37:36 +02:00
|
|
|
|
2008-11-04 00:08:39 +01:00
|
|
|
class KPushButton;
|
|
|
|
|
|
|
|
#include <plasma/plasma_export.h>
|
|
|
|
|
|
|
|
namespace Plasma
|
|
|
|
{
|
|
|
|
|
|
|
|
class PushButtonPrivate;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class PushButton plasma/widgets/pushbutton.h <Plasma/Widgets/PushButton>
|
|
|
|
*
|
|
|
|
* @short Provides a plasma-themed KPushButton.
|
|
|
|
*/
|
|
|
|
class PLASMA_EXPORT PushButton : public QGraphicsProxyWidget
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
Q_PROPERTY(QGraphicsWidget *parentWidget READ parentWidget)
|
|
|
|
Q_PROPERTY(QString text READ text WRITE setText)
|
|
|
|
Q_PROPERTY(QString image READ image WRITE setImage)
|
2010-01-19 21:56:51 +01:00
|
|
|
Q_PROPERTY(QString styleSheet READ styleSheet WRITE setStyleSheet)
|
2008-11-04 00:08:39 +01:00
|
|
|
Q_PROPERTY(KPushButton *nativeWidget READ nativeWidget)
|
2009-04-24 09:40:52 +02:00
|
|
|
Q_PROPERTY(QAction *action READ action WRITE setAction)
|
2009-09-13 19:37:36 +02:00
|
|
|
Q_PROPERTY(QIcon icon READ icon WRITE setIcon)
|
2009-11-14 02:06:58 +01:00
|
|
|
Q_PROPERTY(bool checkable READ isCheckable WRITE setCheckable)
|
2009-09-14 08:08:46 +02:00
|
|
|
Q_PROPERTY(bool checked READ isChecked WRITE setChecked)
|
|
|
|
Q_PROPERTY(bool down READ isDown)
|
2008-11-04 00:08:39 +01:00
|
|
|
|
|
|
|
public:
|
|
|
|
explicit PushButton(QGraphicsWidget *parent = 0);
|
|
|
|
~PushButton();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the display text for this PushButton
|
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param text the text to display; should be translated.
|
2008-11-04 00:08:39 +01: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-04 00:08:39 +01:00
|
|
|
*/
|
|
|
|
void setImage(const QString &path);
|
|
|
|
|
2009-07-28 23:07:19 +02: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-28 23:07:19 +02:00
|
|
|
*
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
void setImage(const QString &path, const QString &elementid);
|
|
|
|
|
2008-11-04 00:08:39 +01:00
|
|
|
/**
|
|
|
|
* @return the image path being displayed currently, or an empty string if none.
|
|
|
|
*/
|
|
|
|
QString image() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the stylesheet used to control the visual display of this PushButton
|
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param stylesheet a CSS string
|
2008-11-04 00:08:39 +01:00
|
|
|
*/
|
|
|
|
void setStyleSheet(const QString &stylesheet);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the stylesheet currently used with this widget
|
|
|
|
*/
|
|
|
|
QString styleSheet();
|
|
|
|
|
2009-04-24 09:40:52 +02: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
|
|
|
|
*/
|
|
|
|
void setAction(QAction *action);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the currently associated action, if any.
|
|
|
|
*
|
|
|
|
* @since 4.3
|
|
|
|
*/
|
|
|
|
QAction *action() const;
|
|
|
|
|
2009-09-13 19:37:36 +02:00
|
|
|
/**
|
2012-04-28 13:03:35 +02:00
|
|
|
* sets the icon for this push button using a KDE::icon
|
2009-09-13 19:37:36 +02:00
|
|
|
*
|
2011-06-13 14:47:29 +02:00
|
|
|
* @param icon the icon to use
|
2009-09-13 19:37:36 +02:00
|
|
|
*
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
2012-02-10 10:02:05 +01:00
|
|
|
void setIcon(const QIcon &icon);
|
2009-09-13 19:37:36 +02:00
|
|
|
|
2009-04-24 09:40:52 +02:00
|
|
|
/**
|
|
|
|
* @return the icon of this button
|
|
|
|
*
|
|
|
|
* @since 4.3
|
|
|
|
*/
|
|
|
|
QIcon icon() const;
|
|
|
|
|
2009-06-05 03:29:19 +02:00
|
|
|
/**
|
|
|
|
* Sets whether or not this button can be toggled on/off
|
|
|
|
*
|
|
|
|
* @since 4.3
|
|
|
|
*/
|
|
|
|
void setCheckable(bool checkable);
|
|
|
|
|
2009-11-14 02:06:58 +01:00
|
|
|
/**
|
|
|
|
* @return true if the button is checkable
|
|
|
|
* @see setCheckable
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
bool isCheckable() const;
|
|
|
|
|
2009-06-05 03:29:19 +02:00
|
|
|
/**
|
|
|
|
* @return true if the button is checked; requires setIsCheckable(true) to
|
|
|
|
* be called
|
|
|
|
*
|
|
|
|
* @since 4.3
|
|
|
|
*/
|
|
|
|
bool isChecked() const;
|
|
|
|
|
2009-09-13 20:12:32 +02:00
|
|
|
/**
|
|
|
|
* @return true if the button is pressed down
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
bool isDown() const;
|
|
|
|
|
2008-11-04 00:08:39 +01:00
|
|
|
/**
|
|
|
|
* @return the native widget wrapped by this PushButton
|
|
|
|
*/
|
|
|
|
KPushButton *nativeWidget() const;
|
|
|
|
|
|
|
|
Q_SIGNALS:
|
2009-09-13 18:50:00 +02:00
|
|
|
/**
|
|
|
|
* Emitted when the button is pressed down; usually the clicked() signal
|
|
|
|
* will suffice, however.
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
void pressed();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Emitted when the button is released; usually the clicked() signal
|
|
|
|
* will suffice, however.
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
void released();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Emitted when the button is pressed then released, completing a click
|
|
|
|
*/
|
2008-11-04 00:08:39 +01:00
|
|
|
void clicked();
|
2009-09-13 18:50:00 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Emitted when the button changes state from up to down
|
|
|
|
*/
|
2009-06-05 03:29:19 +02:00
|
|
|
void toggled(bool);
|
2008-11-04 00:08:39 +01:00
|
|
|
|
2010-09-14 19:34:31 +02:00
|
|
|
public Q_SLOTS:
|
|
|
|
/**
|
|
|
|
* Performs a visual click and emits the associated signals
|
|
|
|
* @since 4.6
|
|
|
|
*/
|
|
|
|
void click();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets whether or not this button is checked. Implies setIsCheckable(true).
|
|
|
|
*
|
|
|
|
* @since 4.3
|
|
|
|
*/
|
|
|
|
void setChecked(bool checked);
|
|
|
|
|
2008-11-04 00:08:39 +01: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-12 17:05:39 +02:00
|
|
|
void changeEvent(QEvent *event);
|
2010-01-07 13:50:56 +01:00
|
|
|
QSizeF sizeHint(Qt::SizeHint which, const QSizeF & constraint) const;
|
2008-11-04 00:08:39 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
Q_PRIVATE_SLOT(d, void syncBorders())
|
2009-09-13 19:13:55 +02:00
|
|
|
Q_PRIVATE_SLOT(d, void setPixmap())
|
2010-08-16 23:16:53 +02:00
|
|
|
Q_PRIVATE_SLOT(d, void pressedChanged())
|
2010-09-11 00:31:58 +02:00
|
|
|
Q_PRIVATE_SLOT(d, void syncToAction())
|
2011-01-03 00:17:57 +01:00
|
|
|
Q_PRIVATE_SLOT(d, void clearAction())
|
2010-10-23 03:37:21 +02:00
|
|
|
Q_PRIVATE_SLOT(d, void setPalette())
|
2009-09-13 19:13:55 +02:00
|
|
|
|
|
|
|
friend class PushButtonPrivate;
|
|
|
|
PushButtonPrivate *const d;
|
2008-11-04 00:08:39 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Plasma
|
|
|
|
|
|
|
|
#endif // multiple inclusion guard
|