2007-09-18 23:16:17 +02:00
|
|
|
/*
|
|
|
|
* Copyright 2007 by 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_CONTAINMENT_H
|
|
|
|
#define PLASMA_CONTAINMENT_H
|
|
|
|
|
|
|
|
#include <QtGui/QGraphicsItem>
|
|
|
|
#include <QtGui/QWidget>
|
|
|
|
|
|
|
|
#include <kplugininfo.h>
|
|
|
|
#include <ksharedconfig.h>
|
|
|
|
#include <kgenericfactory.h>
|
|
|
|
|
|
|
|
#include <plasma/applet.h>
|
2007-10-24 04:10:10 +02:00
|
|
|
#include <plasma/phase.h>
|
2007-09-18 23:16:17 +02:00
|
|
|
|
|
|
|
namespace Plasma
|
|
|
|
{
|
|
|
|
|
2007-11-12 20:27:21 +01:00
|
|
|
class AppletHandle;
|
2007-09-18 23:16:17 +02:00
|
|
|
class DataEngine;
|
|
|
|
class Package;
|
2007-11-09 01:44:35 +01:00
|
|
|
class Corona;
|
2007-09-18 23:16:17 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @short The base class for plugins that provide backgrounds and applet grouping containers
|
|
|
|
*
|
|
|
|
* Containment objects provide the means to group applets into functional sets.
|
|
|
|
* They also provide the following:
|
|
|
|
*
|
|
|
|
* - drawing of the background image (which can be interactive)
|
|
|
|
* - form factors (e.g. panel, desktop, full screen, etc)
|
|
|
|
* - applet layout management
|
|
|
|
*
|
|
|
|
* Since containment is actually just a Plasma::Applet, all the techniques used
|
|
|
|
* for writing the visual presentation of Applets is applicable to Containtments.
|
|
|
|
* Containments are differentiated from Applets by being marked with the ServiceType
|
|
|
|
* of Plasma/Containment. Plugins registered with both the Applet and the Containment
|
|
|
|
* ServiceTypes can be loaded for us in either situation.
|
|
|
|
*
|
|
|
|
* See techbase.kde.org for a tutorial on writing Containments using this class.
|
|
|
|
*/
|
|
|
|
class PLASMA_EXPORT Containment : public Applet
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
typedef QList<Applet*> List;
|
|
|
|
typedef QHash<QString, Applet*> Dict;
|
|
|
|
|
2007-11-29 01:20:37 +01:00
|
|
|
enum Type { NoContainmentType = -1 /**< @internal */,
|
|
|
|
DesktopContainment = 0 /**< A desktop containment */,
|
2007-11-19 02:19:58 +01:00
|
|
|
PanelContainment /**< A desktop panel */,
|
|
|
|
CustomContainment /**< A containment that is neither a desktop nor a panel,
|
|
|
|
but something application specific */
|
2007-10-09 18:33:52 +02:00
|
|
|
};
|
|
|
|
|
2007-09-18 23:16:17 +02:00
|
|
|
/**
|
|
|
|
* @arg parent the QGraphicsItem this applet is parented to
|
|
|
|
* @arg servideId the name of the .desktop file containing the
|
|
|
|
* information about the widget
|
|
|
|
* @arg appletId a unique id used to differentiate between multiple
|
|
|
|
* instances of the same Applet type
|
|
|
|
*/
|
|
|
|
explicit Containment(QGraphicsItem* parent = 0,
|
|
|
|
const QString& serviceId = QString(),
|
|
|
|
uint containmentId = 0);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This constructor is to be used with the plugin loading systems
|
|
|
|
* found in KPluginInfo and KService. The argument list is expected
|
|
|
|
* to have two elements: the KService service ID for the desktop entry
|
|
|
|
* and an applet ID which must be a base 10 number.
|
|
|
|
*
|
|
|
|
* @arg parent a QObject parent; you probably want to pass in 0
|
|
|
|
* @arg args a list of strings containing two entries: the service id
|
|
|
|
* and the applet id
|
|
|
|
*/
|
|
|
|
Containment(QObject* parent, const QVariantList& args);
|
|
|
|
|
|
|
|
~Containment();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reimplemented from Applet
|
|
|
|
*/
|
|
|
|
void init();
|
|
|
|
|
2007-10-09 18:33:52 +02:00
|
|
|
/**
|
|
|
|
* Returns the type of containment
|
|
|
|
*/
|
2007-11-28 22:46:17 +01:00
|
|
|
Type containmentType() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the type of this containment.
|
|
|
|
*/
|
|
|
|
void setContainmentType(Containment::Type type);
|
2007-10-09 18:33:52 +02:00
|
|
|
|
2007-09-18 23:16:17 +02:00
|
|
|
/**
|
|
|
|
* Returns the current form factor the applets in this Containment
|
|
|
|
* are being displayed in.
|
|
|
|
*
|
|
|
|
* @see Plasma::FormFactor
|
|
|
|
*/
|
|
|
|
FormFactor formFactor() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the location of this Containment
|
|
|
|
*
|
|
|
|
* @see Plasma::Location
|
|
|
|
*/
|
|
|
|
Location location() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a list of all known containments.
|
|
|
|
*
|
|
|
|
* @param category Only applets matchin this category will be returned.
|
|
|
|
* Useful in conjunction with knownCategories.
|
2007-10-03 17:46:40 +02:00
|
|
|
* If "Misc" is passed in, then applets without a
|
2007-09-18 23:16:17 +02:00
|
|
|
* Categories= entry are also returned.
|
|
|
|
* If an empty string is passed in, all applets are
|
|
|
|
* returned.
|
2007-10-03 17:46:40 +02:00
|
|
|
* @param parentApp the application to filter applets on. Uses the
|
2007-09-18 23:16:17 +02:00
|
|
|
* X-KDE-ParentApp entry (if any) in the plugin info.
|
|
|
|
* The default value of QString() will result in a
|
|
|
|
* list containing only applets not specifically
|
|
|
|
* registered to an application.
|
|
|
|
* @return list of applets
|
|
|
|
**/
|
|
|
|
static KPluginInfo::List knownContainments(const QString &category = QString(),
|
|
|
|
const QString &parentApp = QString());
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a list of all known applets associated with a certain mimetype
|
|
|
|
*
|
|
|
|
* @return list of applets
|
|
|
|
**/
|
|
|
|
static KPluginInfo::List knownContainmentsForMimetype(const QString &mimetype);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds an applet to this Containment
|
|
|
|
*
|
|
|
|
* @param name the plugin name for the applet, as given by
|
|
|
|
* KPluginInfo::pluginName()
|
|
|
|
* @param args argument list to pass to the plasmoid
|
|
|
|
* @param id to assign to this applet, or 0 to auto-assign it a new id
|
|
|
|
* @param geometry where to place the applet, or to auto-place it if an invalid
|
|
|
|
* is provided
|
|
|
|
* @param delayedInit if true, init() will not be called on the applet
|
|
|
|
*
|
|
|
|
* @return a pointer to the applet on success, or 0 on failure
|
|
|
|
*/
|
|
|
|
Applet* addApplet(const QString& name, const QVariantList& args = QVariantList(),
|
|
|
|
uint id = 0, const QRectF &geometry = QRectF(-1, -1, -1, -1),
|
|
|
|
bool delayedInit = false);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the applets currently in this Containment
|
|
|
|
*/
|
|
|
|
Applet::List applets() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes all applets from this Containment
|
|
|
|
*/
|
|
|
|
void clearApplets();
|
|
|
|
|
2007-11-26 22:57:50 +01:00
|
|
|
/**
|
|
|
|
* add existing applet to this containment
|
|
|
|
*/
|
|
|
|
void addApplet(Applet * applet);
|
|
|
|
|
2007-09-18 23:16:17 +02:00
|
|
|
/**
|
|
|
|
* Sets the physical screen this Containment is associated with.
|
|
|
|
*
|
|
|
|
* @param screen the screen number this containment is the desktop for, or -1
|
|
|
|
* if it is not serving as the desktop for any screen
|
|
|
|
*/
|
|
|
|
void setScreen(int screen);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the screen number this containment is serving as the desktop for
|
|
|
|
* or -1 if none
|
|
|
|
*/
|
|
|
|
int screen() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void saveConstraints(KConfigGroup* group) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
2007-11-17 04:31:25 +01:00
|
|
|
void loadConstraints(KConfigGroup* group);
|
2007-09-18 23:16:17 +02:00
|
|
|
|
2007-11-15 12:06:33 +01:00
|
|
|
/**
|
|
|
|
* Emits the launchActivated() signal
|
|
|
|
*/
|
|
|
|
void emitLaunchActivated();
|
|
|
|
|
2007-11-19 02:19:58 +01:00
|
|
|
/**
|
|
|
|
* Adds an item to the toolbox. The toolbox takes over ownership of the item.
|
|
|
|
*/
|
2007-12-05 21:26:23 +01:00
|
|
|
void addToolBoxTool(QGraphicsItem *tool, const QString &toolname = QString());
|
2007-11-19 02:19:58 +01:00
|
|
|
|
2007-12-14 07:34:26 +01:00
|
|
|
/**
|
|
|
|
* Enables or disables a toolbox tool by name
|
|
|
|
*
|
|
|
|
* @arg name the name of the tool
|
|
|
|
* @arg enable true to enable, false to disable
|
|
|
|
*/
|
|
|
|
void enableToolBoxTool(const QString &toolname, bool enable);
|
|
|
|
|
2007-12-19 03:41:45 +01:00
|
|
|
/**
|
|
|
|
* Returns whether or not a given toolbox tool is enabled
|
|
|
|
*/
|
|
|
|
bool isToolboxToolEnabled(const QString &toolname) const;
|
|
|
|
|
2007-11-19 02:19:58 +01:00
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
* Called when constraints have been updated on this containment to provide
|
|
|
|
* constraint services common to all containments. Containments should still
|
|
|
|
* implement their own constraintsUpdated method
|
|
|
|
*/
|
|
|
|
void containmentConstraintsUpdated(Plasma::Constraints constraints);
|
|
|
|
|
2007-11-09 19:47:35 +01:00
|
|
|
Q_SIGNALS:
|
|
|
|
/**
|
|
|
|
* This signal is emitted when a new applet is created by the containment
|
|
|
|
*/
|
|
|
|
void appletAdded(Plasma::Applet* applet);
|
|
|
|
|
2007-12-11 03:59:02 +01:00
|
|
|
/**
|
|
|
|
* This signal is emitted when an applet is destroyed
|
|
|
|
*/
|
|
|
|
void appletRemoved(Plasma::Applet* applet);
|
|
|
|
|
2007-11-15 12:06:33 +01:00
|
|
|
/**
|
|
|
|
* This signal indicates, that a application launch was triggered
|
|
|
|
*/
|
|
|
|
void launchActivated();
|
|
|
|
|
2007-11-19 02:19:58 +01:00
|
|
|
/**
|
|
|
|
* Emitted when the containment requests zooming out one step.
|
|
|
|
* Usually only used for desktop containments.
|
|
|
|
*/
|
|
|
|
void zoomIn();
|
2007-11-19 03:14:18 +01:00
|
|
|
|
2007-11-19 02:19:58 +01:00
|
|
|
/**
|
|
|
|
* Emitted when the containment requests zooming out one step.
|
|
|
|
* Usually only used for desktop containments.
|
|
|
|
*/
|
|
|
|
void zoomOut();
|
2007-11-19 03:14:18 +01:00
|
|
|
|
2007-11-19 02:19:58 +01:00
|
|
|
/**
|
|
|
|
* Emitted when the containment requests an add widgets dialog is shown.
|
|
|
|
* Usually only used for desktop containments.
|
|
|
|
*/
|
|
|
|
void showAddWidgets();
|
2007-11-19 03:14:18 +01:00
|
|
|
|
2007-09-18 23:16:17 +02:00
|
|
|
public Q_SLOTS:
|
|
|
|
/**
|
|
|
|
* Informs the Corona as to what position it is in. This is informational
|
|
|
|
* only, as the Corona doesn't change it's actual location. This is,
|
|
|
|
* however, passed on to Applets that may be managed by this Corona.
|
|
|
|
*
|
|
|
|
* @param location the new location of this Corona
|
|
|
|
*/
|
|
|
|
void setLocation(Plasma::Location location);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the form factor for this Corona. This may cause changes in both
|
|
|
|
* the arrangement of Applets as well as the display choices of individual
|
|
|
|
* Applets.
|
|
|
|
*/
|
|
|
|
void setFormFactor(Plasma::FormFactor formFactor);
|
|
|
|
|
2007-11-09 01:44:35 +01:00
|
|
|
/**
|
|
|
|
* Returns the Corona (if any) that this Containment is hosted by
|
|
|
|
*/
|
|
|
|
Corona* corona() const;
|
|
|
|
|
2007-11-25 00:38:37 +01:00
|
|
|
protected:
|
2007-09-18 23:16:17 +02:00
|
|
|
void contextMenuEvent(QGraphicsSceneContextMenuEvent * event);
|
2007-11-05 19:40:45 +01:00
|
|
|
void hoverEnterEvent(QGraphicsSceneHoverEvent *event);
|
|
|
|
void hoverLeaveEvent(QGraphicsSceneHoverEvent *event);
|
2007-11-12 20:27:21 +01:00
|
|
|
bool sceneEventFilter(QGraphicsItem *watched, QEvent *event);
|
2007-09-18 23:16:17 +02:00
|
|
|
|
|
|
|
protected Q_SLOTS:
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
void appletDestroyed(QObject*);
|
2007-11-12 20:27:21 +01:00
|
|
|
void appletAnimationComplete(QGraphicsItem *item, Plasma::Phase::Animation anim);
|
2007-09-23 20:03:37 +02:00
|
|
|
void dropEvent(QGraphicsSceneDragDropEvent* event);
|
2007-09-18 23:16:17 +02:00
|
|
|
|
2007-11-12 20:27:21 +01:00
|
|
|
private Q_SLOTS:
|
|
|
|
void handleDisappeared(AppletHandle *handle);
|
2007-11-22 06:11:06 +01:00
|
|
|
void destroyApplet();
|
2007-11-12 20:27:21 +01:00
|
|
|
|
2007-09-18 23:16:17 +02:00
|
|
|
private:
|
2007-12-22 13:32:55 +01:00
|
|
|
QRectF geometryForApplet(Applet *applet) const;
|
|
|
|
bool regionIsEmpty(const QRectF ®ion, Applet *ignoredApplet=0) const;
|
2007-12-29 17:26:36 +01:00
|
|
|
void prepareApplet(Applet *applet, bool delayInit);
|
2007-12-22 13:32:55 +01:00
|
|
|
|
2007-09-18 23:16:17 +02:00
|
|
|
Q_DISABLE_COPY(Containment)
|
|
|
|
|
|
|
|
class Private;
|
|
|
|
Private* const d;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // Plasma namespace
|
|
|
|
|
|
|
|
|
|
|
|
#endif // multiple inclusion guard
|