216 lines
6.2 KiB
C
Raw Normal View History

#pragma once
#include <QObject>
#include <cstdint>
#include <utils/ColorRgb.h>
#include <utils/Image.h>
#include <utils/VideoMode.h>
#include <utils/VideoStandard.h>
#include <utils/ImageResampler.h>
#include <utils/Logger.h>
#include <utils/Components.h>
2020-06-17 20:55:57 +02:00
#include <QMultiMap>
2018-12-27 23:11:32 +01:00
///
/// @brief The Grabber class is responsible to apply image resizes (with or without ImageResampler)
2021-01-31 13:49:31 +01:00
class Grabber : public QObject
{
Q_OBJECT
public:
Grabber(const QString& grabberName = "", int width=0, int height=0, int cropLeft=0, int cropRight=0, int cropTop=0, int cropBottom=0);
///
/// Set the video mode (2D/3D)
/// @param[in] mode The new video mode
///
virtual void setVideoMode(VideoMode mode);
///
/// Apply new flip mode (vertical/horizontal/both)
/// @param[in] mode The new flip mode
///
virtual void setFlipMode(FlipMode mode);
2018-12-27 23:11:32 +01:00
///
/// @brief Apply new crop values, on errors reject the values
///
virtual void setCropping(unsigned cropLeft, unsigned cropRight, unsigned cropTop, unsigned cropBottom);
2017-11-22 00:52:55 +01:00
2020-06-17 20:55:57 +02:00
///
/// @brief Apply new video input (used from v4l)
/// @param input device input
///
virtual bool setInput(int input);
2018-12-27 23:11:32 +01:00
///
/// @brief Apply new width/height values, on errors (collide with cropping) reject the values
2019-01-07 18:13:49 +01:00
/// @return True on success else false
2018-12-27 23:11:32 +01:00
///
virtual bool setWidthHeight(int width, int height);
2018-12-27 23:11:32 +01:00
///
/// @brief Apply new framerate (used from v4l)
/// @param fps framesPerSecond
///
virtual bool setFramerate(int fps);
2018-12-27 23:11:32 +01:00
///
/// @brief Apply new pixelDecimation (used from x11, xcb and qt)
2018-12-27 23:11:32 +01:00
///
virtual void setPixelDecimation(int pixelDecimation) {}
2018-12-27 23:11:32 +01:00
///
/// @brief Apply new signalThreshold (used from v4l)
///
virtual void setSignalThreshold(
double redSignalThreshold,
double greenSignalThreshold,
double blueSignalThreshold,
int noSignalCounterThreshold = 50) {}
2018-12-27 23:11:32 +01:00
///
/// @brief Apply new SignalDetectionOffset (used from v4l)
///
virtual void setSignalDetectionOffset(
double verticalMin,
double horizontalMin,
double verticalMax,
double horizontalMax) {}
2018-12-27 23:11:32 +01:00
///
/// @brief Apply SignalDetectionEnable (used from v4l)
///
virtual void setSignalDetectionEnable(bool enable) {}
2018-12-27 23:11:32 +01:00
///
/// @brief Apply CecDetectionEnable (used from v4l)
///
virtual void setCecDetectionEnable(bool enable) {}
2018-12-27 23:11:32 +01:00
///
/// @brief Apply device and videoStandard (used from v4l)
2018-12-27 23:11:32 +01:00
///
virtual void setDeviceVideoStandard(QString device, VideoStandard videoStandard) {}
2018-12-27 23:11:32 +01:00
///
/// @brief Apply device (used from MediaFoundation)
///
virtual bool setDevice(QString device) { return false; }
2018-12-27 23:11:32 +01:00
///
/// @brief Apply display index (used from qt)
2018-12-27 23:11:32 +01:00
///
virtual void setDisplayIndex(int index) {}
2018-12-27 23:11:32 +01:00
///
/// @brief Apply path for device (used from framebuffer)
///
virtual void setDevicePath(const QString& path) {}
2018-12-27 23:11:32 +01:00
///
/// @brief get current resulting height of image (after crop)
///
virtual int getImageWidth() { return _width; }
2018-12-27 23:11:32 +01:00
///
/// @brief get current resulting width of image (after crop)
///
virtual int getImageHeight() { return _height; }
2018-12-27 23:11:32 +01:00
///
/// @brief Prevent the real capture implementation from capturing if disabled
///
void setEnabled(bool enable);
///
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 { return QStringList(); }
///
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 { return QString(); }
2020-06-17 20:55:57 +02:00
///
/// @brief Get a name/index pair of supported device inputs
/// @param devicePath The device path
/// @return multi pair of name/index on success else empty pair
///
2021-02-05 21:52:02 +01:00
virtual QMultiMap<QString, int> getDeviceInputs(const QString& /*devicePath*/) const { return QMultiMap<QString, int>(); }
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 { return QList<VideoStandard>(); }
///
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 { return QStringList(); }
///
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 { return QMultiMap<int, int>(); }
///
2021-01-31 13:49:31 +01:00
/// @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 { return QIntList(); }
protected:
ImageResampler _imageResampler;
bool _useImageResampler;
2017-11-22 00:52:55 +01:00
/// The selected VideoMode
VideoMode _videoMode;
/// The used Flip Mode
FlipMode _flipMode;
/// With of the captured snapshot [pixels]
int _width;
2017-11-22 00:52:55 +01:00
/// Height of the captured snapshot [pixels]
int _height;
2020-06-17 20:55:57 +02:00
/// frame per second
int _fps;
2020-06-17 20:55:57 +02:00
/// device input
int _input;
/// number of pixels to crop after capturing
int _cropLeft, _cropRight, _cropTop, _cropBottom;
bool _enabled;
/// logger instance
Logger * _log;
};