mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
make v4l signal detection switchable (#415)
This commit is contained in:
parent
bae3808957
commit
a20e073bbd
@ -467,6 +467,7 @@
|
|||||||
"edt_conf_v4l2_cropTop_expl" : "Anzahl der Pixel auf der oberen Seite die vom Bild entfernt werden.",
|
"edt_conf_v4l2_cropTop_expl" : "Anzahl der Pixel auf der oberen Seite die vom Bild entfernt werden.",
|
||||||
"edt_conf_v4l2_cropBottom_title" : "Entferne unten",
|
"edt_conf_v4l2_cropBottom_title" : "Entferne unten",
|
||||||
"edt_conf_v4l2_cropBottom_expl" : "Anzahl der Pixel auf der unteren Seite die vom Bild entfernt werden.",
|
"edt_conf_v4l2_cropBottom_expl" : "Anzahl der Pixel auf der unteren Seite die vom Bild entfernt werden.",
|
||||||
|
"edt_conf_v4l2_signalDetection_title" : "Signal Erkennung",
|
||||||
"edt_conf_v4l2_redSignalThreshold_title" : "Rote Signalschwelle",
|
"edt_conf_v4l2_redSignalThreshold_title" : "Rote Signalschwelle",
|
||||||
"edt_conf_v4l2_redSignalThreshold_expl" : "Verdunkelt rote Werte. (Wird als schwarz interpretiert)",
|
"edt_conf_v4l2_redSignalThreshold_expl" : "Verdunkelt rote Werte. (Wird als schwarz interpretiert)",
|
||||||
"edt_conf_v4l2_greenSignalThreshold_title" : "Grüne Signalschwelle",
|
"edt_conf_v4l2_greenSignalThreshold_title" : "Grüne Signalschwelle",
|
||||||
|
@ -468,6 +468,7 @@
|
|||||||
"edt_conf_v4l2_cropTop_expl" : "Count of pixels on the top side that are removed from the picture.",
|
"edt_conf_v4l2_cropTop_expl" : "Count of pixels on the top side that are removed from the picture.",
|
||||||
"edt_conf_v4l2_cropBottom_title" : "Crop bottom",
|
"edt_conf_v4l2_cropBottom_title" : "Crop bottom",
|
||||||
"edt_conf_v4l2_cropBottom_expl" : "Count of pixels on the bottom side that are removed from the picture.",
|
"edt_conf_v4l2_cropBottom_expl" : "Count of pixels on the bottom side that are removed from the picture.",
|
||||||
|
"edt_conf_v4l2_signalDetection_title" : "Enable signal detection",
|
||||||
"edt_conf_v4l2_redSignalThreshold_title" : "Red signal threshold",
|
"edt_conf_v4l2_redSignalThreshold_title" : "Red signal threshold",
|
||||||
"edt_conf_v4l2_redSignalThreshold_expl" : "Darkens low red values (recognized as black)",
|
"edt_conf_v4l2_redSignalThreshold_expl" : "Darkens low red values (recognized as black)",
|
||||||
"edt_conf_v4l2_greenSignalThreshold_title" : "Green signal threshold",
|
"edt_conf_v4l2_greenSignalThreshold_title" : "Green signal threshold",
|
||||||
|
@ -461,6 +461,7 @@
|
|||||||
"edt_conf_v4l2_cropTop_expl": "Cuenta de píxeles en la parte superior que se quitan de la imagen.",
|
"edt_conf_v4l2_cropTop_expl": "Cuenta de píxeles en la parte superior que se quitan de la imagen.",
|
||||||
"edt_conf_v4l2_cropBottom_title": "Cortar abajo",
|
"edt_conf_v4l2_cropBottom_title": "Cortar abajo",
|
||||||
"edt_conf_v4l2_cropBottom_expl": "Cuenta de píxeles en la parte inferior que se quitan de la imagen.",
|
"edt_conf_v4l2_cropBottom_expl": "Cuenta de píxeles en la parte inferior que se quitan de la imagen.",
|
||||||
|
"edt_conf_v4l2_signalDetection_title" : "Detección de señal",
|
||||||
"edt_conf_v4l2_redSignalThreshold_title": "Umbral de señal rojo",
|
"edt_conf_v4l2_redSignalThreshold_title": "Umbral de señal rojo",
|
||||||
"edt_conf_v4l2_redSignalThreshold_expl": "Oscurece los valores bajos de color rojo (reconocidos como negros)",
|
"edt_conf_v4l2_redSignalThreshold_expl": "Oscurece los valores bajos de color rojo (reconocidos como negros)",
|
||||||
"edt_conf_v4l2_greenSignalThreshold_title": "Umbral de señal verde",
|
"edt_conf_v4l2_greenSignalThreshold_title": "Umbral de señal verde",
|
||||||
|
@ -114,6 +114,7 @@
|
|||||||
/// * cropRight : Cropping from the right [default=0]
|
/// * cropRight : Cropping from the right [default=0]
|
||||||
/// * cropTop : Cropping from the top [default=0]
|
/// * cropTop : Cropping from the top [default=0]
|
||||||
/// * cropBottom : Cropping from the bottom [default=0]
|
/// * cropBottom : Cropping from the bottom [default=0]
|
||||||
|
/// * signalDetection : enable/disable signal detection [default=true]
|
||||||
/// * 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]
|
||||||
@ -142,6 +143,7 @@
|
|||||||
"redSignalThreshold" : 0.0,
|
"redSignalThreshold" : 0.0,
|
||||||
"greenSignalThreshold" : 0.0,
|
"greenSignalThreshold" : 0.0,
|
||||||
"blueSignalThreshold" : 0.0,
|
"blueSignalThreshold" : 0.0,
|
||||||
|
"signalDetection" : true,
|
||||||
"signalDetectionVerticalOffsetMin" : 0.25,
|
"signalDetectionVerticalOffsetMin" : 0.25,
|
||||||
"signalDetectionHorizontalOffsetMin" : 0.25,
|
"signalDetectionHorizontalOffsetMin" : 0.25,
|
||||||
"signalDetectionVerticalOffsetMax" : 0.75,
|
"signalDetectionVerticalOffsetMax" : 0.75,
|
||||||
|
@ -76,6 +76,7 @@
|
|||||||
"redSignalThreshold" : 0.0,
|
"redSignalThreshold" : 0.0,
|
||||||
"greenSignalThreshold" : 0.0,
|
"greenSignalThreshold" : 0.0,
|
||||||
"blueSignalThreshold" : 0.0,
|
"blueSignalThreshold" : 0.0,
|
||||||
|
"signalDetection" : true,
|
||||||
"signalDetectionVerticalOffsetMin" : 0.25,
|
"signalDetectionVerticalOffsetMin" : 0.25,
|
||||||
"signalDetectionHorizontalOffsetMin" : 0.25,
|
"signalDetectionHorizontalOffsetMin" : 0.25,
|
||||||
"signalDetectionVerticalOffsetMax" : 0.75,
|
"signalDetectionVerticalOffsetMax" : 0.75,
|
||||||
|
@ -40,6 +40,7 @@ public:
|
|||||||
virtual ~V4L2Grabber();
|
virtual ~V4L2Grabber();
|
||||||
|
|
||||||
QRectF getSignalDetectionOffset();
|
QRectF getSignalDetectionOffset();
|
||||||
|
bool getSignalDetectionEnabled();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void setCropping(int cropLeft,
|
void setCropping(int cropLeft,
|
||||||
@ -61,6 +62,8 @@ public slots:
|
|||||||
double verticalMax,
|
double verticalMax,
|
||||||
double horizontalMax);
|
double horizontalMax);
|
||||||
|
|
||||||
|
void setSignalDetectionEnable(bool enable);
|
||||||
|
|
||||||
bool start();
|
bool start();
|
||||||
|
|
||||||
void stop();
|
void stop();
|
||||||
@ -133,13 +136,19 @@ private:
|
|||||||
int _lineLength;
|
int _lineLength;
|
||||||
int _frameByteSize;
|
int _frameByteSize;
|
||||||
int _frameDecimation;
|
int _frameDecimation;
|
||||||
int _noSignalCounterThreshold;
|
|
||||||
|
|
||||||
|
// signal detection
|
||||||
|
int _noSignalCounterThreshold;
|
||||||
ColorRgb _noSignalThresholdColor;
|
ColorRgb _noSignalThresholdColor;
|
||||||
|
bool _signalDetectionEnabled;
|
||||||
|
bool _noSignalDetected;
|
||||||
|
int _noSignalCounter;
|
||||||
|
double _x_frac_min;
|
||||||
|
double _y_frac_min;
|
||||||
|
double _x_frac_max;
|
||||||
|
double _y_frac_max;
|
||||||
|
|
||||||
int _currentFrame;
|
int _currentFrame;
|
||||||
int _noSignalCounter;
|
|
||||||
|
|
||||||
QSocketNotifier * _streamNotifier;
|
QSocketNotifier * _streamNotifier;
|
||||||
|
|
||||||
ImageResampler _imageResampler;
|
ImageResampler _imageResampler;
|
||||||
@ -148,10 +157,5 @@ private:
|
|||||||
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;
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -27,6 +27,8 @@ public:
|
|||||||
const int priority);
|
const int priority);
|
||||||
virtual ~V4L2Wrapper();
|
virtual ~V4L2Wrapper();
|
||||||
|
|
||||||
|
bool getSignalDetectionEnable();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
bool start();
|
bool start();
|
||||||
void stop();
|
void stop();
|
||||||
@ -34,6 +36,7 @@ public slots:
|
|||||||
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 setSignalDetectionOffset(double verticalMin, double horizontalMin, double verticalMax, double horizontalMax);
|
||||||
void set3D(VideoMode mode);
|
void set3D(VideoMode mode);
|
||||||
|
void setSignalDetectionEnable(bool enable);
|
||||||
|
|
||||||
// signals:
|
// signals:
|
||||||
// void emitColors(int priority, const std::vector<ColorRgb> &ledColors, const int timeout_ms);
|
// void emitColors(int priority, const std::vector<ColorRgb> &ledColors, const int timeout_ms);
|
||||||
|
@ -47,6 +47,12 @@ V4L2Grabber::V4L2Grabber(const QString & device
|
|||||||
, _frameDecimation(std::max(1, frameDecimation))
|
, _frameDecimation(std::max(1, frameDecimation))
|
||||||
, _noSignalCounterThreshold(50)
|
, _noSignalCounterThreshold(50)
|
||||||
, _noSignalThresholdColor(ColorRgb{0,0,0})
|
, _noSignalThresholdColor(ColorRgb{0,0,0})
|
||||||
|
, _signalDetectionEnabled(true)
|
||||||
|
, _noSignalDetected(false)
|
||||||
|
, _x_frac_min(0.25)
|
||||||
|
, _y_frac_min(0.25)
|
||||||
|
, _x_frac_max(0.75)
|
||||||
|
, _y_frac_max(0.75)
|
||||||
, _currentFrame(0)
|
, _currentFrame(0)
|
||||||
, _noSignalCounter(0)
|
, _noSignalCounter(0)
|
||||||
, _streamNotifier(nullptr)
|
, _streamNotifier(nullptr)
|
||||||
@ -54,11 +60,6 @@ V4L2Grabber::V4L2Grabber(const QString & 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));
|
||||||
@ -809,6 +810,8 @@ void V4L2Grabber::process_image(const uint8_t * data)
|
|||||||
Image<ColorRgb> image(0, 0);
|
Image<ColorRgb> image(0, 0);
|
||||||
_imageResampler.processImage(data, _width, _height, _lineLength, _pixelFormat, image);
|
_imageResampler.processImage(data, _width, _height, _lineLength, _pixelFormat, image);
|
||||||
|
|
||||||
|
if (_signalDetectionEnabled)
|
||||||
|
{
|
||||||
// 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;
|
||||||
|
|
||||||
@ -854,6 +857,11 @@ void V4L2Grabber::process_image(const uint8_t * data)
|
|||||||
Info(_log, "Signal lost");
|
Info(_log, "Signal lost");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
emit newFrame(image);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int V4L2Grabber::xioctl(int request, void *arg)
|
int V4L2Grabber::xioctl(int request, void *arg)
|
||||||
{
|
{
|
||||||
@ -877,3 +885,13 @@ void V4L2Grabber::throw_errno_exception(const QString & error)
|
|||||||
{
|
{
|
||||||
throw std::runtime_error(QString(error + " error code " + QString::number(errno) + ", " + strerror(errno)).toStdString());
|
throw std::runtime_error(QString(error + " error code " + QString::number(errno) + ", " + strerror(errno)).toStdString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void V4L2Grabber::setSignalDetectionEnable(bool enable)
|
||||||
|
{
|
||||||
|
_signalDetectionEnabled = enable;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool V4L2Grabber::getSignalDetectionEnabled()
|
||||||
|
{
|
||||||
|
return _signalDetectionEnabled;
|
||||||
|
}
|
||||||
|
@ -122,3 +122,13 @@ void V4L2Wrapper::action()
|
|||||||
{
|
{
|
||||||
checkSources();
|
checkSources();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void V4L2Wrapper::setSignalDetectionEnable(bool enable)
|
||||||
|
{
|
||||||
|
_grabber.setSignalDetectionEnable(enable);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool V4L2Wrapper::getSignalDetectionEnable()
|
||||||
|
{
|
||||||
|
return _grabber.getSignalDetectionEnabled();
|
||||||
|
}
|
||||||
|
@ -544,6 +544,13 @@
|
|||||||
"append" : "edt_append_pixel",
|
"append" : "edt_append_pixel",
|
||||||
"propertyOrder" : 15
|
"propertyOrder" : 15
|
||||||
},
|
},
|
||||||
|
"signalDetection" :
|
||||||
|
{
|
||||||
|
"type" : "boolean",
|
||||||
|
"title" : "edt_conf_v4l2_signalDetection_title",
|
||||||
|
"default" : true,
|
||||||
|
"propertyOrder" : 16
|
||||||
|
},
|
||||||
"redSignalThreshold" :
|
"redSignalThreshold" :
|
||||||
{
|
{
|
||||||
"type" : "number",
|
"type" : "number",
|
||||||
@ -553,7 +560,7 @@
|
|||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.005,
|
"step" : 0.005,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 16
|
"propertyOrder" : 17
|
||||||
},
|
},
|
||||||
"greenSignalThreshold" :
|
"greenSignalThreshold" :
|
||||||
{
|
{
|
||||||
@ -564,7 +571,7 @@
|
|||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.025,
|
"step" : 0.025,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 17
|
"propertyOrder" : 18
|
||||||
},
|
},
|
||||||
"blueSignalThreshold" :
|
"blueSignalThreshold" :
|
||||||
{
|
{
|
||||||
@ -575,7 +582,7 @@
|
|||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.005,
|
"step" : 0.005,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 18
|
"propertyOrder" : 19
|
||||||
},
|
},
|
||||||
"signalDetectionVerticalOffsetMin" :
|
"signalDetectionVerticalOffsetMin" :
|
||||||
{
|
{
|
||||||
@ -586,7 +593,7 @@
|
|||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.005,
|
"step" : 0.005,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 19
|
"propertyOrder" : 20
|
||||||
},
|
},
|
||||||
"signalDetectionVerticalOffsetMax" :
|
"signalDetectionVerticalOffsetMax" :
|
||||||
{
|
{
|
||||||
@ -597,7 +604,7 @@
|
|||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.005,
|
"step" : 0.005,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 20
|
"propertyOrder" : 21
|
||||||
},
|
},
|
||||||
"signalDetectionHorizontalOffsetMin" :
|
"signalDetectionHorizontalOffsetMin" :
|
||||||
{
|
{
|
||||||
@ -608,7 +615,7 @@
|
|||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.005,
|
"step" : 0.005,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 21
|
"propertyOrder" : 22
|
||||||
},
|
},
|
||||||
"signalDetectionHorizontalOffsetMax" :
|
"signalDetectionHorizontalOffsetMax" :
|
||||||
{
|
{
|
||||||
@ -619,7 +626,7 @@
|
|||||||
"default" : 0.1,
|
"default" : 0.1,
|
||||||
"step" : 0.005,
|
"step" : 0.005,
|
||||||
"append" : "edt_append_percent",
|
"append" : "edt_append_percent",
|
||||||
"propertyOrder" : 22
|
"propertyOrder" : 23
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties" : false
|
"additionalProperties" : false
|
||||||
|
@ -72,6 +72,7 @@ int main(int argc, char** argv)
|
|||||||
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");
|
||||||
|
|
||||||
|
BooleanOption & argSignalDetection = parser.add<BooleanOption>('s', "signal-detection-disabled", "disable signal detection");
|
||||||
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)");
|
||||||
@ -120,6 +121,7 @@ int main(int argc, char** argv)
|
|||||||
std::max(1, argSizeDecimation.getInt(parser)));
|
std::max(1, argSizeDecimation.getInt(parser)));
|
||||||
|
|
||||||
// set signal detection
|
// set signal detection
|
||||||
|
grabber.setSignalDetectionEnable(! parser.isSet(argSignalDetection));
|
||||||
grabber.setSignalThreshold(
|
grabber.setSignalThreshold(
|
||||||
std::min(1.0, std::max(0.0, parser.isSet(argRedSignalThreshold) ? argRedSignalThreshold.getDouble(parser) : argSignalThreshold.getDouble(parser))),
|
std::min(1.0, std::max(0.0, parser.isSet(argRedSignalThreshold) ? argRedSignalThreshold.getDouble(parser) : argSignalThreshold.getDouble(parser))),
|
||||||
std::min(1.0, std::max(0.0, parser.isSet(argGreenSignalThreshold) ? argGreenSignalThreshold.getDouble(parser) : argSignalThreshold.getDouble(parser))),
|
std::min(1.0, std::max(0.0, parser.isSet(argGreenSignalThreshold) ? argGreenSignalThreshold.getDouble(parser) : argSignalThreshold.getDouble(parser))),
|
||||||
|
@ -612,6 +612,7 @@ 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->setSignalDetectionEnable(grabberConfig["signalDetection"].toBool(true));
|
||||||
grabber->setSignalDetectionOffset(
|
grabber->setSignalDetectionOffset(
|
||||||
grabberConfig["signalDetectionHorizontalOffsetMin"].toDouble(0.25),
|
grabberConfig["signalDetectionHorizontalOffsetMin"].toDouble(0.25),
|
||||||
grabberConfig["signalDetectionVerticalOffsetMin"].toDouble(0.25),
|
grabberConfig["signalDetectionVerticalOffsetMin"].toDouble(0.25),
|
||||||
|
Loading…
Reference in New Issue
Block a user