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 * Refactor Hyperion Daemon unsing smartpointers * Correction * Correct typos/ align text * Fix startGrabberDispmanx * Fix startGrabberDispmanx * Address CodeQL finding * Create Screen grabbers via Template * Fix typo * Change way of logging * Revert change * Address deprecation warning * Correct auto screen grabber evaluation --------- Co-authored-by: Paulchen-Panther <16664240+Paulchen-Panther@users.noreply.github.com>
74 lines
1.8 KiB
C++
74 lines
1.8 KiB
C++
#pragma once
|
|
|
|
#include <linux/fb.h>
|
|
|
|
// Utils includes
|
|
#include <utils/ColorRgb.h>
|
|
#include <hyperion/Grabber.h>
|
|
|
|
///
|
|
/// The FramebufferFrameGrabber is used for creating snapshots of the display (screenshots)
|
|
///
|
|
class FramebufferFrameGrabber : public Grabber
|
|
{
|
|
public:
|
|
///
|
|
/// Construct a FramebufferFrameGrabber that will capture snapshots with specified dimensions.
|
|
///
|
|
/// @param[in] device The framebuffer device name/path
|
|
///
|
|
FramebufferFrameGrabber(int deviceIdx = 0);
|
|
|
|
~FramebufferFrameGrabber() 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 Setup a new capture screen, will free the previous one
|
|
/// @return True on success, false if no screen is found
|
|
///
|
|
bool setupScreen();
|
|
|
|
|
|
QSize getScreenSize() const;
|
|
QSize getScreenSize(const QString& device) const;
|
|
|
|
///
|
|
///@brief Set new width and height for framegrabber, overwrite Grabber.h implementation
|
|
bool setWidthHeight(int width, int height) override;
|
|
|
|
QString getPath() const {return QString("/dev/fb%1").arg(_input);}
|
|
|
|
///
|
|
/// @brief Discover Framebuffer 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);
|
|
|
|
private:
|
|
|
|
bool openDevice();
|
|
bool closeDevice();
|
|
bool getScreenInfo();
|
|
|
|
// /// Framebuffer device e.g. /dev/fb0
|
|
QString _fbDevice;
|
|
|
|
int _fbfd;
|
|
struct fb_var_screeninfo _varInfo;
|
|
struct fb_fix_screeninfo _fixInfo;
|
|
|
|
PixelFormat _pixelFormat;
|
|
};
|