Merge remote-tracking branch 'remotes/origin/master'

Former-commit-id: 0f424826def93b35209c055244003dc21d07e9b7
This commit is contained in:
T. van der Zwan 2013-09-25 09:25:14 +02:00
commit 6792321192
4 changed files with 363 additions and 318 deletions

View File

@ -1,318 +1,333 @@
// Automatically generated configuration file for 'Hyperion' // Hyperion configuration
// Generation script: ./WriteConfig
{ {
"device" : "device" :
{ {
"name" : "MyPi", "name" : "MyPi",
"type" : "ws2801", "type" : "ws2801",
"output" : "/dev/spidev0.0", "output" : "/dev/spidev0.0",
"interval" : 20000, "interval" : 20000,
"rate" : 48000 "rate" : 48000
}, },
"color" : "color" :
{ {
"hsv" : { "hsv" : {
"saturationGain" : 1.0, "saturationGain" : 1.0,
"valueGain" : 1.0 "valueGain" : 1.0
}, },
"red" : "red" :
{ {
"threshold" : 0.0, "threshold" : 0.0,
"gamma" : 1.0, "gamma" : 1.0,
"blacklevel" : 0.0, "blacklevel" : 0.0,
"whitelevel" : 1.0 "whitelevel" : 1.0
}, },
"green" : "green" :
{ {
"threshold" : 0.0, "threshold" : 0.0,
"gamma" : 1.0, "gamma" : 1.0,
"blacklevel" : 0.0, "blacklevel" : 0.0,
"whitelevel" : 1.0 "whitelevel" : 1.0
}, },
"blue" : "blue" :
{ {
"threshold" : 0.0, "threshold" : 0.0,
"gamma" : 1.0, "gamma" : 1.0,
"blacklevel" : 0.0, "blacklevel" : 0.0,
"whitelevel" : 1.0 "whitelevel" : 1.0
} }
}, },
"leds" : "leds" :
[ [
{ {
"index" : 0, "index" : 0,
"hscan" : { "minimum" : 47.0588, "maximum" : 52.9412 }, "hscan" : { "minimum" : 47.0588, "maximum" : 52.9412 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 1, "index" : 1,
"hscan" : { "minimum" : 41.1765, "maximum" : 47.0588 }, "hscan" : { "minimum" : 41.1765, "maximum" : 47.0588 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 2, "index" : 2,
"hscan" : { "minimum" : 35.2941, "maximum" : 41.1765 }, "hscan" : { "minimum" : 35.2941, "maximum" : 41.1765 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 3, "index" : 3,
"hscan" : { "minimum" : 29.4118, "maximum" : 35.2941 }, "hscan" : { "minimum" : 29.4118, "maximum" : 35.2941 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 4, "index" : 4,
"hscan" : { "minimum" : 23.5294, "maximum" : 29.4118 }, "hscan" : { "minimum" : 23.5294, "maximum" : 29.4118 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 5, "index" : 5,
"hscan" : { "minimum" : 17.6471, "maximum" : 23.5294 }, "hscan" : { "minimum" : 17.6471, "maximum" : 23.5294 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 6, "index" : 6,
"hscan" : { "minimum" : 11.7647, "maximum" : 17.6471 }, "hscan" : { "minimum" : 11.7647, "maximum" : 17.6471 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 7, "index" : 7,
"hscan" : { "minimum" : 5.88235, "maximum" : 11.7647 }, "hscan" : { "minimum" : 5.88235, "maximum" : 11.7647 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
// TOP-LEFT Corner // TOP-LEFT Corner
{ {
"index" : 8, "index" : 8,
"hscan" : { "minimum" : 0, "maximum" : 5.88235 }, "hscan" : { "minimum" : 0, "maximum" : 5.88235 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 9, "index" : 9,
"hscan" : { "minimum" : 0, "maximum" : 10 }, "hscan" : { "minimum" : 0, "maximum" : 10 },
"vscan" : { "minimum" : 10, "maximum" : 20 } "vscan" : { "minimum" : 10, "maximum" : 20 }
}, },
{ {
"index" : 10, "index" : 10,
"hscan" : { "minimum" : 0, "maximum" : 10 }, "hscan" : { "minimum" : 0, "maximum" : 10 },
"vscan" : { "minimum" : 20, "maximum" : 30 } "vscan" : { "minimum" : 20, "maximum" : 30 }
}, },
{ {
"index" : 11, "index" : 11,
"hscan" : { "minimum" : 0, "maximum" : 10 }, "hscan" : { "minimum" : 0, "maximum" : 10 },
"vscan" : { "minimum" : 30, "maximum" : 40 } "vscan" : { "minimum" : 30, "maximum" : 40 }
}, },
{ {
"index" : 12, "index" : 12,
"hscan" : { "minimum" : 0, "maximum" : 10 }, "hscan" : { "minimum" : 0, "maximum" : 10 },
"vscan" : { "minimum" : 40, "maximum" : 50 } "vscan" : { "minimum" : 40, "maximum" : 50 }
}, },
{ {
"index" : 13, "index" : 13,
"hscan" : { "minimum" : 0, "maximum" : 10 }, "hscan" : { "minimum" : 0, "maximum" : 10 },
"vscan" : { "minimum" : 50, "maximum" : 60 } "vscan" : { "minimum" : 50, "maximum" : 60 }
}, },
{ {
"index" : 14, "index" : 14,
"hscan" : { "minimum" : 0, "maximum" : 10 }, "hscan" : { "minimum" : 0, "maximum" : 10 },
"vscan" : { "minimum" : 60, "maximum" : 70 } "vscan" : { "minimum" : 60, "maximum" : 70 }
}, },
{ {
"index" : 15, "index" : 15,
"hscan" : { "minimum" : 0, "maximum" : 10 }, "hscan" : { "minimum" : 0, "maximum" : 10 },
"vscan" : { "minimum" : 70, "maximum" : 80 } "vscan" : { "minimum" : 70, "maximum" : 80 }
}, },
{ {
"index" : 16, "index" : 16,
"hscan" : { "minimum" : 0, "maximum" : 10 }, "hscan" : { "minimum" : 0, "maximum" : 10 },
"vscan" : { "minimum" : 80, "maximum" : 90 } "vscan" : { "minimum" : 80, "maximum" : 90 }
}, },
// BOTTOM-LEFT Corner // BOTTOM-LEFT Corner
{ {
"index" : 17, "index" : 17,
"hscan" : { "minimum" : 0, "maximum" : 5.88235 }, "hscan" : { "minimum" : 0, "maximum" : 5.88235 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 18, "index" : 18,
"hscan" : { "minimum" : 5.88235, "maximum" : 11.7647 }, "hscan" : { "minimum" : 5.88235, "maximum" : 11.7647 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 19, "index" : 19,
"hscan" : { "minimum" : 11.7647, "maximum" : 17.6471 }, "hscan" : { "minimum" : 11.7647, "maximum" : 17.6471 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 20, "index" : 20,
"hscan" : { "minimum" : 17.6471, "maximum" : 23.5294 }, "hscan" : { "minimum" : 17.6471, "maximum" : 23.5294 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 21, "index" : 21,
"hscan" : { "minimum" : 23.5294, "maximum" : 29.4118 }, "hscan" : { "minimum" : 23.5294, "maximum" : 29.4118 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 22, "index" : 22,
"hscan" : { "minimum" : 29.4118, "maximum" : 35.2941 }, "hscan" : { "minimum" : 29.4118, "maximum" : 35.2941 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 23, "index" : 23,
"hscan" : { "minimum" : 35.2941, "maximum" : 41.1765 }, "hscan" : { "minimum" : 35.2941, "maximum" : 41.1765 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 24, "index" : 24,
"hscan" : { "minimum" : 41.1765, "maximum" : 47.0588 }, "hscan" : { "minimum" : 41.1765, "maximum" : 47.0588 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 25, "index" : 25,
"hscan" : { "minimum" : 47.0588, "maximum" : 52.9412 }, "hscan" : { "minimum" : 47.0588, "maximum" : 52.9412 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 26, "index" : 26,
"hscan" : { "minimum" : 52.9412, "maximum" : 58.8235 }, "hscan" : { "minimum" : 52.9412, "maximum" : 58.8235 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 27, "index" : 27,
"hscan" : { "minimum" : 58.8235, "maximum" : 64.7059 }, "hscan" : { "minimum" : 58.8235, "maximum" : 64.7059 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 28, "index" : 28,
"hscan" : { "minimum" : 64.7059, "maximum" : 70.5882 }, "hscan" : { "minimum" : 64.7059, "maximum" : 70.5882 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 29, "index" : 29,
"hscan" : { "minimum" : 70.5882, "maximum" : 76.4706 }, "hscan" : { "minimum" : 70.5882, "maximum" : 76.4706 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 30, "index" : 30,
"hscan" : { "minimum" : 76.4706, "maximum" : 82.3529 }, "hscan" : { "minimum" : 76.4706, "maximum" : 82.3529 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 31, "index" : 31,
"hscan" : { "minimum" : 82.3529, "maximum" : 88.2353 }, "hscan" : { "minimum" : 82.3529, "maximum" : 88.2353 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 32, "index" : 32,
"hscan" : { "minimum" : 88.2353, "maximum" : 94.1176 }, "hscan" : { "minimum" : 88.2353, "maximum" : 94.1176 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
// BOTTOM-RIGHT Corner // BOTTOM-RIGHT Corner
{ {
"index" : 33, "index" : 33,
"hscan" : { "minimum" : 94.1176, "maximum" : 100 }, "hscan" : { "minimum" : 94.1176, "maximum" : 100 },
"vscan" : { "minimum" : 90, "maximum" : 100 } "vscan" : { "minimum" : 90, "maximum" : 100 }
}, },
{ {
"index" : 34, "index" : 34,
"hscan" : { "minimum" : 90, "maximum" : 100 }, "hscan" : { "minimum" : 90, "maximum" : 100 },
"vscan" : { "minimum" : 80, "maximum" : 90 } "vscan" : { "minimum" : 80, "maximum" : 90 }
}, },
{ {
"index" : 35, "index" : 35,
"hscan" : { "minimum" : 90, "maximum" : 100 }, "hscan" : { "minimum" : 90, "maximum" : 100 },
"vscan" : { "minimum" : 70, "maximum" : 80 } "vscan" : { "minimum" : 70, "maximum" : 80 }
}, },
{ {
"index" : 36, "index" : 36,
"hscan" : { "minimum" : 90, "maximum" : 100 }, "hscan" : { "minimum" : 90, "maximum" : 100 },
"vscan" : { "minimum" : 60, "maximum" : 70 } "vscan" : { "minimum" : 60, "maximum" : 70 }
}, },
{ {
"index" : 37, "index" : 37,
"hscan" : { "minimum" : 90, "maximum" : 100 }, "hscan" : { "minimum" : 90, "maximum" : 100 },
"vscan" : { "minimum" : 50, "maximum" : 60 } "vscan" : { "minimum" : 50, "maximum" : 60 }
}, },
{ {
"index" : 38, "index" : 38,
"hscan" : { "minimum" : 90, "maximum" : 100 }, "hscan" : { "minimum" : 90, "maximum" : 100 },
"vscan" : { "minimum" : 40, "maximum" : 50 } "vscan" : { "minimum" : 40, "maximum" : 50 }
}, },
{ {
"index" : 39, "index" : 39,
"hscan" : { "minimum" : 90, "maximum" : 100 }, "hscan" : { "minimum" : 90, "maximum" : 100 },
"vscan" : { "minimum" : 30, "maximum" : 40 } "vscan" : { "minimum" : 30, "maximum" : 40 }
}, },
{ {
"index" : 40, "index" : 40,
"hscan" : { "minimum" : 90, "maximum" : 100 }, "hscan" : { "minimum" : 90, "maximum" : 100 },
"vscan" : { "minimum" : 20, "maximum" : 30 } "vscan" : { "minimum" : 20, "maximum" : 30 }
}, },
{ {
"index" : 41, "index" : 41,
"hscan" : { "minimum" : 90, "maximum" : 100 }, "hscan" : { "minimum" : 90, "maximum" : 100 },
"vscan" : { "minimum" : 10, "maximum" : 20 } "vscan" : { "minimum" : 10, "maximum" : 20 }
}, },
// TOP-RIGHT Corner // TOP-RIGHT Corner
{ {
"index" : 42, "index" : 42,
"hscan" : { "minimum" : 94.1176, "maximum" : 100 }, "hscan" : { "minimum" : 94.1176, "maximum" : 100 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 43, "index" : 43,
"hscan" : { "minimum" : 88.2353, "maximum" : 94.1176 }, "hscan" : { "minimum" : 88.2353, "maximum" : 94.1176 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 44, "index" : 44,
"hscan" : { "minimum" : 82.3529, "maximum" : 88.2353 }, "hscan" : { "minimum" : 82.3529, "maximum" : 88.2353 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 45, "index" : 45,
"hscan" : { "minimum" : 76.4706, "maximum" : 82.3529 }, "hscan" : { "minimum" : 76.4706, "maximum" : 82.3529 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 46, "index" : 46,
"hscan" : { "minimum" : 70.5882, "maximum" : 76.4706 }, "hscan" : { "minimum" : 70.5882, "maximum" : 76.4706 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 47, "index" : 47,
"hscan" : { "minimum" : 64.7059, "maximum" : 70.5882 }, "hscan" : { "minimum" : 64.7059, "maximum" : 70.5882 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 48, "index" : 48,
"hscan" : { "minimum" : 58.8235, "maximum" : 64.7059 }, "hscan" : { "minimum" : 58.8235, "maximum" : 64.7059 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
}, },
{ {
"index" : 49, "index" : 49,
"hscan" : { "minimum" : 52.9412, "maximum" : 58.8235 }, "hscan" : { "minimum" : 52.9412, "maximum" : 58.8235 },
"vscan" : { "minimum" : 0, "maximum" : 10 } "vscan" : { "minimum" : 0, "maximum" : 10 }
} }
], ],
"xbmcVideoChecker" : { // The XBMC video checker will connect to XBMC to check its player state and adjust the grabbing on it
"enable" : true, "xbmcVideoChecker" : {
"xbmcAddress" : "127.0.0.1", // Enable the use of the XBMC checker
"xbmcTcpPort" : 9090 "enable" : true,
},
"bootsequence" : // Address of the hoxt running XBMC
{ "xbmcAddress" : "127.0.0.1",
"type" : "rainbow",
"duration_ms" : 3000
},
"framegrabber" : // Port used by XBMC for the TCP json service (Default disabled by XBMC for non-local clients)
{ "xbmcTcpPort" : 9090,
"width" : 64,
"height" : 64,
"frequency_Hz" : 10
}
// Grab screen when XBMC is playing video
"grabVideo" : true,
// Grab screen when XBMC is playing pictures
"grabPictures" : true,
// Grab screen when XBMC is playing audio
"grabAudio" : true,
// Grab screen when XBMC is not playing anything (in menu)
"grabMenu" : true
},
"bootsequence" :
{
"type" : "rainbow",
"duration_ms" : 3000
},
"framegrabber" :
{
"width" : 64,
"height" : 64,
"frequency_Hz" : 10
}
} }

View File

@ -181,6 +181,22 @@
"xbmcTcpPort" : { "xbmcTcpPort" : {
"type" : "integer", "type" : "integer",
"required" : true "required" : true
},
"grabVideo" : {
"type" : "boolean",
"required" : true
},
"grabPictures" : {
"type" : "boolean",
"required" : true
},
"grabAudio" : {
"type" : "boolean",
"required" : true
},
"grabMenu" : {
"type" : "boolean",
"required" : true
} }
}, },
"additionalProperties" : false "additionalProperties" : false

View File

@ -7,7 +7,7 @@ XBMCVideoChecker::XBMCVideoChecker(const std::string & address, uint16_t port, u
QObject(), QObject(),
_address(QString::fromStdString(address)), _address(QString::fromStdString(address)),
_port(port), _port(port),
_request("{\"jsonrpc\":\"2.0\",\"method\":\"Player.GetActivePlayers\",\"id\":1}"), _request("{\"jsonrpc\":\"2.0\",\"method\":\"Player.GetActivePlayers\",\"id\":666}"),
_timer(), _timer(),
_socket(), _socket(),
_grabVideo(grabVideo), _grabVideo(grabVideo),
@ -54,6 +54,13 @@ void XBMCVideoChecker::receiveReply()
// expect that the reply is received as a single message. Probably oke considering the size of the expected reply // expect that the reply is received as a single message. Probably oke considering the size of the expected reply
QString reply(_socket.readAll()); QString reply(_socket.readAll());
// check if the resply is a reply to one of my requests
if (!reply.contains("\"id\":666"))
{
// probably not. Leave this mreply as is and don't act on it
return;
}
GrabbingMode newMode = GRABBINGMODE_INVALID; GrabbingMode newMode = GRABBINGMODE_INVALID;
if (reply.contains("video")) if (reply.contains("video"))
{ {
@ -62,13 +69,13 @@ void XBMCVideoChecker::receiveReply()
} }
else if (reply.contains("picture")) else if (reply.contains("picture"))
{ {
// photo viewer is playing // picture viewer is playing
newMode = _grabVideo ? GRABBINGMODE_PHOTO : GRABBINGMODE_OFF; newMode = _grabPhoto ? GRABBINGMODE_PHOTO : GRABBINGMODE_OFF;
} }
else if (reply.contains("audio")) else if (reply.contains("audio"))
{ {
// photo viewer is playing // audio is playing
newMode = _grabVideo ? GRABBINGMODE_AUDIO : GRABBINGMODE_OFF; newMode = _grabAudio ? GRABBINGMODE_AUDIO : GRABBINGMODE_OFF;
} }
else else
{ {

View File

@ -83,7 +83,14 @@ int main(int argc, char** argv)
} }
const Json::Value & videoCheckerConfig = config["xbmcVideoChecker"]; const Json::Value & videoCheckerConfig = config["xbmcVideoChecker"];
XBMCVideoChecker xbmcVideoChecker(videoCheckerConfig["xbmcAddress"].asString(), videoCheckerConfig["xbmcTcpPort"].asUInt(), 1000, true, true, true, true); XBMCVideoChecker xbmcVideoChecker(
videoCheckerConfig["xbmcAddress"].asString(),
videoCheckerConfig["xbmcTcpPort"].asUInt(),
1000,
videoCheckerConfig["grabVideo"].asBool(),
videoCheckerConfig["grabPictures"].asBool(),
videoCheckerConfig["grabAudio"].asBool(),
videoCheckerConfig["grabMenu"].asBool());
if (videoCheckerConfig["enable"].asBool()) if (videoCheckerConfig["enable"].asBool())
{ {
xbmcVideoChecker.start(); xbmcVideoChecker.start();