mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
f2eef4ecea
The OSD will use 20Hz for frame capture frequency The video capture frequency is based on the amlvideodri capture module
115 lines
2.5 KiB
C++
115 lines
2.5 KiB
C++
#pragma once
|
|
|
|
#include <QObject>
|
|
#include <QJsonObject>
|
|
#include <QJsonArray>
|
|
#include <QString>
|
|
#include <QStringList>
|
|
|
|
#include <utils/Logger.h>
|
|
#include <utils/Components.h>
|
|
#include <utils/Image.h>
|
|
#include <utils/ColorRgb.h>
|
|
#include <utils/VideoMode.h>
|
|
#include <utils/settings.h>
|
|
|
|
class Grabber;
|
|
class GlobalSignals;
|
|
class QTimer;
|
|
|
|
///
|
|
/// This class will be inherted by FramebufferWrapper and others which contains the real capture interface
|
|
///
|
|
class GrabberWrapper : public QObject
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
GrabberWrapper(QString grabberName, Grabber * ggrabber, unsigned width, unsigned height, const unsigned updateRate_Hz = 0);
|
|
|
|
virtual ~GrabberWrapper();
|
|
|
|
///
|
|
/// Starts the grabber wich produces led values with the specified update rate
|
|
///
|
|
virtual bool start();
|
|
|
|
///
|
|
/// Stop grabber
|
|
///
|
|
virtual void stop();
|
|
|
|
static QStringList availableGrabbers();
|
|
|
|
public:
|
|
template <typename Grabber_T>
|
|
bool transferFrame(Grabber_T &grabber)
|
|
{
|
|
unsigned w = grabber.getImageWidth();
|
|
unsigned h = grabber.getImageHeight();
|
|
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
|
|
///
|
|
virtual void setVideoMode(const VideoMode& videoMode);
|
|
|
|
///
|
|
/// 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);
|
|
|
|
///
|
|
/// @brief Handle settings update from HyperionDaemon Settingsmanager emit
|
|
/// @param type settingyType from enum
|
|
/// @param config configuration object
|
|
///
|
|
virtual void handleSettingsUpdate(const settings::type& type, const QJsonDocument& config);
|
|
|
|
signals:
|
|
///
|
|
/// @brief Emit the final processed image
|
|
///
|
|
void systemImage(const QString& name, const Image<ColorRgb>& image);
|
|
|
|
protected:
|
|
|
|
QString _grabberName;
|
|
|
|
/// The timer for generating events with the specified update rate
|
|
QTimer* _timer;
|
|
|
|
/// The calced update rate [ms]
|
|
int _updateInterval_ms;
|
|
|
|
/// The Logger instance
|
|
Logger * _log;
|
|
|
|
Grabber *_ggrabber;
|
|
|
|
/// The image used for grabbing frames
|
|
Image<ColorRgb> _image;
|
|
};
|