2014-10-14 12:04:35 +00:00
|
|
|
/********************************************************************
|
|
|
|
Copyright 2014 Martin Gräßlin <mgraesslin@kde.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 WAYLAND_SERVER_SUBCOMPOSITOR_INTERFACE_H
|
|
|
|
#define WAYLAND_SERVER_SUBCOMPOSITOR_INTERFACE_H
|
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
#include <QPointer>
|
|
|
|
|
|
|
|
#include <KWayland/Server/kwaylandserver_export.h>
|
|
|
|
|
2014-11-13 14:07:31 +00:00
|
|
|
#include "global.h"
|
2014-11-14 08:45:02 +00:00
|
|
|
#include "resource.h"
|
2014-11-13 14:07:31 +00:00
|
|
|
|
2014-10-14 12:04:35 +00:00
|
|
|
struct wl_resource;
|
|
|
|
|
|
|
|
namespace KWayland
|
|
|
|
{
|
|
|
|
namespace Server
|
|
|
|
{
|
|
|
|
|
|
|
|
class Display;
|
|
|
|
class SurfaceInterface;
|
|
|
|
class SubSurfaceInterface;
|
|
|
|
|
2017-05-26 16:33:25 +00:00
|
|
|
/**
|
|
|
|
* @todo Add documentation
|
|
|
|
*/
|
2014-11-13 14:07:31 +00:00
|
|
|
class KWAYLANDSERVER_EXPORT SubCompositorInterface : public Global
|
2014-10-14 12:04:35 +00:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
|
|
|
virtual ~SubCompositorInterface();
|
|
|
|
|
|
|
|
Q_SIGNALS:
|
|
|
|
void subSurfaceCreated(KWayland::Server::SubSurfaceInterface*);
|
|
|
|
|
|
|
|
private:
|
|
|
|
explicit SubCompositorInterface(Display *display, QObject *parent = nullptr);
|
|
|
|
friend class Display;
|
|
|
|
class Private;
|
|
|
|
};
|
|
|
|
|
2017-05-26 16:33:25 +00:00
|
|
|
/**
|
|
|
|
* @todo Add documentation
|
|
|
|
*/
|
2014-11-14 08:45:02 +00:00
|
|
|
class KWAYLANDSERVER_EXPORT SubSurfaceInterface : public Resource
|
2014-10-14 12:04:35 +00:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
Q_PROPERTY(QPoint position READ position NOTIFY positionChanged)
|
|
|
|
Q_PROPERTY(KWayland::Server::SubSurfaceInterface::Mode mode READ mode NOTIFY modeChanged)
|
|
|
|
public:
|
|
|
|
virtual ~SubSurfaceInterface();
|
|
|
|
|
|
|
|
QPoint position() const;
|
|
|
|
|
|
|
|
enum class Mode {
|
|
|
|
Synchronized,
|
|
|
|
Desynchronized
|
|
|
|
};
|
|
|
|
Mode mode() const;
|
|
|
|
|
2016-03-18 09:41:56 +00:00
|
|
|
/**
|
|
|
|
* Whether this SubSurfaceInterface is in synchronized mode.
|
2017-05-26 00:57:20 +00:00
|
|
|
* A SubSurface is in synchronized mode if either {@link mode} is
|
2016-03-18 09:41:56 +00:00
|
|
|
* @c Mode::Synchronized or if the parent surface is in synchronized
|
|
|
|
* mode. If a SubSurfaceInterface is in synchronized mode all child
|
|
|
|
* SubSurfaceInterfaces are also in synchronized mode ignoring the actual mode.
|
|
|
|
* @returns Whether this SubSurfaceInterface is in synchronized mode.
|
|
|
|
* @see mode
|
2016-04-27 05:43:43 +00:00
|
|
|
* @since 5.22
|
2016-03-18 09:41:56 +00:00
|
|
|
**/
|
|
|
|
bool isSynchronized() const;
|
|
|
|
|
2016-03-24 14:30:48 +00:00
|
|
|
// TODO: remove with ABI break (KF6)
|
2014-10-14 12:04:35 +00:00
|
|
|
QPointer<SurfaceInterface> surface();
|
2016-03-24 14:30:48 +00:00
|
|
|
/**
|
|
|
|
* @returns The surface this SubSurfaceInterface was created on.
|
2016-04-27 05:43:43 +00:00
|
|
|
* @since 5.22
|
2016-03-24 14:30:48 +00:00
|
|
|
**/
|
|
|
|
QPointer<SurfaceInterface> surface() const;
|
|
|
|
// TODO: remove with ABI break (KF6)
|
2014-10-14 12:04:35 +00:00
|
|
|
QPointer<SurfaceInterface> parentSurface();
|
2016-03-24 14:30:48 +00:00
|
|
|
/**
|
|
|
|
* @returns The parent surface for which this SubSurfaceInterface is a child
|
2016-04-27 05:43:43 +00:00
|
|
|
* @since 5.22
|
2016-03-24 14:30:48 +00:00
|
|
|
**/
|
|
|
|
QPointer<SurfaceInterface> parentSurface() const;
|
2014-10-14 12:04:35 +00:00
|
|
|
|
2016-03-23 15:59:18 +00:00
|
|
|
/**
|
|
|
|
* @returns the main surface for the sub-surface tree, that is the first surface without a parent
|
2016-04-27 05:43:43 +00:00
|
|
|
* @since 5.22
|
2016-03-23 15:59:18 +00:00
|
|
|
**/
|
|
|
|
QPointer<SurfaceInterface> mainSurface() const;
|
|
|
|
|
2014-10-14 12:04:35 +00:00
|
|
|
Q_SIGNALS:
|
|
|
|
void positionChanged(const QPoint&);
|
|
|
|
void modeChanged(KWayland::Server::SubSurfaceInterface::Mode);
|
|
|
|
|
|
|
|
private:
|
|
|
|
friend class SubCompositorInterface;
|
|
|
|
friend class SurfaceInterface;
|
2014-11-20 15:40:14 +00:00
|
|
|
explicit SubSurfaceInterface(SubCompositorInterface *parent, wl_resource *parentResource);
|
2014-10-14 12:04:35 +00:00
|
|
|
|
|
|
|
class Private;
|
2014-11-14 08:45:02 +00:00
|
|
|
Private *d_func() const;
|
2014-10-14 12:04:35 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Q_DECLARE_METATYPE(KWayland::Server::SubSurfaceInterface::Mode)
|
|
|
|
|
|
|
|
#endif
|