hyperion.ng/include/hyperion/GrabberWrapper.h

208 lines
5.9 KiB
C
Raw Normal View History

#pragma once
#include <QObject>
#include <QJsonObject>
#include <QJsonArray>
#include <QString>
#include <QStringList>
2020-06-17 20:55:57 +02:00
#include <QMultiMap>
#include <utils/Logger.h>
#include <utils/Components.h>
#include <utils/Image.h>
#include <utils/ColorRgb.h>
#include <utils/VideoMode.h>
2021-01-31 13:49:31 +01:00
#include <utils/PixelFormat.h>
2018-12-27 23:11:32 +01:00
#include <utils/settings.h>
#include <utils/VideoStandard.h>
class Grabber;
class GlobalSignals;
2018-12-27 23:11:32 +01:00
class QTimer;
/// Map of Hyperion instances with grabber name that requested screen capture
static QMap<int, QString> GRABBER_SYS_CLIENTS;
static QMap<int, QString> GRABBER_V4L_CLIENTS;
2018-12-27 23:11:32 +01:00
///
/// This class will be inherted by FramebufferWrapper and others which contains the real capture interface
///
class GrabberWrapper : public QObject
{
Q_OBJECT
2017-11-22 00:52:55 +01:00
public:
GrabberWrapper(const QString& grabberName, Grabber * ggrabber, unsigned width, unsigned height, unsigned updateRate_Hz = 0);
2017-11-22 00:52:55 +01:00
~GrabberWrapper() override;
2017-11-22 00:52:55 +01:00
static GrabberWrapper* instance;
static GrabberWrapper* getInstance(){ return instance; }
///
2020-11-14 16:22:21 +01:00
/// Starts the grabber which produces led values with the specified update rate
///
virtual bool start();
///
2020-11-14 16:22:21 +01:00
/// Starts maybe the grabber which produces led values with the specified update rate
///
virtual void tryStart();
///
/// Stop grabber
///
virtual void stop();
///
/// Check if grabber is active
///
virtual bool isActive() const;
///
2021-01-31 13:49:31 +01:00
/// @brief Get a list of all available devices
/// @return List of all available devices on success else empty List
///
2021-01-31 13:49:31 +01:00
virtual QStringList getDevices() const;
///
2021-01-31 13:49:31 +01:00
/// @brief Get the device name by path
/// @param devicePath The device path
2021-01-31 13:49:31 +01:00
/// @return The name of the device on success else empty String
///
2021-01-31 13:49:31 +01:00
virtual QString getDeviceName(const QString& devicePath) const;
2020-06-17 20:55:57 +02:00
///
2021-02-05 21:52:02 +01:00
/// @brief Get a map of name/index pair of supported device inputs
2020-06-17 20:55:57 +02:00
/// @param devicePath The device path
/// @return multi pair of name/index on success else empty pair
///
2021-01-31 13:49:31 +01:00
virtual QMultiMap<QString, int> getDeviceInputs(const QString& devicePath) const;
2020-06-17 20:55:57 +02:00
///
/// @brief Get a list of available device video standards depends on device input
/// @param devicePath The device path
/// @param inputIndex The device input index
/// @return List of video standards on success else empty List
///
virtual QList<VideoStandard> getAvailableDeviceStandards(const QString& devicePath, const int& deviceInput) const;
///
2021-01-31 13:49:31 +01:00
/// @brief Get a list of all available device encoding formats depends on device input
/// @param devicePath The device path
2021-01-31 13:49:31 +01:00
/// @param inputIndex The device input index
/// @return List of device encoding formats on success else empty List
///
2021-01-31 13:49:31 +01:00
virtual QStringList getAvailableEncodingFormats(const QString& devicePath, const int& deviceInput) const;
///
2021-02-05 21:52:02 +01:00
/// @brief Get a map of available device resolutions (width/heigth) depends on device input and encoding format
/// @param devicePath The device path
2021-01-31 13:49:31 +01:00
/// @param inputIndex The device input index
/// @param encFormat The device encoding format
2021-02-05 21:52:02 +01:00
/// @return Map of resolutions (width/heigth) on success else empty List
///
2021-02-05 21:52:02 +01:00
virtual QMultiMap<int, int> getAvailableDeviceResolutions(const QString& devicePath, const int& deviceInput, const PixelFormat& encFormat) const;
///
/// @brief Get a list of available device framerates depends on device input, encoding format and resolution
/// @param devicePath The device path
2021-01-31 13:49:31 +01:00
/// @param inputIndex The device input index
/// @param encFormat The device encoding format
/// @param width The device width
/// @param heigth The device heigth
/// @return List of framerates on success else empty List
///
2021-02-07 11:12:28 +01:00
virtual QIntList getAvailableDeviceFramerates(const QString& devicePath, const int& deviceInput, const PixelFormat& encFormat, const unsigned width, const unsigned height) const;
2020-11-14 16:22:21 +01:00
///
/// @brief Get active grabber name
/// @param hyperionInd The instance index
/// @return Active grabbers
2020-11-14 16:22:21 +01:00
///
virtual QStringList getActive(int inst) const;
2020-11-14 16:22:21 +01:00
static QStringList availableGrabbers();
public:
template <typename Grabber_T>
bool transferFrame(Grabber_T &grabber)
{
unsigned w = grabber.getImageWidth();
unsigned h = grabber.getImageHeight();
2018-12-27 23:11:32 +01:00
if ( _image.width() != w || _image.height() != h)
{
_image.resize(w, h);
}
int ret = grabber.grabFrame(_image);
if (ret >= 0)
{
emit systemImage(_grabberName, _image);
return true;
}
return false;
}
public slots:
///
/// virtual method, should perform single frame grab and computes the led-colors
///
virtual void action() = 0;
///
/// Set the video mode (2D/3D)
/// @param[in] mode The new video mode
///
2020-08-08 13:09:15 +02:00
virtual void setVideoMode(VideoMode videoMode);
2018-12-27 23:11:32 +01:00
///
/// Set the crop values
/// @param cropLeft Left pixel crop
/// @param cropRight Right pixel crop
/// @param cropTop Top pixel crop
/// @param cropBottom Bottom pixel crop
///
virtual void setCropping(unsigned cropLeft, unsigned cropRight, unsigned cropTop, unsigned cropBottom);
2018-12-27 23:11:32 +01:00
///
/// @brief Handle settings update from HyperionDaemon Settingsmanager emit
/// @param type settingyType from enum
/// @param config configuration object
///
2020-08-08 13:09:15 +02:00
virtual void handleSettingsUpdate(settings::type type, const QJsonDocument& config);
2018-12-27 23:11:32 +01:00
signals:
2018-12-27 23:11:32 +01:00
///
/// @brief Emit the final processed image
///
void systemImage(const QString& name, const Image<ColorRgb>& image);
private slots:
/// @brief Handle a source request event from Hyperion.
/// Will start and stop grabber based on active listeners count
2020-08-08 13:09:15 +02:00
void handleSourceRequest(hyperion::Components component, int hyperionInd, bool listen);
///
/// @brief Update Update capture rate
/// @param type interval between frames in millisecons
///
void updateTimer(int interval);
protected:
QString _grabberName;
2017-11-22 00:52:55 +01:00
/// The timer for generating events with the specified update rate
2018-12-27 23:11:32 +01:00
QTimer* _timer;
2018-12-27 23:11:32 +01:00
/// The calced update rate [ms]
int _updateInterval_ms;
/// The Logger instance
Logger * _log;
2017-11-22 00:52:55 +01:00
Grabber *_ggrabber;
/// The image used for grabbing frames
Image<ColorRgb> _image;
};