mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
Kill "Rainbow lights" when v4l grabber has no signal (#334)
* on v4l screenshot, print out nosignal threshold values * separate fractional parameters for no signal detection * fully implement handling for "rainbow grabber"
This commit is contained in:
parent
b227f5a71c
commit
d59c94421d
@ -153,6 +153,10 @@
|
|||||||
/// * redSignalThreshold : Signal threshold for the red channel between 0.0 and 1.0 [default=0.0]
|
/// * redSignalThreshold : Signal threshold for the red channel between 0.0 and 1.0 [default=0.0]
|
||||||
/// * greenSignalThreshold : Signal threshold for the green channel between 0.0 and 1.0 [default=0.0]
|
/// * greenSignalThreshold : Signal threshold for the green channel between 0.0 and 1.0 [default=0.0]
|
||||||
/// * blueSignalThreshold : Signal threshold for the blue channel between 0.0 and 1.0 [default=0.0]
|
/// * blueSignalThreshold : Signal threshold for the blue channel between 0.0 and 1.0 [default=0.0]
|
||||||
|
/// * signalDetectionVerticalOffsetMin : area for signal detection - horizontal minimum offset value. Values between 0.0 and 1.0
|
||||||
|
/// * signalDetectionHorizontalOffsetMin : area for signal detection - vertical minimum offset value. Values between 0.0 and 1.0
|
||||||
|
/// * signalDetectionVerticalOffsetMax : area for signal detection - horizontal maximum offset value. Values between 0.0 and 1.0
|
||||||
|
/// * signalDetectionHorizontalOffsetMax : area for signal detection - vertical maximum offset value. Values between 0.0 and 1.0
|
||||||
"grabberV4L2" :
|
"grabberV4L2" :
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -173,7 +177,11 @@
|
|||||||
"cropBottom" : 0,
|
"cropBottom" : 0,
|
||||||
"redSignalThreshold" : 0.0,
|
"redSignalThreshold" : 0.0,
|
||||||
"greenSignalThreshold" : 0.0,
|
"greenSignalThreshold" : 0.0,
|
||||||
"blueSignalThreshold" : 0.0
|
"blueSignalThreshold" : 0.0,
|
||||||
|
"signalDetectionVerticalOffsetMin" : 0.25,
|
||||||
|
"signalDetectionHorizontalOffsetMin" : 0.25,
|
||||||
|
"signalDetectionVerticalOffsetMax" : 0.75,
|
||||||
|
"signalDetectionHorizontalOffsetMax" : 0.75
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
||||||
|
@ -105,7 +105,11 @@
|
|||||||
"cropBottom" : 0,
|
"cropBottom" : 0,
|
||||||
"redSignalThreshold" : 0.0,
|
"redSignalThreshold" : 0.0,
|
||||||
"greenSignalThreshold" : 0.0,
|
"greenSignalThreshold" : 0.0,
|
||||||
"blueSignalThreshold" : 0.0
|
"blueSignalThreshold" : 0.0,
|
||||||
|
"signalDetectionVerticalOffsetMin" : 0.25,
|
||||||
|
"signalDetectionHorizontalOffsetMin" : 0.25,
|
||||||
|
"signalDetectionVerticalOffsetMax" : 0.75,
|
||||||
|
"signalDetectionHorizontalOffsetMax" : 0.75
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
// Qt includes
|
// Qt includes
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QSocketNotifier>
|
#include <QSocketNotifier>
|
||||||
|
#include <QRectF>
|
||||||
|
|
||||||
// util includes
|
// util includes
|
||||||
#include <utils/Image.h>
|
#include <utils/Image.h>
|
||||||
@ -35,9 +36,12 @@ public:
|
|||||||
int height,
|
int height,
|
||||||
int frameDecimation,
|
int frameDecimation,
|
||||||
int horizontalPixelDecimation,
|
int horizontalPixelDecimation,
|
||||||
int verticalPixelDecimation);
|
int verticalPixelDecimation
|
||||||
|
);
|
||||||
virtual ~V4L2Grabber();
|
virtual ~V4L2Grabber();
|
||||||
|
|
||||||
|
QRectF getSignalDetectionOffset();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void setCropping(int cropLeft,
|
void setCropping(int cropLeft,
|
||||||
int cropRight,
|
int cropRight,
|
||||||
@ -46,11 +50,18 @@ public slots:
|
|||||||
|
|
||||||
void set3D(VideoMode mode);
|
void set3D(VideoMode mode);
|
||||||
|
|
||||||
void setSignalThreshold(double redSignalThreshold,
|
void setSignalThreshold(
|
||||||
|
double redSignalThreshold,
|
||||||
double greenSignalThreshold,
|
double greenSignalThreshold,
|
||||||
double blueSignalThreshold,
|
double blueSignalThreshold,
|
||||||
int noSignalCounterThreshold);
|
int noSignalCounterThreshold);
|
||||||
|
|
||||||
|
void setSignalDetectionOffset(
|
||||||
|
double verticalMin,
|
||||||
|
double horizontalMin,
|
||||||
|
double verticalMax,
|
||||||
|
double horizontalMax);
|
||||||
|
|
||||||
bool start();
|
bool start();
|
||||||
|
|
||||||
void stop();
|
void stop();
|
||||||
@ -137,4 +148,11 @@ private:
|
|||||||
Logger * _log;
|
Logger * _log;
|
||||||
bool _initialized;
|
bool _initialized;
|
||||||
bool _deviceAutoDiscoverEnabled;
|
bool _deviceAutoDiscoverEnabled;
|
||||||
|
|
||||||
|
bool _noSignalDetected;
|
||||||
|
double _x_frac_min;
|
||||||
|
double _y_frac_min;
|
||||||
|
double _x_frac_max;
|
||||||
|
double _y_frac_max;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -29,11 +29,10 @@ public:
|
|||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
bool start();
|
bool start();
|
||||||
|
|
||||||
void stop();
|
void stop();
|
||||||
|
|
||||||
void setCropping(int cropLeft, int cropRight, int cropTop, int cropBottom);
|
void setCropping(int cropLeft, int cropRight, int cropTop, int cropBottom);
|
||||||
|
void setSignalDetectionOffset(double verticalMin, double horizontalMin, double verticalMax, double horizontalMax);
|
||||||
void set3D(VideoMode mode);
|
void set3D(VideoMode mode);
|
||||||
|
|
||||||
// signals:
|
// signals:
|
||||||
|
@ -61,3 +61,16 @@ inline bool operator<=(const ColorRgb & lhs, const ColorRgb & rhs)
|
|||||||
{
|
{
|
||||||
return (lhs.red <= rhs.red) && (lhs.green <= rhs.green) && (lhs.blue <= rhs.blue);
|
return (lhs.red <= rhs.red) && (lhs.green <= rhs.green) && (lhs.blue <= rhs.blue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Compare operator to check if a color is 'greater' to another color
|
||||||
|
inline bool operator>(const ColorRgb & lhs, const ColorRgb & rhs)
|
||||||
|
{
|
||||||
|
return (lhs.red > rhs.red) && (lhs.green > rhs.green) && (lhs.blue > rhs.blue);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Compare operator to check if a color is 'greater' than or 'equal' to another color
|
||||||
|
inline bool operator>=(const ColorRgb & lhs, const ColorRgb & rhs)
|
||||||
|
{
|
||||||
|
return (lhs.red >= rhs.red) && (lhs.green >= rhs.green) && (lhs.blue >= rhs.blue);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -23,15 +23,16 @@
|
|||||||
|
|
||||||
#define CLEAR(x) memset(&(x), 0, sizeof(x))
|
#define CLEAR(x) memset(&(x), 0, sizeof(x))
|
||||||
|
|
||||||
V4L2Grabber::V4L2Grabber(const std::string & device,
|
V4L2Grabber::V4L2Grabber(const std::string & device
|
||||||
int input,
|
, int input
|
||||||
VideoStandard videoStandard,
|
, VideoStandard videoStandard
|
||||||
PixelFormat pixelFormat,
|
, PixelFormat pixelFormat
|
||||||
int width,
|
, int width
|
||||||
int height,
|
, int height
|
||||||
int frameDecimation,
|
, int frameDecimation
|
||||||
int horizontalPixelDecimation,
|
, int horizontalPixelDecimation
|
||||||
int verticalPixelDecimation)
|
, int verticalPixelDecimation
|
||||||
|
)
|
||||||
: _deviceName(device)
|
: _deviceName(device)
|
||||||
, _input(input)
|
, _input(input)
|
||||||
, _videoStandard(videoStandard)
|
, _videoStandard(videoStandard)
|
||||||
@ -53,6 +54,12 @@ V4L2Grabber::V4L2Grabber(const std::string & device,
|
|||||||
, _log(Logger::getInstance("V4L2:"+device))
|
, _log(Logger::getInstance("V4L2:"+device))
|
||||||
, _initialized(false)
|
, _initialized(false)
|
||||||
, _deviceAutoDiscoverEnabled(false)
|
, _deviceAutoDiscoverEnabled(false)
|
||||||
|
, _noSignalDetected(false)
|
||||||
|
, _x_frac_min(0.25)
|
||||||
|
, _y_frac_min(0.25)
|
||||||
|
, _x_frac_max(0.75)
|
||||||
|
, _y_frac_max(0.75)
|
||||||
|
|
||||||
{
|
{
|
||||||
_imageResampler.setHorizontalPixelDecimation(std::max(1, horizontalPixelDecimation));
|
_imageResampler.setHorizontalPixelDecimation(std::max(1, horizontalPixelDecimation));
|
||||||
_imageResampler.setVerticalPixelDecimation(std::max(1, verticalPixelDecimation));
|
_imageResampler.setVerticalPixelDecimation(std::max(1, verticalPixelDecimation));
|
||||||
@ -196,6 +203,24 @@ void V4L2Grabber::setSignalThreshold(double redSignalThreshold, double greenSign
|
|||||||
Info(_log, "Signal threshold set to: %s", ss.str().c_str() );
|
Info(_log, "Signal threshold set to: %s", ss.str().c_str() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void V4L2Grabber::setSignalDetectionOffset(double horizontalMin, double verticalMin, double horizontalMax, double verticalMax)
|
||||||
|
{
|
||||||
|
// rainbow 16 stripes 0.47 0.2 0.49 0.8
|
||||||
|
// unicolor: 0.25 0.25 0.75 0.75
|
||||||
|
|
||||||
|
_x_frac_min = horizontalMin;
|
||||||
|
_y_frac_min = verticalMin;
|
||||||
|
_x_frac_max = horizontalMax;
|
||||||
|
_y_frac_max = verticalMax;
|
||||||
|
|
||||||
|
Info(_log, "Signal detection area set to: %f,%f x %f,%f", _x_frac_min, _y_frac_min, _x_frac_max, _y_frac_max );
|
||||||
|
}
|
||||||
|
|
||||||
|
QRectF V4L2Grabber::getSignalDetectionOffset()
|
||||||
|
{
|
||||||
|
return QRectF(_x_frac_min, _y_frac_min, _x_frac_max, _y_frac_max);
|
||||||
|
}
|
||||||
|
|
||||||
bool V4L2Grabber::start()
|
bool V4L2Grabber::start()
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
@ -787,16 +812,21 @@ void V4L2Grabber::process_image(const uint8_t * data)
|
|||||||
|
|
||||||
// check signal (only in center of the resulting image, because some grabbers have noise values along the borders)
|
// check signal (only in center of the resulting image, because some grabbers have noise values along the borders)
|
||||||
bool noSignal = true;
|
bool noSignal = true;
|
||||||
for (unsigned x = 0; noSignal && x < (image.width()>>1); ++x)
|
|
||||||
{
|
|
||||||
int xImage = (image.width()>>2) + x;
|
|
||||||
|
|
||||||
for (unsigned y = 0; noSignal && y < (image.height()>>1); ++y)
|
// top left
|
||||||
{
|
unsigned xOffset = image.width() * _x_frac_min;
|
||||||
int yImage = (image.height()>>2) + y;
|
unsigned yOffset = image.height() * _y_frac_min;
|
||||||
|
|
||||||
ColorRgb & rgb = image(xImage, yImage);
|
// bottom right
|
||||||
noSignal &= rgb <= _noSignalThresholdColor;
|
unsigned xMax = image.width() * _x_frac_max;
|
||||||
|
unsigned yMax = image.height() * _y_frac_max;
|
||||||
|
|
||||||
|
|
||||||
|
for (unsigned x = xOffset; noSignal && x < xMax; ++x)
|
||||||
|
{
|
||||||
|
for (unsigned y = yOffset; noSignal && y < yMax; ++y)
|
||||||
|
{
|
||||||
|
noSignal &= (ColorRgb&)image(x, y) <= _noSignalThresholdColor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -808,6 +838,7 @@ void V4L2Grabber::process_image(const uint8_t * data)
|
|||||||
{
|
{
|
||||||
if (_noSignalCounter >= _noSignalCounterThreshold)
|
if (_noSignalCounter >= _noSignalCounterThreshold)
|
||||||
{
|
{
|
||||||
|
_noSignalDetected = true;
|
||||||
Info(_log, "Signal detected");
|
Info(_log, "Signal detected");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -820,6 +851,7 @@ void V4L2Grabber::process_image(const uint8_t * data)
|
|||||||
}
|
}
|
||||||
else if (_noSignalCounter == _noSignalCounterThreshold)
|
else if (_noSignalCounter == _noSignalCounterThreshold)
|
||||||
{
|
{
|
||||||
|
_noSignalDetected = false;
|
||||||
Info(_log, "Signal lost");
|
Info(_log, "Signal lost");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -74,6 +74,12 @@ void V4L2Wrapper::setCropping(int cropLeft, int cropRight, int cropTop, int crop
|
|||||||
_grabber.setCropping(cropLeft, cropRight, cropTop, cropBottom);
|
_grabber.setCropping(cropLeft, cropRight, cropTop, cropBottom);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void V4L2Wrapper::setSignalDetectionOffset(double verticalMin, double horizontalMin, double verticalMax, double horizontalMax)
|
||||||
|
{
|
||||||
|
_grabber.setSignalDetectionOffset(verticalMin, horizontalMin, verticalMax, horizontalMax);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void V4L2Wrapper::set3D(VideoMode mode)
|
void V4L2Wrapper::set3D(VideoMode mode)
|
||||||
{
|
{
|
||||||
_grabber.set3D(mode);
|
_grabber.set3D(mode);
|
||||||
|
@ -540,7 +540,7 @@
|
|||||||
"minimum" : 0.0,
|
"minimum" : 0.0,
|
||||||
"maximum" : 1.0,
|
"maximum" : 1.0,
|
||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.01,
|
"step" : 0.005,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 16
|
"propertyOrder" : 16
|
||||||
},
|
},
|
||||||
@ -551,7 +551,7 @@
|
|||||||
"minimum" : 0.0,
|
"minimum" : 0.0,
|
||||||
"maximum" : 1.0,
|
"maximum" : 1.0,
|
||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.01,
|
"step" : 0.025,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 17
|
"propertyOrder" : 17
|
||||||
},
|
},
|
||||||
@ -562,9 +562,53 @@
|
|||||||
"minimum" : 0.0,
|
"minimum" : 0.0,
|
||||||
"maximum" : 1.0,
|
"maximum" : 1.0,
|
||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.01,
|
"step" : 0.005,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 18
|
"propertyOrder" : 18
|
||||||
|
},
|
||||||
|
"signalDetectionVerticalOffsetMin" :
|
||||||
|
{
|
||||||
|
"type" : "number",
|
||||||
|
"title" : "edt_conf_v4l2_signalDetectionVerticalOffsetMin_title",
|
||||||
|
"minimum" : 0.0,
|
||||||
|
"maximum" : 1.0,
|
||||||
|
"default" : 0.1,
|
||||||
|
"step" : 0.005,
|
||||||
|
"append" : "edt_append_percent",
|
||||||
|
"propertyOrder" : 19
|
||||||
|
},
|
||||||
|
"signalDetectionVerticalOffsetMax" :
|
||||||
|
{
|
||||||
|
"type" : "number",
|
||||||
|
"title" : "edt_conf_v4l2_signalDetectionVerticalOffsetMax_title",
|
||||||
|
"minimum" : 0.0,
|
||||||
|
"maximum" : 1.0,
|
||||||
|
"default" : 0.1,
|
||||||
|
"step" : 0.005,
|
||||||
|
"append" : "edt_append_percent",
|
||||||
|
"propertyOrder" : 20
|
||||||
|
},
|
||||||
|
"signalDetectionHorizontalOffsetMin" :
|
||||||
|
{
|
||||||
|
"type" : "number",
|
||||||
|
"title" : "edt_conf_v4l2_signalDetectionHorizontalOffsetMin_title",
|
||||||
|
"minimum" : 0.0,
|
||||||
|
"maximum" : 1.0,
|
||||||
|
"default" : 0.1,
|
||||||
|
"step" : 0.005,
|
||||||
|
"append" : "edt_append_percent",
|
||||||
|
"propertyOrder" : 21
|
||||||
|
},
|
||||||
|
"signalDetectionHorizontalOffsetMax" :
|
||||||
|
{
|
||||||
|
"type" : "number",
|
||||||
|
"title" : "edt_conf_v4l2_signalDetectionHorizontalOffsetMax_title",
|
||||||
|
"minimum" : 0.0,
|
||||||
|
"maximum" : 1.0,
|
||||||
|
"default" : 0.1,
|
||||||
|
"step" : 0.005,
|
||||||
|
"append" : "edt_append_percent",
|
||||||
|
"propertyOrder" : 22
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties" : false
|
"additionalProperties" : false
|
||||||
|
@ -5,8 +5,9 @@
|
|||||||
// hyperion-v4l2 includes
|
// hyperion-v4l2 includes
|
||||||
#include "ScreenshotHandler.h"
|
#include "ScreenshotHandler.h"
|
||||||
|
|
||||||
ScreenshotHandler::ScreenshotHandler(const QString & filename) :
|
ScreenshotHandler::ScreenshotHandler(const QString & filename, const QRectF & signalDetectionOffset)
|
||||||
_filename(filename)
|
: _filename(filename)
|
||||||
|
, _signalDetectionOffset(signalDetectionOffset)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -16,6 +17,41 @@ ScreenshotHandler::~ScreenshotHandler()
|
|||||||
|
|
||||||
void ScreenshotHandler::receiveImage(const Image<ColorRgb> & image)
|
void ScreenshotHandler::receiveImage(const Image<ColorRgb> & image)
|
||||||
{
|
{
|
||||||
|
double x_frac_min = _signalDetectionOffset.x();
|
||||||
|
double y_frac_min = _signalDetectionOffset.y();
|
||||||
|
double x_frac_max = _signalDetectionOffset.width();
|
||||||
|
double y_frac_max = _signalDetectionOffset.height();
|
||||||
|
|
||||||
|
int xOffset = image.width() * x_frac_min;
|
||||||
|
int yOffset = image.height() * y_frac_min;
|
||||||
|
int xMax = image.width() * x_frac_max;
|
||||||
|
int yMax = image.height() * y_frac_max;
|
||||||
|
|
||||||
|
std::cout << std::endl << "Screenshot details"
|
||||||
|
<< std::endl << "=================="
|
||||||
|
<< std::endl << "dimension after decimation: " << image.width() << " x " << image.height()
|
||||||
|
<< std::endl << "signal detection area : " << xOffset << "," << yOffset << " x " << xMax << "," << yMax << std::endl;
|
||||||
|
|
||||||
|
ColorRgb noSignalThresholdColor = {0,0,0};
|
||||||
|
|
||||||
|
for (unsigned x = 0; x < (image.width()>>1); ++x)
|
||||||
|
{
|
||||||
|
int xImage = (image.width()>>2) + x;
|
||||||
|
|
||||||
|
for (unsigned y = 0; y < (image.height()>>1); ++y)
|
||||||
|
{
|
||||||
|
int yImage = (image.height()>>2) + y;
|
||||||
|
|
||||||
|
ColorRgb rgb = image(xImage, yImage);
|
||||||
|
if (rgb > noSignalThresholdColor)
|
||||||
|
{
|
||||||
|
noSignalThresholdColor = rgb;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
std::cout << "signal threshold color : " << noSignalThresholdColor << std::endl;
|
||||||
|
std::cout << "signal threshold values: " << (float)noSignalThresholdColor.red/255.0f << ", "<< (float)noSignalThresholdColor.green/255.0f << ", " << (float)noSignalThresholdColor.blue/255.0f << std::endl;
|
||||||
|
|
||||||
// store as PNG
|
// store as PNG
|
||||||
QImage pngImage((const uint8_t *) image.memptr(), image.width(), image.height(), 3*image.width(), QImage::Format_RGB888);
|
QImage pngImage((const uint8_t *) image.memptr(), image.width(), image.height(), 3*image.width(), QImage::Format_RGB888);
|
||||||
pngImage.save(_filename);
|
pngImage.save(_filename);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
// Qt includes
|
// Qt includes
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
#include <QRectF>
|
||||||
|
|
||||||
// hyperionincludes
|
// hyperionincludes
|
||||||
#include <utils/Image.h>
|
#include <utils/Image.h>
|
||||||
@ -11,7 +12,7 @@ class ScreenshotHandler : public QObject
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ScreenshotHandler(const QString & filename);
|
ScreenshotHandler(const QString & filename, const QRectF & signalDetectionOffset);
|
||||||
virtual ~ScreenshotHandler();
|
virtual ~ScreenshotHandler();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
@ -21,4 +22,5 @@ public slots:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
const QString _filename;
|
const QString _filename;
|
||||||
|
const QRectF _signalDetectionOffset;
|
||||||
};
|
};
|
||||||
|
@ -34,6 +34,7 @@ void saveScreenshot(QString filename, const Image<ColorRgb> & image)
|
|||||||
|
|
||||||
int main(int argc, char** argv)
|
int main(int argc, char** argv)
|
||||||
{
|
{
|
||||||
|
Logger *log = Logger::getInstance("V4L2GRABBER");
|
||||||
std::cout
|
std::cout
|
||||||
<< "hyperion-v4l2:" << std::endl
|
<< "hyperion-v4l2:" << std::endl
|
||||||
<< "\tVersion : " << HYPERION_VERSION << " (" << HYPERION_BUILD_ID << ")" << std::endl
|
<< "\tVersion : " << HYPERION_VERSION << " (" << HYPERION_BUILD_ID << ")" << std::endl
|
||||||
@ -68,10 +69,17 @@ int main(int argc, char** argv)
|
|||||||
IntOption & argSizeDecimation = parser.add<IntOption> ('s', "size-decimator", "Decimation factor for the output size [default=%1]", "1");
|
IntOption & argSizeDecimation = parser.add<IntOption> ('s', "size-decimator", "Decimation factor for the output size [default=%1]", "1");
|
||||||
IntOption & argFrameDecimation = parser.add<IntOption> ('f', "frame-decimator", "Decimation factor for the video frames [default=%1]", "1");
|
IntOption & argFrameDecimation = parser.add<IntOption> ('f', "frame-decimator", "Decimation factor for the video frames [default=%1]", "1");
|
||||||
BooleanOption & argScreenshot = parser.add<BooleanOption>(0x0, "screenshot", "Take a single screenshot, save it to file and quit");
|
BooleanOption & argScreenshot = parser.add<BooleanOption>(0x0, "screenshot", "Take a single screenshot, save it to file and quit");
|
||||||
|
|
||||||
DoubleOption & argSignalThreshold = parser.add<DoubleOption> ('t', "signal-threshold", "The signal threshold for detecting the presence of a signal. Value should be between 0.0 and 1.0.", QString(), 0.0, 1.0);
|
DoubleOption & argSignalThreshold = parser.add<DoubleOption> ('t', "signal-threshold", "The signal threshold for detecting the presence of a signal. Value should be between 0.0 and 1.0.", QString(), 0.0, 1.0);
|
||||||
DoubleOption & argRedSignalThreshold = parser.add<DoubleOption> (0x0, "red-threshold", "The red signal threshold. Value should be between 0.0 and 1.0. (overrides --signal-threshold)");
|
DoubleOption & argRedSignalThreshold = parser.add<DoubleOption> (0x0, "red-threshold", "The red signal threshold. Value should be between 0.0 and 1.0. (overrides --signal-threshold)");
|
||||||
DoubleOption & argGreenSignalThreshold= parser.add<DoubleOption> (0x0, "green-threshold", "The green signal threshold. Value should be between 0.0 and 1.0. (overrides --signal-threshold)");
|
DoubleOption & argGreenSignalThreshold= parser.add<DoubleOption> (0x0, "green-threshold", "The green signal threshold. Value should be between 0.0 and 1.0. (overrides --signal-threshold)");
|
||||||
DoubleOption & argBlueSignalThreshold = parser.add<DoubleOption> (0x0, "blue-threshold", "The blue signal threshold. Value should be between 0.0 and 1.0. (overrides --signal-threshold)");
|
DoubleOption & argBlueSignalThreshold = parser.add<DoubleOption> (0x0, "blue-threshold", "The blue signal threshold. Value should be between 0.0 and 1.0. (overrides --signal-threshold)");
|
||||||
|
|
||||||
|
DoubleOption & argSignalHorizontalMin = parser.add<DoubleOption> (0x0, "signal-horizontal-min", "area for signal detection - horizontal minimum offset value. Values between 0.0 and 1.0");
|
||||||
|
DoubleOption & argSignalVerticalMin = parser.add<DoubleOption> (0x0, "signal-vertical-min" , "area for signal detection - vertical minimum offset value. Values between 0.0 and 1.0");
|
||||||
|
DoubleOption & argSignalHorizontalMax = parser.add<DoubleOption> (0x0, "signal-horizontal-max", "area for signal detection - horizontal maximum offset value. Values between 0.0 and 1.0");
|
||||||
|
DoubleOption & argSignalVerticalMax = parser.add<DoubleOption> (0x0, "signal-vertical-max" , "area for signal detection - vertical maximum offset value. Values between 0.0 and 1.0");
|
||||||
|
|
||||||
BooleanOption & arg3DSBS = parser.add<BooleanOption>(0x0, "3DSBS", "Interpret the incoming video stream as 3D side-by-side");
|
BooleanOption & arg3DSBS = parser.add<BooleanOption>(0x0, "3DSBS", "Interpret the incoming video stream as 3D side-by-side");
|
||||||
BooleanOption & arg3DTAB = parser.add<BooleanOption>(0x0, "3DTAB", "Interpret the incoming video stream as 3D top-and-bottom");
|
BooleanOption & arg3DTAB = parser.add<BooleanOption>(0x0, "3DTAB", "Interpret the incoming video stream as 3D top-and-bottom");
|
||||||
Option & argAddress = parser.add<Option> ('a', "address", "Set the address of the hyperion server [default: %1]", "127.0.0.1:19445");
|
Option & argAddress = parser.add<Option> ('a', "address", "Set the address of the hyperion server [default: %1]", "127.0.0.1:19445");
|
||||||
@ -123,6 +131,44 @@ int main(int argc, char** argv)
|
|||||||
parser.isSet(argCropTop) ? argCropTop.getInt(parser) : argCropHeight.getInt(parser),
|
parser.isSet(argCropTop) ? argCropTop.getInt(parser) : argCropHeight.getInt(parser),
|
||||||
parser.isSet(argCropBottom) ? argCropBottom.getInt(parser) : argCropHeight.getInt(parser));
|
parser.isSet(argCropBottom) ? argCropBottom.getInt(parser) : argCropHeight.getInt(parser));
|
||||||
|
|
||||||
|
bool signalAreaOptsOk = true;
|
||||||
|
if (parser.isSet(argSignalHorizontalMin) != parser.isSet(argSignalVerticalMin))
|
||||||
|
{
|
||||||
|
signalAreaOptsOk = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parser.isSet(argSignalHorizontalMin) != parser.isSet(argSignalHorizontalMax))
|
||||||
|
{
|
||||||
|
signalAreaOptsOk = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parser.isSet(argSignalHorizontalMin) != parser.isSet(argSignalVerticalMax))
|
||||||
|
{
|
||||||
|
signalAreaOptsOk = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!signalAreaOptsOk)
|
||||||
|
{
|
||||||
|
Error(log, "aborting, because --signal-[vertical|horizontal]-[min|max] options must be used together");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
double x_frac_min = argSignalHorizontalMin.getDouble(parser);
|
||||||
|
double y_frac_min = argSignalVerticalMin.getDouble(parser);
|
||||||
|
double x_frac_max = argSignalHorizontalMax.getDouble(parser);
|
||||||
|
double y_frac_max = argSignalVerticalMax.getDouble(parser);
|
||||||
|
|
||||||
|
if (x_frac_min<0.0 || y_frac_min<0.0 || x_frac_max<0.0 || y_frac_max<0.0 || x_frac_min>1.0 || y_frac_min>1.0 || x_frac_max>1.0 || y_frac_max>1.0)
|
||||||
|
{
|
||||||
|
Error(log, "aborting, because --signal-[vertical|horizontal]-[min|max] values have to be between 0.0 and 1.0");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parser.isSet(argSignalHorizontalMin))
|
||||||
|
{
|
||||||
|
grabber.setSignalDetectionOffset( x_frac_min, y_frac_min, x_frac_max, y_frac_max);
|
||||||
|
}
|
||||||
|
|
||||||
// set 3D mode if applicable
|
// set 3D mode if applicable
|
||||||
if (parser.isSet(arg3DSBS))
|
if (parser.isSet(arg3DSBS))
|
||||||
{
|
{
|
||||||
@ -136,7 +182,9 @@ int main(int argc, char** argv)
|
|||||||
// run the grabber
|
// run the grabber
|
||||||
if (parser.isSet(argScreenshot))
|
if (parser.isSet(argScreenshot))
|
||||||
{
|
{
|
||||||
ScreenshotHandler handler("screenshot.png");
|
const QRectF signalDetectionOffset = grabber.getSignalDetectionOffset();
|
||||||
|
|
||||||
|
ScreenshotHandler handler("screenshot.png", signalDetectionOffset);
|
||||||
QObject::connect(&grabber, SIGNAL(newFrame(Image<ColorRgb>)), &handler, SLOT(receiveImage(Image<ColorRgb>)));
|
QObject::connect(&grabber, SIGNAL(newFrame(Image<ColorRgb>)), &handler, SLOT(receiveImage(Image<ColorRgb>)));
|
||||||
grabber.start();
|
grabber.start();
|
||||||
QCoreApplication::exec();
|
QCoreApplication::exec();
|
||||||
@ -154,7 +202,7 @@ int main(int argc, char** argv)
|
|||||||
catch (const std::runtime_error & e)
|
catch (const std::runtime_error & e)
|
||||||
{
|
{
|
||||||
// An error occured. Display error and quit
|
// An error occured. Display error and quit
|
||||||
Error(Logger::getInstance("V4L2GRABBER"), "%s", e.what());
|
Error(log, "%s", e.what());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -582,6 +582,11 @@ void HyperionDaemon::createGrabberV4L2()
|
|||||||
grabberConfig["cropRight"].toInt(0),
|
grabberConfig["cropRight"].toInt(0),
|
||||||
grabberConfig["cropTop"].toInt(0),
|
grabberConfig["cropTop"].toInt(0),
|
||||||
grabberConfig["cropBottom"].toInt(0));
|
grabberConfig["cropBottom"].toInt(0));
|
||||||
|
grabber->setSignalDetectionOffset(
|
||||||
|
grabberConfig["signalDetectionHorizontalOffsetMin"].toDouble(0.25),
|
||||||
|
grabberConfig["signalDetectionVerticalOffsetMin"].toDouble(0.25),
|
||||||
|
grabberConfig["signalDetectionHorizontalOffsetMax"].toDouble(0.75),
|
||||||
|
grabberConfig["signalDetectionVerticalOffsetMax"].toDouble(0.75));
|
||||||
Debug(_log, "V4L2 grabber created");
|
Debug(_log, "V4L2 grabber created");
|
||||||
|
|
||||||
QObject::connect(grabber, SIGNAL(emitImage(int, const Image<ColorRgb>&, const int)), _protoServer, SLOT(sendImageToProtoSlaves(int, const Image<ColorRgb>&, const int)));
|
QObject::connect(grabber, SIGNAL(emitImage(int, const Image<ColorRgb>&, const int)), _protoServer, SLOT(sendImageToProtoSlaves(int, const Image<ColorRgb>&, const int)));
|
||||||
|
Loading…
Reference in New Issue
Block a user