diff options
Diffstat (limited to 'decorators/libdecorator/mabstractdecorator.h')
-rw-r--r-- | decorators/libdecorator/mabstractdecorator.h | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/decorators/libdecorator/mabstractdecorator.h b/decorators/libdecorator/mabstractdecorator.h new file mode 100644 index 0000000..1b52a64 --- /dev/null +++ b/decorators/libdecorator/mabstractdecorator.h @@ -0,0 +1,80 @@ +/*************************************************************************** +** +** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies). +** All rights reserved. +** Contact: Nokia Corporation (directui@nokia.com) +** +** This file is part of duicompositor. +** +** If you have questions regarding the use of this file, please contact +** Nokia at directui@nokia.com. +** +** This library is free software; you can redistribute it and/or +** modify it under the terms of the GNU Lesser General Public +** License version 2.1 as published by the Free Software Foundation +** and appearing in the file LICENSE.LGPL included in the packaging +** of this file. +** +****************************************************************************/ + +#ifndef MABSTRACTDECORATOR_H +#define MABSTRACTDECORATOR_H + +#include <QObject> + +/*! + * MAbstractDecorator is the base class for window decorators + */ +class MAbstractDecorator: public QObject +{ + Q_OBJECT +public: + /*! + * Initializes MAbstractDecorator and the connections to MCompositor + */ + MAbstractDecorator(QObject *parent = 0); + virtual ~MAbstractDecorator() = 0; + + /*! + * Returns the id of the window decorated by this decorator + */ + Qt::HANDLE managedWinId(); + +public slots: + + /*! + * Minimizes the managed window + */ + void minimize(); + + /*! + * Closes the managed window + */ + void close(); + + /*! + * Interface to MRMI sockets + */ + void RemoteSetManagedWinId(qulonglong window); + void RemoteActivateWindow(); + +protected: + + /*! + * Pure virtual function that gets called when the user activates the + * managed window by tapping on its client area. + * Re-implement to obtain activate events from the managed window + */ + virtual void activateEvent() = 0; + + /*! + * Pure virtual function that gets called this decorator manages a window + */ + virtual void manageEvent(Qt::HANDLE window) = 0; + +private: + Qt::HANDLE client; + +}; + +#endif //MABSTRACTDECORATOR_H |