2008-11-03 23:08:39 +00: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_LABEL_H
|
|
|
|
#define PLASMA_LABEL_H
|
|
|
|
|
|
|
|
#include <QtGui/QGraphicsProxyWidget>
|
|
|
|
|
|
|
|
#include <plasma/plasma_export.h>
|
|
|
|
#include <plasma/dataengine.h>
|
|
|
|
|
|
|
|
class QLabel;
|
|
|
|
|
|
|
|
namespace Plasma
|
|
|
|
{
|
|
|
|
|
|
|
|
class LabelPrivate;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class Label plasma/widgets/label.h <Plasma/Widgets/Label>
|
|
|
|
*
|
|
|
|
* @short Provides a plasma-themed QLabel.
|
|
|
|
*/
|
|
|
|
class PLASMA_EXPORT Label : 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)
|
2008-12-23 20:39:59 +00:00
|
|
|
Q_PROPERTY(Qt::Alignment alignment READ alignment WRITE setAlignment)
|
2008-12-30 20:53:02 +00:00
|
|
|
Q_PROPERTY(bool hasScaledContents READ hasScaledContents WRITE setScaledContents)
|
2008-11-03 23:08:39 +00:00
|
|
|
Q_PROPERTY(QString styleSheet READ styleSheet WRITE setStyleSheet)
|
|
|
|
Q_PROPERTY(QLabel *nativeWidget READ nativeWidget)
|
|
|
|
|
|
|
|
public:
|
2009-03-05 15:41:01 +00:00
|
|
|
/**
|
|
|
|
* Constructs a label with word wrap on by default
|
|
|
|
*
|
|
|
|
* @arg parent the parent of this widget
|
|
|
|
*/
|
2008-11-03 23:08:39 +00:00
|
|
|
explicit Label(QGraphicsWidget *parent = 0);
|
|
|
|
~Label();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the display text for this Label
|
|
|
|
*
|
|
|
|
* @arg text the text to display; should be translated.
|
|
|
|
*/
|
|
|
|
void setText(const QString &text);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the display text
|
|
|
|
*/
|
|
|
|
QString text() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the path to an image to display.
|
|
|
|
*
|
|
|
|
* @arg path the path to the image; if a relative path, then a themed image will be loaded.
|
|
|
|
*/
|
|
|
|
void setImage(const QString &path);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the image path being displayed currently, or an empty string if none.
|
|
|
|
*/
|
|
|
|
QString image() const;
|
|
|
|
|
2008-12-23 20:39:59 +00:00
|
|
|
/**
|
|
|
|
* Sets the alignment for the text
|
|
|
|
*
|
|
|
|
* @arg the desired alignment
|
|
|
|
*/
|
|
|
|
void setAlignment(Qt::Alignment alignment);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the alignment for the text used in the labels
|
|
|
|
*/
|
|
|
|
Qt::Alignment alignment() const;
|
|
|
|
|
2008-12-30 20:53:02 +00:00
|
|
|
/**
|
|
|
|
* Scale or not the contents of the label to the label size
|
|
|
|
*
|
|
|
|
* @arg scale
|
|
|
|
*/
|
|
|
|
void setScaledContents(bool scaled);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return true if the contents are scaled to the label size
|
|
|
|
*/
|
|
|
|
bool hasScaledContents() const;
|
|
|
|
|
2009-08-29 16:59:28 +00:00
|
|
|
/**
|
|
|
|
* Set if the text on the label can be selected with the mouse
|
|
|
|
*
|
|
|
|
* @arg enable true if we want to manage text selection with the mouse
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
void setTextSelectable(bool enable);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return true if the text is selectable with the mouse
|
|
|
|
* @since 4.4
|
|
|
|
*/
|
|
|
|
bool textSelectable() const;
|
|
|
|
|
2008-11-03 23:08:39 +00:00
|
|
|
/**
|
|
|
|
* Sets the stylesheet used to control the visual display of this Label
|
|
|
|
*
|
|
|
|
* @arg stylesheet a CSS string
|
|
|
|
*/
|
|
|
|
void setStyleSheet(const QString &stylesheet);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the stylesheet currently used with this widget
|
|
|
|
*/
|
|
|
|
QString styleSheet();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the native widget wrapped by this Label
|
|
|
|
*/
|
|
|
|
QLabel *nativeWidget() const;
|
|
|
|
|
|
|
|
Q_SIGNALS:
|
|
|
|
void linkActivated(const QString &link);
|
2009-02-28 20:25:13 +00:00
|
|
|
void linkHovered(const QString &link);
|
2008-11-03 23:08:39 +00:00
|
|
|
|
|
|
|
public Q_SLOTS:
|
|
|
|
void dataUpdated(const QString &sourceName, const Plasma::DataEngine::Data &data);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
void resizeEvent(QGraphicsSceneResizeEvent *event);
|
2009-08-29 16:59:28 +00:00
|
|
|
void mousePressEvent(QGraphicsSceneMouseEvent *event);
|
2009-08-17 12:24:33 +00:00
|
|
|
void paint(QPainter *painter,
|
|
|
|
const QStyleOptionGraphicsItem *option,
|
|
|
|
QWidget *widget);
|
2008-11-03 23:08:39 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
Q_PRIVATE_SLOT(d, void setPalette())
|
|
|
|
|
|
|
|
LabelPrivate * const d;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Plasma
|
|
|
|
|
|
|
|
#endif // multiple inclusion guard
|