/* * Copyright 2008 Marco Martin * * 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_FRAME_H #define PLASMA_FRAME_H #include #include class QFrame; namespace Plasma { class FramePrivate; /** * @short A widget that provides a simple frame * A simple frame to group widgets, it can have a plain, sunken or raise aspect * the default aspect is plain */ class PLASMA_EXPORT Frame : public QGraphicsWidget { Q_OBJECT public: enum Shadow { Plain = 1, Raised, Sunken }; /** * Constructs a new Frame * * @arg parent the parent of this widget */ explicit Frame(QGraphicsWidget *parent = 0); ~Frame(); /** * Sets the Frame's shadow style * * @arg shadow plain, raised or sunken */ void setFrameShadow(Shadow shadow); /** * @return the Frame's shadow style */ Shadow frameShadow() const; /** * Set the text to display by this Frame * * @arg text the text */ void setText(QString text); /** * @return text displayed from this Frame */ 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; /** * Sets the stylesheet used to control the visual display of this Frame * * @arg stylesheet a CSS string */ void setStyleSheet(const QString &stylesheet); /** * @return the stylesheet currently used with this widget */ QString styleSheet() const; /** * @return the native widget wrapped by this Label */ QWidget* nativeWidget() const; protected: void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0); void resizeEvent(QGraphicsSceneResizeEvent *event); private: FramePrivate * const d; Q_PRIVATE_SLOT(d, void syncBorders()) }; } // namespace Plasma #endif // multiple inclusion guard