/* * Copyright 2007 Aaron Seigo * * 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 VIEW_H #define VIEW_H #include #include #include namespace Plasma { class Containment; class Corona; /** * @short A QGraphicsView for Plasma::Applets. Each View is associated with * a Plasma::Containment and tracks geometry changes, maps to the current desktop * (if any) among other helpful utilities. It isn't stricly required to use * a Plasma::View with Plasma enabled applications, but it can make some * things easier. */ class PLASMA_EXPORT View : public QGraphicsView { Q_OBJECT public: /** * Constructs a view for a given contanment. An Id is automatically * assigned to the View. * * @arg containment the containment to center the view on * @arg parent the parent object for this view */ explicit View(Containment *containment, QWidget *parent = 0); /** * Constructs a view for a given contanment. * * @arg containment the containment to center the view on * @arg viewId the id to assign to this view * @arg parent the parent object for this view */ View(Containment *containment, int viewId, QWidget *parent = 0); ~View(); /** * Sets whether or not to draw the containment wallpaper when painting * on this item */ void setDrawWallpaper(bool draw); /** * @return whether or not containments should draw wallpaper */ bool drawWallpaper() const; /** * Sets which screen this view is associated with, if any. * This will also set the containment if a valid screen is specified * * @arg screen the xinerama screen number; -1 for no screen */ void setScreen(int screen); /** * Returns the screen this view is associated with * * @return the xinerama screen number, or -1 for none */ int screen() const; /** * Sets which virtual desktop this view is asociated with, if any. * * @arg desktop a valid desktop number, -1 for all desktops, less than -1 for none */ void setDesktop(int desktop); /** * The virtual desktop this view is associated with * * @return the desktop number, -1 for all desktops and less than -1 for none */ int desktop() const; /** * The virtual desktop this view is actually being viewed on * * @return the desktop number (always valid, never < 0) */ int effectiveDesktop() const; /** * Sets the containment for this view, which will also cause the view * to track the geometry of the containment. * * @arg containment the containment to center the view on */ void setContainment(Containment *containment); /** * @return the containment associated with this view, or 0 if none is */ Containment* containment() const; /** * @return a KConfigGroup for this application unique to the view */ KConfigGroup config() const; /** * @return the id of the View set in the constructor */ int id() const; Q_SIGNALS: /** * This signal is emitted whenever the containment being viewed has * changed its geometry, but before the View has shifted the viewd scene rect * to the new geometry. This is useful for Views which want to keep * their rect() in sync with the containment'sa * * @arg rect the new scene rect. */ void sceneRectAboutToChange(); /** * This signal is emitted whenever the containment being viewed has * changed its geometry, and after the View has shifted the viewd scene rect * to the new geometry. This is useful for Views which want to keep * their rect() in sync with the containment's. * * @arg rect the new scene rect. */ void sceneRectChanged(); protected Q_SLOTS: void updateSceneRect(); private: void initGraphicsView(); class Private; Private * const d; }; } // namespace Plasma #endif