2020-03-15 15:19:28 +00:00
|
|
|
/*
|
|
|
|
SPDX-FileCopyrightText: 2015 Martin Gräßlin <mgraesslin@kde.org>
|
2015-07-02 09:35:16 +00:00
|
|
|
|
2020-03-15 15:19:28 +00:00
|
|
|
SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL
|
|
|
|
*/
|
2021-03-10 16:08:30 +00:00
|
|
|
#pragma once
|
2015-07-02 09:35:16 +00:00
|
|
|
|
2022-04-22 09:27:33 +00:00
|
|
|
#include "kwin_export.h"
|
2020-07-24 17:19:19 +00:00
|
|
|
|
2022-04-22 09:27:33 +00:00
|
|
|
#include <QObject>
|
2020-07-24 17:19:19 +00:00
|
|
|
|
|
|
|
struct wl_resource;
|
2015-07-02 09:35:16 +00:00
|
|
|
|
2023-09-13 17:59:29 +00:00
|
|
|
namespace KWin
|
2015-07-02 09:35:16 +00:00
|
|
|
{
|
|
|
|
class Display;
|
2020-07-24 17:19:19 +00:00
|
|
|
class IdleInterfacePrivate;
|
2015-07-02 09:35:16 +00:00
|
|
|
|
2015-09-10 11:36:42 +00:00
|
|
|
/**
|
|
|
|
* @brief Global representing the org_kde_kwin_idle interface.
|
|
|
|
*
|
|
|
|
* The IdleInterface allows to register callbacks which are invoked if there has
|
|
|
|
* not been any user activity (no input) for a specified time span on a seat.
|
|
|
|
*
|
|
|
|
* A client can bind an idle timeout for a SeatInterface and through that register
|
|
|
|
* an idle timeout. The complete interaction is handled internally, thus the API
|
|
|
|
* user only needs to create the IdleInterface in order to provide this feature.
|
|
|
|
*
|
|
|
|
* This interface is useful for clients as it allows them to perform power management,
|
|
|
|
* chat applications might want to set to away after no user input for some time, etc.
|
|
|
|
*
|
|
|
|
* Of course this exposes the global input usage to all clients. Normally clients don't
|
|
|
|
* know whether the input devices are used, only if their surfaces have focus. With this
|
|
|
|
* interface it is possible to notice that there are input events. A server should consider
|
|
|
|
* this to decide whether it wants to provide this feature!
|
2021-03-16 08:17:36 +00:00
|
|
|
*/
|
2022-04-22 09:27:33 +00:00
|
|
|
class KWIN_EXPORT IdleInterface : public QObject
|
2015-07-02 09:35:16 +00:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
2020-12-09 20:13:19 +00:00
|
|
|
|
2015-07-02 09:35:16 +00:00
|
|
|
public:
|
2020-12-09 20:13:19 +00:00
|
|
|
explicit IdleInterface(Display *display, QObject *parent = nullptr);
|
2020-07-24 17:19:19 +00:00
|
|
|
~IdleInterface() override;
|
2015-07-02 09:35:16 +00:00
|
|
|
|
|
|
|
private:
|
2022-08-01 21:29:02 +00:00
|
|
|
std::unique_ptr<IdleInterfacePrivate> d;
|
2015-07-02 09:35:16 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|