From c1cb148f41c2b2c872bfd5bccab15dfeff38341e Mon Sep 17 00:00:00 2001 From: penfold42 Date: Sun, 10 Jul 2016 21:36:05 +1000 Subject: [PATCH] added enable to v4lgrabber (#93) * added enable to v4lgrabber * updated configs with v4l enable/disable example --- config/hyperion.config.json.commented | 2 ++ config/hyperion.config.json.default | 1 + src/hyperiond/hyperiond.cpp | 47 ++++++++++++++------------- 3 files changed, 28 insertions(+), 22 deletions(-) diff --git a/config/hyperion.config.json.commented b/config/hyperion.config.json.commented index b44f7bb9..347a5c96 100644 --- a/config/hyperion.config.json.commented +++ b/config/hyperion.config.json.commented @@ -141,6 +141,7 @@ }, /// Configuration for the embedded V4L2 grabber + /// * enable : Enable or disable the v4lgrabber (true/false) /// * device : V4L2 Device to use [default="/dev/video0"] /// * input : V4L2 input to use [default=0] /// * standard : Video standard (no-change/PAL/NTSC) [default="no-change"] @@ -159,6 +160,7 @@ /// * blueSignalThreshold : Signal threshold for the blue channel between 0.0 and 1.0 [default=0.0] "grabber-v4l2" : { + "enable" : false, "device" : "/dev/video0", "input" : 0, "standard" : "no-change", diff --git a/config/hyperion.config.json.default b/config/hyperion.config.json.default index 7f9a01c8..b72bbf17 100644 --- a/config/hyperion.config.json.default +++ b/config/hyperion.config.json.default @@ -92,6 +92,7 @@ "grabber-v4l2" : { + "enable" : false, "device" : "/dev/video0", "input" : 0, "standard" : "PAL", diff --git a/src/hyperiond/hyperiond.cpp b/src/hyperiond/hyperiond.cpp index 93696300..ad676c22 100644 --- a/src/hyperiond/hyperiond.cpp +++ b/src/hyperiond/hyperiond.cpp @@ -359,30 +359,33 @@ void HyperionDaemon::createGrabberV4L2() if (_config.isMember("grabber-v4l2")) { const Json::Value & grabberConfig = _config["grabber-v4l2"]; - _v4l2Grabber = new V4L2Wrapper( - grabberConfig.get("device", "/dev/video0").asString(), - grabberConfig.get("input", 0).asInt(), - parseVideoStandard(grabberConfig.get("standard", "no-change").asString()), - parsePixelFormat(grabberConfig.get("pixelFormat", "no-change").asString()), - grabberConfig.get("width", -1).asInt(), - grabberConfig.get("height", -1).asInt(), - grabberConfig.get("frameDecimation", 2).asInt(), - grabberConfig.get("sizeDecimation", 8).asInt(), - grabberConfig.get("redSignalThreshold", 0.0).asDouble(), - grabberConfig.get("greenSignalThreshold", 0.0).asDouble(), - grabberConfig.get("blueSignalThreshold", 0.0).asDouble(), - grabberConfig.get("priority", 900).asInt()); - _v4l2Grabber->set3D(parse3DMode(grabberConfig.get("mode", "2D").asString())); - _v4l2Grabber->setCropping( - grabberConfig.get("cropLeft", 0).asInt(), - grabberConfig.get("cropRight", 0).asInt(), - grabberConfig.get("cropTop", 0).asInt(), - grabberConfig.get("cropBottom", 0).asInt()); + if (grabberConfig.get("enable", true).asBool()) + { + _v4l2Grabber = new V4L2Wrapper( + grabberConfig.get("device", "/dev/video0").asString(), + grabberConfig.get("input", 0).asInt(), + parseVideoStandard(grabberConfig.get("standard", "no-change").asString()), + parsePixelFormat(grabberConfig.get("pixelFormat", "no-change").asString()), + grabberConfig.get("width", -1).asInt(), + grabberConfig.get("height", -1).asInt(), + grabberConfig.get("frameDecimation", 2).asInt(), + grabberConfig.get("sizeDecimation", 8).asInt(), + grabberConfig.get("redSignalThreshold", 0.0).asDouble(), + grabberConfig.get("greenSignalThreshold", 0.0).asDouble(), + grabberConfig.get("blueSignalThreshold", 0.0).asDouble(), + grabberConfig.get("priority", 900).asInt()); + _v4l2Grabber->set3D(parse3DMode(grabberConfig.get("mode", "2D").asString())); + _v4l2Grabber->setCropping( + grabberConfig.get("cropLeft", 0).asInt(), + grabberConfig.get("cropRight", 0).asInt(), + grabberConfig.get("cropTop", 0).asInt(), + grabberConfig.get("cropBottom", 0).asInt()); - QObject::connect(_v4l2Grabber, SIGNAL(emitImage(int, const Image&, const int)), _protoServer, SLOT(sendImageToProtoSlaves(int, const Image&, const int)) ); + QObject::connect(_v4l2Grabber, SIGNAL(emitImage(int, const Image&, const int)), _protoServer, SLOT(sendImageToProtoSlaves(int, const Image&, const int)) ); - _v4l2Grabber->start(); - Info(_log, "V4L2 grabber created and started"); + _v4l2Grabber->start(); + Info(_log, "V4L2 grabber created and started"); + } } #else ErrorIf(_config.isMember("grabber-v4l2"), _log, "The v4l2 grabber can not be instantiated, because it has been left out from the build");