diff options
author | Giulio Camuffo <giulio.camuffo@kdab.com> | 2016-03-28 12:12:04 +0300 |
---|---|---|
committer | Giulio Camuffo <giulio.camuffo@kdab.com> | 2016-04-18 10:48:11 +0000 |
commit | 68f40f95972b857433df424cc16809eebfd77b8f (patch) | |
tree | 815ad8e49e25d4c19a3b3d20395b3e89fa30df51 /src/compositor/compositor_api/qwaylandsurfacegrabber.cpp | |
parent | 95d2bff24bc2678da91cfbd210382c3a5af6af8a (diff) |
Add API to grab a surface's content
This patch adds a new QWaylandSurfaceGrabber class. The user can use it
to grab a surface's content, and get a QImage with the data.
Change-Id: I25dd72a8ba39201cd91addbfc976b93ca1e05112
Reviewed-by: Pier Luigi Fiorini <pierluigi.fiorini@gmail.com>
Diffstat (limited to 'src/compositor/compositor_api/qwaylandsurfacegrabber.cpp')
-rw-r--r-- | src/compositor/compositor_api/qwaylandsurfacegrabber.cpp | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/src/compositor/compositor_api/qwaylandsurfacegrabber.cpp b/src/compositor/compositor_api/qwaylandsurfacegrabber.cpp new file mode 100644 index 000000000..ab3342269 --- /dev/null +++ b/src/compositor/compositor_api/qwaylandsurfacegrabber.cpp @@ -0,0 +1,115 @@ +/**************************************************************************** +** +** Copyright (C) 2016 Klarälvdalens Datakonsult AB (KDAB). +** Contact: http://www.qt.io/licensing/ +** +** This file is part of the QtWaylandCompositor module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL3$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see http://www.qt.io/terms-conditions. For further +** information use the contact form at http://www.qt.io/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 3 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPLv3 included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 3 requirements +** will be met: https://www.gnu.org/licenses/lgpl.html. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 2.0 or later as published by the Free +** Software Foundation and appearing in the file LICENSE.GPL included in +** the packaging of this file. Please review the following information to +** ensure the GNU General Public License version 2.0 requirements will be +** met: http://www.gnu.org/licenses/gpl-2.0.html. +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include "qwaylandsurfacegrabber.h" + +#include <QtCore/private/qobject_p.h> +#include <QtWaylandCompositor/qwaylandsurface.h> +#include <QtWaylandCompositor/qwaylandcompositor.h> +#include <QtWaylandCompositor/private/qwaylandsurface_p.h> + +QT_BEGIN_NAMESPACE + +/*! + \class QWaylandSurfaceGrabber + \inmodule QtWaylandCompositor + \since 5.7 + \brief The QWaylandSurfaceGrabber class allows to read the content of a QWaylandSurface + + Sometimes it is needed to get the contents of a surface, for example to provide a screenshot + to the user. The QWaylandSurfaceGrabber class provides a simple method to do so, without + having to care what type of buffer backs the surface, be it SHM, OpenGL or something else. +*/ + +/*! + \enum QWaylandSurfaceGrabber::Error + + The Error enum describes the reason for a grab failure. + + \value InvalidSurface The surface is null or otherwise not valid. + \value NoBufferAttached The client has not attached a buffer on the surface yet. + \value UnknownBufferType The buffer attached on the surface is of an unknown type. + \value RendererNotReady The compositor renderer is not ready to grab the surface content. + */ + +class QWaylandSurfaceGrabberPrivate : public QObjectPrivate +{ + Q_DECLARE_PUBLIC(QWaylandSurfaceGrabber) + + QWaylandSurface *surface; +}; + +/*! + * Create a QWaylandSurfaceGrabber object with the given \a surface and \a parent + */ +QWaylandSurfaceGrabber::QWaylandSurfaceGrabber(QWaylandSurface *surface, QObject *parent) + : QObject(*(new QWaylandSurfaceGrabberPrivate), parent) +{ + Q_D(QWaylandSurfaceGrabber); + d->surface = surface; +} + +/*! + * Returns the surface set on this object + */ +QWaylandSurface *QWaylandSurfaceGrabber::surface() const +{ + Q_D(const QWaylandSurfaceGrabber); + return d->surface; +} + +/*! + * Grab the content of the surface set on this object. + * It may not be possible to do that immediately so the \a success and \a failed signals + * should be used to be notified of when the grab is completed. + */ +void QWaylandSurfaceGrabber::grab() +{ + Q_D(QWaylandSurfaceGrabber); + if (!d->surface) { + emit failed(InvalidSurface); + return; + } + + QWaylandSurfacePrivate *surf = QWaylandSurfacePrivate::get(d->surface); + QWaylandBufferRef buf = surf->bufferRef; + if (!buf.hasBuffer()) { + emit failed(NoBufferAttached); + return; + } + + d->surface->compositor()->grabSurface(this, buf); +} |