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.
62 lines
1.7 KiB
62 lines
1.7 KiB
/* |
|
SPDX-FileCopyrightText: 2020 Aleix Pol Gonzalez <aleixpol@kde.org> |
|
|
|
SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL |
|
*/ |
|
|
|
#pragma once |
|
|
|
#include "screencasting.h" |
|
#include <QObject> |
|
|
|
class ScreencastingStream; |
|
struct ScreencastingRequestPrivate; |
|
|
|
/** |
|
* Allows us to request a stream for a window identified by its universally |
|
* unique identifier. |
|
* |
|
* We will get a PipeWire node id that can be fed to any pipewire player, be it |
|
* the PipeWireSourceItem, GStreamer's pipewiresink or any other. |
|
*/ |
|
class ScreencastingRequest : public QObject |
|
{ |
|
Q_OBJECT |
|
/** |
|
* The unique identifier of the window we want to cast. |
|
* |
|
* @see PlasmaWindow::uuid |
|
* @see PlasmaWindow::stackingOrderUuids |
|
* @see PlasmaWindowModel::Uuid |
|
* @see TasksModel::WinIdList |
|
*/ |
|
Q_PROPERTY(QString uuid READ uuid WRITE setUuid NOTIFY uuidChanged) |
|
|
|
/** |
|
* The output name as define in Screen.name |
|
*/ |
|
Q_PROPERTY(QString outputName READ outputName WRITE setOutputName NOTIFY outputNameChanged) |
|
|
|
/** The offered nodeId to give to a source */ |
|
Q_PROPERTY(quint32 nodeId READ nodeId NOTIFY nodeIdChanged) |
|
public: |
|
ScreencastingRequest(QObject *parent = nullptr); |
|
~ScreencastingRequest(); |
|
|
|
void setUuid(const QString &uuid); |
|
QString uuid() const; |
|
void setOutputName(const QString &outputName); |
|
QString outputName() const; |
|
quint32 nodeId() const; |
|
|
|
Q_SIGNALS: |
|
void nodeIdChanged(quint32 nodeId); |
|
void uuidChanged(const QString &uuid); |
|
void outputNameChanged(const QString &outputNames); |
|
|
|
private: |
|
void adopt(ScreencastingStream *stream); |
|
void setNodeid(uint nodeId); |
|
|
|
QScopedPointer<ScreencastingRequestPrivate> d; |
|
};
|
|
|