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.
 
 
 
 
 
 

149 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