You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
148 lines
4.7 KiB
148 lines
4.7 KiB
/******************************************************************** |
|
Copyright 2016 Eike Hein <hein.org> |
|
|
|
This library is free software; you can redistribute it and/or |
|
modify it under the terms of the GNU Lesser General Public |
|
License as published by the Free Software Foundation; either |
|
version 2.1 of the License, or (at your option) version 3, or any |
|
later version accepted by the membership of KDE e.V. (or its |
|
successor approved by the membership of KDE e.V.), which shall |
|
act as a proxy defined in Section 6 of version 3 of the license. |
|
|
|
This library 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 |
|
Lesser General Public License for more details. |
|
|
|
You should have received a copy of the GNU Lesser General Public |
|
License along with this library. If not, see <http://www.gnu.org/licenses/>. |
|
*********************************************************************/ |
|
|
|
#ifndef VIRTUALDESKTOPINFO_H |
|
#define VIRTUALDESKTOPINFO_H |
|
|
|
#include <QObject> |
|
|
|
#include "taskmanager_export.h" |
|
|
|
namespace TaskManager |
|
{ |
|
/** |
|
* @short Provides basic virtual desktop information. The underlying windowing |
|
* system is abstracted away. |
|
* |
|
* This class provides basic information about the virtual desktops present |
|
* in the session as a set of notifiable properties. |
|
* |
|
* @author Eike Hein <hein@kde.org> |
|
**/ |
|
|
|
class TASKMANAGER_EXPORT VirtualDesktopInfo : public QObject |
|
{ |
|
Q_OBJECT |
|
|
|
Q_PROPERTY(QVariant currentDesktop READ currentDesktop NOTIFY currentDesktopChanged) |
|
Q_PROPERTY(int numberOfDesktops READ numberOfDesktops NOTIFY numberOfDesktopsChanged) |
|
Q_PROPERTY(QVariantList desktopIds READ desktopIds NOTIFY desktopIdsChanged) |
|
Q_PROPERTY(QStringList desktopNames READ desktopNames NOTIFY desktopNamesChanged) |
|
Q_PROPERTY(int desktopLayoutRows READ desktopLayoutRows NOTIFY desktopLayoutRowsChanged) |
|
|
|
public: |
|
explicit VirtualDesktopInfo(QObject *parent = nullptr); |
|
~VirtualDesktopInfo() override; |
|
|
|
/** |
|
* The currently active virtual desktop. |
|
* |
|
* @returns the id of the currently active virtual desktop. QString on |
|
* Wayland; uint >0 on X11. |
|
**/ |
|
QVariant currentDesktop() const; |
|
|
|
/** |
|
* The number of virtual desktops present in the session. |
|
* |
|
* @returns the number of virtual desktops present in the session. |
|
**/ |
|
int numberOfDesktops() const; |
|
|
|
/** |
|
* The ids of all virtual desktops present in the session. |
|
* |
|
* On Wayland, the ids are QString. On X11, they are uint >0. |
|
* |
|
* @returns a the list of ids of the virtual desktops present in the |
|
* session. |
|
**/ |
|
QVariantList desktopIds() const; |
|
|
|
/** |
|
* The names of all virtual desktops present in the session. |
|
* |
|
* Note that on X11, virtual desktops are indexed starting at 1, so |
|
* the name for virtual desktop 1 is at index 0 in this list. |
|
* |
|
* @returns the list of names of the virtual desktops present in the |
|
* session. |
|
**/ |
|
QStringList desktopNames() const; |
|
|
|
/** |
|
* Returns the position of the passed-in virtual desktop. |
|
* @param desktop A virtual desktop id (QString on Wayland; uint >0 on X11). |
|
* @returns the position of the virtual desktop, or -1 if the desktop |
|
* id is not valid. |
|
**/ |
|
quint32 position(const QVariant &desktop) const; |
|
|
|
/** |
|
* The number of rows in the virtual desktop layout. |
|
* |
|
* @returns the number of rows in the virtual desktop layout. |
|
**/ |
|
int desktopLayoutRows() const; |
|
|
|
/** |
|
* Request activating the passed-in virtual desktop. |
|
* |
|
* @param desktop A virtual desktop id (QString on Wayland; uint >0 on X11). |
|
**/ |
|
void requestActivate(const QVariant &desktop); |
|
|
|
/** |
|
* Request adding a new virtual desktop at the specified position. |
|
* |
|
* On X11, the position parameter is ignored and the new desktop is always |
|
* created at the end of the list. |
|
* |
|
* @param position The position of the requested new virtual desktop (ignored on X11). |
|
**/ |
|
void requestCreateDesktop(quint32 position); |
|
|
|
/** |
|
* Request removing the virtual desktop at the specified position. |
|
* |
|
* On X11, the position parameter is ignored and the last desktop in the list |
|
* is always the one removed. |
|
* |
|
* @param position The position of the virtual desktop to remove (ignored on X11). |
|
**/ |
|
void requestRemoveDesktop(quint32 position); |
|
|
|
Q_SIGNALS: |
|
void currentDesktopChanged() const; |
|
void numberOfDesktopsChanged() const; |
|
void desktopIdsChanged() const; |
|
void desktopNamesChanged() const; |
|
void desktopLayoutRowsChanged() const; |
|
|
|
private: |
|
class Private; |
|
class XWindowPrivate; |
|
class WaylandPrivate; |
|
static Private *d; |
|
}; |
|
|
|
} |
|
|
|
#endif
|
|
|