2019-01-06 19:49:56 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
|
|
|
|
// Hyperion-utils includes
|
|
|
|
#include <utils/ColorRgb.h>
|
|
|
|
#include <hyperion/Grabber.h>
|
|
|
|
|
|
|
|
class QScreen;
|
|
|
|
|
|
|
|
///
|
|
|
|
/// @brief The platform capture implementation based on QT API
|
|
|
|
///
|
|
|
|
class QtGrabber : public Grabber
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
QtGrabber(int cropLeft, int cropRight, int cropTop, int cropBottom, int pixelDecimation, int display);
|
|
|
|
|
2020-07-12 09:19:59 +02:00
|
|
|
~QtGrabber() override;
|
2019-01-06 19:49:56 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Captures a single snapshot of the display and writes the data to the given image. The
|
|
|
|
/// provided image should have the same dimensions as the configured values (_width and
|
|
|
|
/// _height)
|
|
|
|
///
|
|
|
|
/// @param[out] image The snapped screenshot (should be initialized with correct width and
|
|
|
|
/// height)
|
|
|
|
///
|
2020-08-02 22:35:09 +02:00
|
|
|
int grabFrame(Image<ColorRgb> & image);
|
2019-01-06 19:49:56 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// @brief Set a new video mode
|
|
|
|
///
|
2020-08-02 22:35:09 +02:00
|
|
|
void setVideoMode(VideoMode mode) override;
|
2019-01-06 19:49:56 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// @brief Apply new width/height values, overwrite Grabber.h implementation as qt doesn't use width/height, just pixelDecimation to calc dimensions
|
|
|
|
///
|
2020-11-14 17:58:56 +01:00
|
|
|
bool setWidthHeight(int width, int height) override { return true; }
|
2019-01-06 19:49:56 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// @brief Apply new pixelDecimation
|
|
|
|
///
|
2020-08-02 22:35:09 +02:00
|
|
|
void setPixelDecimation(int pixelDecimation) override;
|
2019-01-06 19:49:56 +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
|
|
|
|
///
|
2020-08-02 22:35:09 +02:00
|
|
|
void setCropping(unsigned cropLeft, unsigned cropRight, unsigned cropTop, unsigned cropBottom) override;
|
2019-01-06 19:49:56 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// @brief Apply display index
|
|
|
|
///
|
2020-08-02 22:35:09 +02:00
|
|
|
void setDisplayIndex(int index) override;
|
2019-01-06 19:49:56 +01:00
|
|
|
|
|
|
|
private slots:
|
|
|
|
///
|
|
|
|
/// @brief is called whenever the current _screen changes it's geometry
|
|
|
|
/// @param geo The new geometry
|
|
|
|
///
|
|
|
|
void geometryChanged(const QRect &geo);
|
|
|
|
|
|
|
|
private:
|
|
|
|
///
|
|
|
|
/// @brief Setup a new capture display, will free the previous one
|
|
|
|
/// @return True on success, false if no display is found
|
|
|
|
///
|
2019-06-05 18:19:08 +02:00
|
|
|
bool setupDisplay();
|
2019-01-06 19:49:56 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// @brief Is called whenever we need new screen dimension calculations based on window geometry
|
|
|
|
///
|
2020-08-08 13:09:15 +02:00
|
|
|
int updateScreenDimensions(bool force);
|
2019-01-06 19:49:56 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// @brief free the _screen pointer
|
|
|
|
///
|
|
|
|
void freeResources();
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
unsigned _display;
|
|
|
|
int _pixelDecimation;
|
|
|
|
unsigned _screenWidth;
|
|
|
|
unsigned _screenHeight;
|
|
|
|
unsigned _src_x;
|
|
|
|
unsigned _src_y;
|
|
|
|
unsigned _src_x_max;
|
|
|
|
unsigned _src_y_max;
|
|
|
|
QScreen* _screen;
|
|
|
|
};
|