2013-08-13 11:10:45 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// QT includes
|
|
|
|
#include <QObject>
|
|
|
|
#include <QTimer>
|
|
|
|
|
2013-08-14 10:54:49 +02:00
|
|
|
// Utils includes
|
|
|
|
#include <utils/RgbColor.h>
|
2013-08-14 17:02:09 +02:00
|
|
|
#include <utils/RgbImage.h>
|
2013-09-23 22:33:38 +02:00
|
|
|
#include <utils/GrabbingMode.h>
|
2013-08-14 10:54:49 +02:00
|
|
|
|
2013-08-13 11:10:45 +02:00
|
|
|
// Forward class declaration
|
|
|
|
class DispmanxFrameGrabber;
|
2013-08-14 10:54:49 +02:00
|
|
|
class Hyperion;
|
|
|
|
class ImageProcessor;
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-08-14 10:54:49 +02:00
|
|
|
///
|
|
|
|
/// The DispmanxWrapper uses an instance of the DispmanxFrameGrabber to obtain RgbImage's from the
|
|
|
|
/// displayed content. This RgbImage is processed to a RgbColor for each led and commmited to the
|
|
|
|
/// attached Hyperion.
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
class DispmanxWrapper: public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// Constructs the dispmanx frame grabber with a specified grab size and update rate.
|
|
|
|
///
|
|
|
|
/// @param[in] grabWidth The width of the grabbed image [pixels]
|
|
|
|
/// @param[in] grabHeight The height of the grabbed images [pixels]
|
|
|
|
/// @param[in] updateRate_Hz The image grab rate [Hz]
|
|
|
|
/// @param[in] hyperion The instance of Hyperion used to write the led values
|
|
|
|
///
|
2013-08-14 10:54:49 +02:00
|
|
|
DispmanxWrapper(const unsigned grabWidth, const unsigned grabHeight, const unsigned updateRate_Hz, Hyperion * hyperion);
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// Destructor of this dispmanx frame grabber. Releases any claimed resources.
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
virtual ~DispmanxWrapper();
|
|
|
|
|
|
|
|
public slots:
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// Starts the grabber wich produces led values with the specified update rate
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
void start();
|
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// Performs a single frame grab and computes the led-colors
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
void action();
|
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// Stops the grabber
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
void stop();
|
|
|
|
|
2013-09-23 22:33:38 +02:00
|
|
|
///
|
|
|
|
/// \brief Set the grabbing mode
|
|
|
|
/// \param mode The new grabbing mode
|
|
|
|
///
|
|
|
|
void setGrabbingMode(GrabbingMode mode);
|
|
|
|
|
2013-08-13 11:10:45 +02:00
|
|
|
private:
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The update rate [Hz]
|
2013-08-14 10:54:49 +02:00
|
|
|
const int _updateInterval_ms;
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The timeout of the led colors [ms]
|
2013-08-14 10:54:49 +02:00
|
|
|
const int _timeout_ms;
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The priority of the led colors [ms]
|
2013-08-18 12:21:07 +02:00
|
|
|
const int _priority;
|
2013-08-14 10:54:49 +02:00
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The timer for generating events with the specified update rate
|
2013-08-13 11:10:45 +02:00
|
|
|
QTimer _timer;
|
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The image used for grabbing frames
|
2013-08-14 17:02:09 +02:00
|
|
|
RgbImage _image;
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The actual grabber
|
2013-08-14 10:54:49 +02:00
|
|
|
DispmanxFrameGrabber * _frameGrabber;
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The processor for transforming images to led colors
|
2013-08-14 10:54:49 +02:00
|
|
|
ImageProcessor * _processor;
|
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The list with computed led colors
|
2013-08-14 10:54:49 +02:00
|
|
|
std::vector<RgbColor> _ledColors;
|
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
/// Pointer to Hyperion for writing led values
|
2013-08-14 10:54:49 +02:00
|
|
|
Hyperion * _hyperion;
|
2013-08-13 11:10:45 +02:00
|
|
|
};
|