2013-08-13 11:10:45 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// BCM includes
|
2013-08-13 12:03:00 +02:00
|
|
|
#pragma GCC system_header
|
2013-08-13 11:10:45 +02:00
|
|
|
#include <bcm_host.h>
|
|
|
|
|
|
|
|
// STL includes
|
|
|
|
#include <cstdint>
|
|
|
|
|
|
|
|
// Utils includes
|
2013-11-11 10:00:37 +01:00
|
|
|
#include <utils/Image.h>
|
|
|
|
#include <utils/ColorRgba.h>
|
2013-12-21 14:32:30 +01:00
|
|
|
#include <utils/VideoMode.h>
|
2016-07-12 00:53:48 +02:00
|
|
|
#include <utils/Logger.h>
|
2013-08-13 11:10:45 +02:00
|
|
|
|
|
|
|
///
|
2013-08-21 16:37:00 +02:00
|
|
|
/// The DispmanxFrameGrabber is used for creating snapshots of the display (screenshots) with a
|
|
|
|
/// downsized and scaled resolution.
|
2013-08-13 11:10:45 +02:00
|
|
|
///
|
|
|
|
class DispmanxFrameGrabber
|
|
|
|
{
|
|
|
|
public:
|
2013-08-21 16:37:00 +02:00
|
|
|
///
|
|
|
|
/// Construct a DispmanxFrameGrabber that will capture snapshots with specified dimensions.
|
|
|
|
///
|
|
|
|
/// @param[in] width The width of the captured screenshot
|
|
|
|
/// @param[in] height The heigth of the captured screenshot
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
DispmanxFrameGrabber(const unsigned width, const unsigned height);
|
|
|
|
~DispmanxFrameGrabber();
|
|
|
|
|
2013-10-02 09:46:12 +02:00
|
|
|
///
|
|
|
|
/// Updates the frame-grab flags as used by the VC library for frame grabbing
|
|
|
|
///
|
|
|
|
/// @param vc_flags The snapshot grabbing mask
|
|
|
|
///
|
|
|
|
void setFlags(const int vc_flags);
|
|
|
|
|
2013-12-21 14:32:30 +01:00
|
|
|
///
|
|
|
|
/// Set the video mode (2D/3D)
|
|
|
|
/// @param[in] mode The new video mode
|
|
|
|
///
|
|
|
|
void setVideoMode(const VideoMode videoMode);
|
|
|
|
|
2016-05-18 11:26:25 +02:00
|
|
|
void setCropping(const unsigned cropLeft, const unsigned cropRight,
|
|
|
|
const unsigned cropTop, const unsigned cropBottom);
|
|
|
|
|
2013-08-21 16:37:00 +02: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)
|
|
|
|
///
|
2013-11-11 10:00:37 +01:00
|
|
|
void grabFrame(Image<ColorRgba> & image);
|
2013-08-13 11:10:45 +02:00
|
|
|
|
|
|
|
private:
|
2013-08-21 16:37:00 +02:00
|
|
|
/// Handle to the display that is being captured
|
|
|
|
DISPMANX_DISPLAY_HANDLE_T _vc_display;
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-08-21 16:37:00 +02:00
|
|
|
/// Handle to the resource for storing the captured snapshot
|
|
|
|
DISPMANX_RESOURCE_HANDLE_T _vc_resource;
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-08-21 16:37:00 +02:00
|
|
|
/// Rectangle of the captured resource that is transfered to user space
|
2013-08-13 11:10:45 +02:00
|
|
|
VC_RECT_T _rectangle;
|
2013-08-21 16:37:00 +02:00
|
|
|
|
2013-10-02 09:46:12 +02:00
|
|
|
/// Flags (transforms) for creating snapshots
|
|
|
|
int _vc_flags;
|
|
|
|
|
2013-08-21 16:37:00 +02:00
|
|
|
/// With of the captured snapshot [pixels]
|
2013-12-21 14:32:30 +01:00
|
|
|
const unsigned _width;
|
2013-08-21 16:37:00 +02:00
|
|
|
/// Height of the captured snapshot [pixels]
|
2013-12-21 14:32:30 +01:00
|
|
|
const unsigned _height;
|
2016-05-18 11:26:25 +02:00
|
|
|
|
|
|
|
// the selected VideoMode
|
|
|
|
VideoMode _videoMode;
|
|
|
|
|
|
|
|
// number of pixels to crop after capturing
|
|
|
|
unsigned _cropLeft, _cropRight, _cropTop, _cropBottom;
|
|
|
|
|
|
|
|
// temp buffer when capturing with unsupported pitch size or
|
|
|
|
// when we need to crop the image
|
|
|
|
ColorRgba* _captureBuffer;
|
|
|
|
|
|
|
|
// size of the capture buffer in Pixels
|
|
|
|
unsigned _captureBufferSize;
|
2016-07-12 00:53:48 +02:00
|
|
|
|
|
|
|
Logger * _log;
|
2013-08-13 11:10:45 +02:00
|
|
|
};
|