mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2025-03-01 10:33:28 +00:00
* Refactor to fix #1671
* Add GUI/NonGUI mode to info page
* Do not show lock config, if in non-UI mode
* Updae Changelog
* Correct includes
* Ensure key member initialization - RGB Channels
* Ensure key member initialization - WebServer
* Update RGBChannels
* Fix initialization order
* Fix key when inserting new logger in LoggerMap,
Prepare logBuffer-JSON snapshot view in LoggerManager,
Increase buffered loglines to 500
* Fix Memory leak in GrabberWrapper
* Fix Memory leak in BlackBorderProcessor
* Fix Memory leak in BlackBorderProcessor
* use ninja generator under macos
* Fix BGEffectHandler destruction
* Fix Mdns code
* Clear list after applying qDeleteAll
* Fix deletion of CecHandler
* Fix memory leak caused by wrong buffer allocation
* Remove extra pixel consistently
* Change mDNS to Qt SmartPointers
* Correct removal
* Fix usage of _width/_height (they are the output resolution, not the screen resolution)
That avoids unnecessary resizing of the output image with every transferFrame call
* Move main non Thread Objects to Smart Pointers
* Revert "Move main non Thread Objects to Smart Pointers"
This reverts commit 26102ca963
.
* Add missing deletes
* Revert MdnsBrowser chnage
* Revert MdnsBrowser change
* Fix memory leaks related standalone grabber
* Address CodeQL finding
* delete pointer OsxFrameGrabber
---------
Co-authored-by: Paulchen-Panther <16664240+Paulchen-Panther@users.noreply.github.com>
129 lines
2.9 KiB
C++
129 lines
2.9 KiB
C++
#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 display=0, int cropLeft=0, int cropRight=0, int cropTop=0, int cropBottom=0);
|
|
|
|
~QtGrabber() override;
|
|
|
|
///
|
|
/// 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)
|
|
///
|
|
int grabFrame(Image<ColorRgb> & image);
|
|
|
|
///
|
|
/// @brief Set a new video mode
|
|
///
|
|
void setVideoMode(VideoMode mode) override;
|
|
|
|
///
|
|
/// @brief Apply new width/height values, overwrite Grabber.h implementation as qt doesn't use width/height, just pixelDecimation to calc dimensions
|
|
///
|
|
bool setWidthHeight(int /*width*/, int /*height*/) override { return true; }
|
|
|
|
///
|
|
/// @brief Apply new pixelDecimation
|
|
///
|
|
bool setPixelDecimation(int pixelDecimation) override;
|
|
|
|
///
|
|
/// Set the crop values
|
|
/// @param cropLeft Left pixel crop
|
|
/// @param cropRight Right pixel crop
|
|
/// @param cropTop Top pixel crop
|
|
/// @param cropBottom Bottom pixel crop
|
|
///
|
|
void setCropping(int cropLeft, int cropRight, int cropTop, int cropBottom) override;
|
|
|
|
///
|
|
/// @brief Apply display index
|
|
///
|
|
bool setDisplayIndex(int index) override;
|
|
|
|
///
|
|
/// @brief Discover QT screens available (for configuration).
|
|
///
|
|
/// @param[in] params Parameters used to overwrite discovery default behaviour
|
|
///
|
|
/// @return A JSON structure holding a list of devices found
|
|
///
|
|
QJsonObject discover(const QJsonObject& params);
|
|
|
|
///
|
|
/// @brief Setup a new capture display, will free the previous one
|
|
/// @return True on success, false if no display is found
|
|
///
|
|
bool setupDisplay();
|
|
|
|
///
|
|
/// @brief Opens the input device.
|
|
///
|
|
/// @return Zero, on success (i.e. device is ready), else negative
|
|
///
|
|
bool open();
|
|
|
|
#ifdef _WIN32
|
|
///
|
|
/// @brief Replacement for the virtual QWindowsScreen Function grabWindow (only on Windows).
|
|
///
|
|
/// @return QPixmap
|
|
///
|
|
QPixmap grabWindow(quintptr window, int xIn, int yIn, int width, int height) const;
|
|
#endif
|
|
|
|
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 Is called whenever we need new screen dimension calculations based on window geometry
|
|
///
|
|
int updateScreenDimensions(bool force);
|
|
|
|
///
|
|
/// @brief free the _screen pointer
|
|
///
|
|
void freeResources();
|
|
|
|
private:
|
|
|
|
int _display;
|
|
int _numberOfSDisplays;
|
|
|
|
int _screenWidth;
|
|
int _screenHeight;
|
|
int _src_x;
|
|
int _src_y;
|
|
int _src_x_max;
|
|
int _src_y_max;
|
|
bool _isWayland;
|
|
|
|
QScreen* _screen;
|
|
bool _isVirtual;
|
|
|
|
Logger * _logger;
|
|
};
|