2020-11-14 16:22:21 +01:00
|
|
|
$(document).ready(function () {
|
add Hue EntertainmentAPI + Forwarder & other Fixes (#592)
* whitespaces + typo fixes
* JS / LGTM fixes
* SSDP Handler crash fix
* MessageForwarder handlePriorityChanges Slave fixes
* use aboutToQuit Signal
* complete rewriten Hue Entertainment API structure
combined Philips Hue and Entertainment API
with new MbedTLS based SSL UDP Provider
* add required cross-compile submodules
* logical rebuild fn: initLeds, setLights + new logs
-more detailed checks and error handling inside iniLeds and setLights
- logical script procedure before ProviderUdpSSL init
- first steps for multiple ProviderUdpSSL usage
- better fallback support to old RestAPI, if entertainment api is not supported
- just 4 u LordGrey: new log fn for cosmetic config outputs ;)
* add OSX CompileHowTo - undo from CrossCompileHowTo
* whitespace fixes
* lightID toString fix
* fix unsigned int E-API + debug output
* bugfixes, reworked black signal detection, wizard:
- change device config field light-ids from int to string -> real unsigned int fix
- add signal detection brightness minimum threshold value
0.0 for 0% brightness - 1.0 for 100% brightness to count for blacklight signal detection
reason: input may not 100% black, like mine - i have a deep dark gray input signal
-> my threshold value is set to 0.005 for 0.5% minimum brightness = 1 (from max 255) to count as black
- wizard optimations, with fallback without entertainment support (beta state)
- whitespace fixes
* cleanup + minor fixes
* change fixed Hue UPD SSL config to _devConfig paras
* Hotfix SSL Connection, new light models, wizard:
- Fix UPD SSL Connection failed Problems
- add new supported gamut C light models: LCG002, LCA001, LCA002, LCA003
- wizard: extend fallback support to classic mode + hints
* whitespace, typo fix
* uncheck useEntertainmentAPI, if noAPISupport detected + hint
* coredump fix -> add _blackLightsTimer nullptr init
* code cleanup / remove old debugs + whitespacefixes
* add gamut C LCP001, LCP002
* SSL UDP config made more flexible + remove qDebug
-> switch to hyerion.ng _log
-> replace logCommand with verbose
-> code cleanups etc...
* extended mbedtls debugging infos
* add adjustable ssl timeout settings
* error handling
* streamdebugger bugfixes
* UPDSSL psk / psk_identity bugfixes! + hue wizard fn typo fix +
- verbose option available without dependencies
- whitespace fixes
* Philips Hue Assistant now recognizes non-original bridges better...
+ Added note if no clientkey is set when using the entertainment API
+ User creation (+ clientkey) for non-original bridges can now also be used
+ Minor changes and bug fixes
* CMAKE mbedTLS detection
* minor bug fixes + code cleanups
* FindMbedTLS.cmake remove Path-Hints + wizard.js: ajax timeout handling
Test - content_grabber.js: run relevant code only, if V4L2_AVAIL is true:
conf_grabber don't displays other devices, if V4L2 is not available
* compile mbedtls via cmake as static lib
* remove libmbedtls-dev from compileHowto / scripts
* Fix Windows build
* Fix windows build (part 2)
* removed unnecessary osx x11 include directory path
* QTimer Shutdown bugfix
* cmake win32 fix + minor bugfixes
* cmake debug msg used mbedtls libs
* Bugfix: noSignalDetection wasn't switchedOn again
if no signal was previously detected
* Some code fixes based on alerts from lgtm.com
Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com>
2020-05-22 19:40:50 +02:00
|
|
|
performTranslation();
|
2021-05-08 19:29:28 +02:00
|
|
|
|
2021-02-14 12:36:21 +01:00
|
|
|
var conf_editor_video = null;
|
|
|
|
var conf_editor_screen = null;
|
add Hue EntertainmentAPI + Forwarder & other Fixes (#592)
* whitespaces + typo fixes
* JS / LGTM fixes
* SSDP Handler crash fix
* MessageForwarder handlePriorityChanges Slave fixes
* use aboutToQuit Signal
* complete rewriten Hue Entertainment API structure
combined Philips Hue and Entertainment API
with new MbedTLS based SSL UDP Provider
* add required cross-compile submodules
* logical rebuild fn: initLeds, setLights + new logs
-more detailed checks and error handling inside iniLeds and setLights
- logical script procedure before ProviderUdpSSL init
- first steps for multiple ProviderUdpSSL usage
- better fallback support to old RestAPI, if entertainment api is not supported
- just 4 u LordGrey: new log fn for cosmetic config outputs ;)
* add OSX CompileHowTo - undo from CrossCompileHowTo
* whitespace fixes
* lightID toString fix
* fix unsigned int E-API + debug output
* bugfixes, reworked black signal detection, wizard:
- change device config field light-ids from int to string -> real unsigned int fix
- add signal detection brightness minimum threshold value
0.0 for 0% brightness - 1.0 for 100% brightness to count for blacklight signal detection
reason: input may not 100% black, like mine - i have a deep dark gray input signal
-> my threshold value is set to 0.005 for 0.5% minimum brightness = 1 (from max 255) to count as black
- wizard optimations, with fallback without entertainment support (beta state)
- whitespace fixes
* cleanup + minor fixes
* change fixed Hue UPD SSL config to _devConfig paras
* Hotfix SSL Connection, new light models, wizard:
- Fix UPD SSL Connection failed Problems
- add new supported gamut C light models: LCG002, LCA001, LCA002, LCA003
- wizard: extend fallback support to classic mode + hints
* whitespace, typo fix
* uncheck useEntertainmentAPI, if noAPISupport detected + hint
* coredump fix -> add _blackLightsTimer nullptr init
* code cleanup / remove old debugs + whitespacefixes
* add gamut C LCP001, LCP002
* SSL UDP config made more flexible + remove qDebug
-> switch to hyerion.ng _log
-> replace logCommand with verbose
-> code cleanups etc...
* extended mbedtls debugging infos
* add adjustable ssl timeout settings
* error handling
* streamdebugger bugfixes
* UPDSSL psk / psk_identity bugfixes! + hue wizard fn typo fix +
- verbose option available without dependencies
- whitespace fixes
* Philips Hue Assistant now recognizes non-original bridges better...
+ Added note if no clientkey is set when using the entertainment API
+ User creation (+ clientkey) for non-original bridges can now also be used
+ Minor changes and bug fixes
* CMAKE mbedTLS detection
* minor bug fixes + code cleanups
* FindMbedTLS.cmake remove Path-Hints + wizard.js: ajax timeout handling
Test - content_grabber.js: run relevant code only, if V4L2_AVAIL is true:
conf_grabber don't displays other devices, if V4L2 is not available
* compile mbedtls via cmake as static lib
* remove libmbedtls-dev from compileHowto / scripts
* Fix Windows build
* Fix windows build (part 2)
* removed unnecessary osx x11 include directory path
* QTimer Shutdown bugfix
* cmake win32 fix + minor bugfixes
* cmake debug msg used mbedtls libs
* Bugfix: noSignalDetection wasn't switchedOn again
if no signal was previously detected
* Some code fixes based on alerts from lgtm.com
Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com>
2020-05-22 19:40:50 +02:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
// Screen-Grabber
|
|
|
|
$('#conf_cont').append(createRow('conf_cont_screen'));
|
|
|
|
$('#conf_cont_screen').append(createOptPanel('fa-camera', $.i18n("edt_conf_fg_heading_title"), 'editor_container_screengrabber', 'btn_submit_screengrabber', 'panel-system', 'screengrabberPanelId'));
|
2020-11-14 16:22:21 +01:00
|
|
|
if (window.showOptHelp) {
|
2021-05-05 13:31:31 +02:00
|
|
|
$('#conf_cont_screen').append(createHelpTable(window.schema.framegrabber.properties, $.i18n("edt_conf_fg_heading_title"), "screengrabberHelpPanelId"));
|
add Hue EntertainmentAPI + Forwarder & other Fixes (#592)
* whitespaces + typo fixes
* JS / LGTM fixes
* SSDP Handler crash fix
* MessageForwarder handlePriorityChanges Slave fixes
* use aboutToQuit Signal
* complete rewriten Hue Entertainment API structure
combined Philips Hue and Entertainment API
with new MbedTLS based SSL UDP Provider
* add required cross-compile submodules
* logical rebuild fn: initLeds, setLights + new logs
-more detailed checks and error handling inside iniLeds and setLights
- logical script procedure before ProviderUdpSSL init
- first steps for multiple ProviderUdpSSL usage
- better fallback support to old RestAPI, if entertainment api is not supported
- just 4 u LordGrey: new log fn for cosmetic config outputs ;)
* add OSX CompileHowTo - undo from CrossCompileHowTo
* whitespace fixes
* lightID toString fix
* fix unsigned int E-API + debug output
* bugfixes, reworked black signal detection, wizard:
- change device config field light-ids from int to string -> real unsigned int fix
- add signal detection brightness minimum threshold value
0.0 for 0% brightness - 1.0 for 100% brightness to count for blacklight signal detection
reason: input may not 100% black, like mine - i have a deep dark gray input signal
-> my threshold value is set to 0.005 for 0.5% minimum brightness = 1 (from max 255) to count as black
- wizard optimations, with fallback without entertainment support (beta state)
- whitespace fixes
* cleanup + minor fixes
* change fixed Hue UPD SSL config to _devConfig paras
* Hotfix SSL Connection, new light models, wizard:
- Fix UPD SSL Connection failed Problems
- add new supported gamut C light models: LCG002, LCA001, LCA002, LCA003
- wizard: extend fallback support to classic mode + hints
* whitespace, typo fix
* uncheck useEntertainmentAPI, if noAPISupport detected + hint
* coredump fix -> add _blackLightsTimer nullptr init
* code cleanup / remove old debugs + whitespacefixes
* add gamut C LCP001, LCP002
* SSL UDP config made more flexible + remove qDebug
-> switch to hyerion.ng _log
-> replace logCommand with verbose
-> code cleanups etc...
* extended mbedtls debugging infos
* add adjustable ssl timeout settings
* error handling
* streamdebugger bugfixes
* UPDSSL psk / psk_identity bugfixes! + hue wizard fn typo fix +
- verbose option available without dependencies
- whitespace fixes
* Philips Hue Assistant now recognizes non-original bridges better...
+ Added note if no clientkey is set when using the entertainment API
+ User creation (+ clientkey) for non-original bridges can now also be used
+ Minor changes and bug fixes
* CMAKE mbedTLS detection
* minor bug fixes + code cleanups
* FindMbedTLS.cmake remove Path-Hints + wizard.js: ajax timeout handling
Test - content_grabber.js: run relevant code only, if V4L2_AVAIL is true:
conf_grabber don't displays other devices, if V4L2 is not available
* compile mbedtls via cmake as static lib
* remove libmbedtls-dev from compileHowto / scripts
* Fix Windows build
* Fix windows build (part 2)
* removed unnecessary osx x11 include directory path
* QTimer Shutdown bugfix
* cmake win32 fix + minor bugfixes
* cmake debug msg used mbedtls libs
* Bugfix: noSignalDetection wasn't switchedOn again
if no signal was previously detected
* Some code fixes based on alerts from lgtm.com
Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com>
2020-05-22 19:40:50 +02:00
|
|
|
}
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-05-12 22:40:22 +02:00
|
|
|
// Video-Grabber
|
2021-05-11 18:08:34 +02:00
|
|
|
$('#conf_cont').append(createRow('conf_cont_video'));
|
|
|
|
$('#conf_cont_video').append(createOptPanel('fa-camera', $.i18n("edt_conf_v4l2_heading_title"), 'editor_container_videograbber', 'btn_submit_videograbber', 'panel-system', 'videograbberPanelId'));
|
|
|
|
if (window.showOptHelp) {
|
|
|
|
$('#conf_cont_video').append(createHelpTable(window.schema.grabberV4L2.properties, $.i18n("edt_conf_v4l2_heading_title"), "videograbberHelpPanelId"));
|
2020-12-29 15:54:32 +01:00
|
|
|
}
|
2020-11-14 16:22:21 +01:00
|
|
|
|
2021-02-17 23:26:39 +01:00
|
|
|
JSONEditor.defaults.custom_validators.push(function (schema, value, path) {
|
|
|
|
var errors = [];
|
|
|
|
|
|
|
|
if (path === "root.grabberV4L2" || path === "root.framegrabber") {
|
|
|
|
var editor;
|
|
|
|
switch (path) {
|
|
|
|
case "root.framegrabber":
|
|
|
|
editor = conf_editor_screen;
|
|
|
|
break;
|
|
|
|
case "root.grabberV4L2":
|
|
|
|
editor = conf_editor_video;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (value.cropLeft || value.cropRight) {
|
|
|
|
var width = editor.getEditor(path + ".width").getValue();
|
|
|
|
if (value.cropLeft + value.cropRight > width) {
|
|
|
|
errors.push({
|
|
|
|
path: path,
|
|
|
|
property: 'maximum',
|
|
|
|
message: $.i18n('edt_conf_v4l2_cropWidthValidation_error', width)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (value.cropTop || value.cropBottom) {
|
|
|
|
var height = editor.getEditor(path + ".height").getValue();
|
|
|
|
if (value.cropTop + value.cropBottom > height) {
|
|
|
|
errors.push({
|
|
|
|
path: path,
|
|
|
|
property: 'maximum',
|
|
|
|
message: $.i18n('edt_conf_v4l2_cropHeightValidation_error', height)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return errors;
|
|
|
|
});
|
|
|
|
|
|
|
|
function updateCropForWidth(editor, path) {
|
2021-05-03 21:32:12 +02:00
|
|
|
var width = editor.getEditor(path + ".width").getValue();
|
2021-02-17 23:26:39 +01:00
|
|
|
updateJsonEditorRange(editor.getEditor(path), 'cropLeft', 0, width);
|
|
|
|
updateJsonEditorRange(editor.getEditor(path), 'cropRight', 0, width);
|
|
|
|
}
|
|
|
|
|
|
|
|
function updateCropForHeight(editor, path) {
|
|
|
|
var height = editor.getEditor(path + ".height").getValue();
|
|
|
|
updateJsonEditorRange(editor.getEditor(path), 'cropTop', 0, height);
|
|
|
|
updateJsonEditorRange(editor.getEditor(path), 'cropBottom', 0, height);
|
|
|
|
}
|
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
// Screen-Grabber
|
2021-02-14 12:36:21 +01:00
|
|
|
conf_editor_screen = createJsonEditor('editor_container_screengrabber', {
|
2020-12-29 15:54:32 +01:00
|
|
|
framegrabber: window.schema.framegrabber
|
|
|
|
}, true, true);
|
|
|
|
|
2021-02-14 12:36:21 +01:00
|
|
|
conf_editor_screen.on('ready', function () {
|
2021-05-11 18:08:34 +02:00
|
|
|
// Trigger conf_editor_screen.watch - 'root.framegrabber.enable'
|
|
|
|
var screenEnable = window.serverConfig.framegrabber.enable;
|
|
|
|
conf_editor_screen.getEditor("root.framegrabber.enable").setValue(screenEnable);
|
add Hue EntertainmentAPI + Forwarder & other Fixes (#592)
* whitespaces + typo fixes
* JS / LGTM fixes
* SSDP Handler crash fix
* MessageForwarder handlePriorityChanges Slave fixes
* use aboutToQuit Signal
* complete rewriten Hue Entertainment API structure
combined Philips Hue and Entertainment API
with new MbedTLS based SSL UDP Provider
* add required cross-compile submodules
* logical rebuild fn: initLeds, setLights + new logs
-more detailed checks and error handling inside iniLeds and setLights
- logical script procedure before ProviderUdpSSL init
- first steps for multiple ProviderUdpSSL usage
- better fallback support to old RestAPI, if entertainment api is not supported
- just 4 u LordGrey: new log fn for cosmetic config outputs ;)
* add OSX CompileHowTo - undo from CrossCompileHowTo
* whitespace fixes
* lightID toString fix
* fix unsigned int E-API + debug output
* bugfixes, reworked black signal detection, wizard:
- change device config field light-ids from int to string -> real unsigned int fix
- add signal detection brightness minimum threshold value
0.0 for 0% brightness - 1.0 for 100% brightness to count for blacklight signal detection
reason: input may not 100% black, like mine - i have a deep dark gray input signal
-> my threshold value is set to 0.005 for 0.5% minimum brightness = 1 (from max 255) to count as black
- wizard optimations, with fallback without entertainment support (beta state)
- whitespace fixes
* cleanup + minor fixes
* change fixed Hue UPD SSL config to _devConfig paras
* Hotfix SSL Connection, new light models, wizard:
- Fix UPD SSL Connection failed Problems
- add new supported gamut C light models: LCG002, LCA001, LCA002, LCA003
- wizard: extend fallback support to classic mode + hints
* whitespace, typo fix
* uncheck useEntertainmentAPI, if noAPISupport detected + hint
* coredump fix -> add _blackLightsTimer nullptr init
* code cleanup / remove old debugs + whitespacefixes
* add gamut C LCP001, LCP002
* SSL UDP config made more flexible + remove qDebug
-> switch to hyerion.ng _log
-> replace logCommand with verbose
-> code cleanups etc...
* extended mbedtls debugging infos
* add adjustable ssl timeout settings
* error handling
* streamdebugger bugfixes
* UPDSSL psk / psk_identity bugfixes! + hue wizard fn typo fix +
- verbose option available without dependencies
- whitespace fixes
* Philips Hue Assistant now recognizes non-original bridges better...
+ Added note if no clientkey is set when using the entertainment API
+ User creation (+ clientkey) for non-original bridges can now also be used
+ Minor changes and bug fixes
* CMAKE mbedTLS detection
* minor bug fixes + code cleanups
* FindMbedTLS.cmake remove Path-Hints + wizard.js: ajax timeout handling
Test - content_grabber.js: run relevant code only, if V4L2_AVAIL is true:
conf_grabber don't displays other devices, if V4L2 is not available
* compile mbedtls via cmake as static lib
* remove libmbedtls-dev from compileHowto / scripts
* Fix Windows build
* Fix windows build (part 2)
* removed unnecessary osx x11 include directory path
* QTimer Shutdown bugfix
* cmake win32 fix + minor bugfixes
* cmake debug msg used mbedtls libs
* Bugfix: noSignalDetection wasn't switchedOn again
if no signal was previously detected
* Some code fixes based on alerts from lgtm.com
Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com>
2020-05-22 19:40:50 +02:00
|
|
|
});
|
2018-12-27 23:11:32 +01:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
conf_editor_screen.on('change', function () {
|
2021-05-11 18:08:34 +02:00
|
|
|
|
2021-05-03 21:32:12 +02:00
|
|
|
if (!conf_editor_screen.validate().length) {
|
|
|
|
var deviceSelected = conf_editor_screen.getEditor("root.framegrabber.available_devices").getValue();
|
|
|
|
switch (deviceSelected) {
|
|
|
|
case "SELECT":
|
2021-05-12 22:40:22 +02:00
|
|
|
showInputOptionsForKey(conf_editor_screen, "framegrabber", ["enable", "available_devices"], false);
|
2021-05-03 21:32:12 +02:00
|
|
|
break;
|
2021-05-12 22:40:22 +02:00
|
|
|
case "NONE":
|
|
|
|
showInputOptionsForKey(conf_editor_screen, "framegrabber", ["enable", "available_devices"], false);
|
2021-05-03 21:32:12 +02:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
window.readOnlyMode ? $('#btn_submit_screengrabber').attr('disabled', true) : $('#btn_submit_screengrabber').attr('disabled', false);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$('#btn_submit_screengrabber').attr('disabled', true);
|
|
|
|
}
|
2021-04-04 12:43:29 +02:00
|
|
|
});
|
2016-09-10 23:30:05 +02:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_screen.watch('root.framegrabber.enable', () => {
|
|
|
|
|
|
|
|
var screenEnable = conf_editor_screen.getEditor("root.framegrabber.enable").getValue();
|
|
|
|
if (screenEnable) {
|
|
|
|
showInputOptionsForKey(conf_editor_screen, "framegrabber", "enable", true);
|
|
|
|
if (window.showOptHelp) {
|
|
|
|
$('#screengrabberHelpPanelId').show();
|
|
|
|
}
|
|
|
|
discoverInputSources("screen");
|
|
|
|
}
|
|
|
|
else {
|
2021-05-12 22:40:22 +02:00
|
|
|
$('#btn_submit_screengrabber').attr('disabled', false);
|
2021-05-11 18:08:34 +02:00
|
|
|
showInputOptionsForKey(conf_editor_screen, "framegrabber", "enable", false);
|
|
|
|
$('#screengrabberHelpPanelId').hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
conf_editor_screen.watch('root.framegrabber.available_devices', () => {
|
2021-05-03 21:32:12 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
var deviceSelected = conf_editor_screen.getEditor("root.framegrabber.available_devices").getValue();
|
2021-05-03 21:32:12 +02:00
|
|
|
if (deviceSelected === "SELECT" || deviceSelected === "NONE" || deviceSelected === "") {
|
2021-04-04 12:43:29 +02:00
|
|
|
$('#btn_submit_screengrabber').attr('disabled', true);
|
2021-05-12 22:40:22 +02:00
|
|
|
showInputOptionsForKey(conf_editor_screen, "framegrabber", ["enable", "available_devices"], false);
|
2021-04-04 12:43:29 +02:00
|
|
|
}
|
|
|
|
else {
|
2021-05-12 22:40:22 +02:00
|
|
|
showInputOptionsForKey(conf_editor_screen, "framegrabber", ["enable", "available_devices"], true);
|
2021-04-04 12:43:29 +02:00
|
|
|
var addSchemaElements = {};
|
|
|
|
var enumVals = [];
|
|
|
|
var enumTitelVals = [];
|
|
|
|
var enumDefaultVal = "";
|
2018-12-27 23:11:32 +01:00
|
|
|
|
2021-05-03 21:32:12 +02:00
|
|
|
var deviceProperties = getPropertiesOfDevice("screen", deviceSelected);
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
//Update hidden input element
|
|
|
|
conf_editor_screen.getEditor("root.framegrabber.device").setValue(deviceProperties.device);
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
var video_inputs = deviceProperties.video_inputs;
|
|
|
|
if (video_inputs.length <= 1) {
|
|
|
|
addSchemaElements.access = "expert";
|
|
|
|
}
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
for (const video_input of video_inputs) {
|
|
|
|
enumVals.push(video_input.inputIdx);
|
|
|
|
enumTitelVals.push(video_input.name);
|
2020-05-02 15:47:15 +02:00
|
|
|
}
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
if (enumVals.length > 0) {
|
|
|
|
if (deviceSelected === configuredDevice) {
|
|
|
|
var configuredVideoInput = window.serverConfig.framegrabber.input;
|
|
|
|
if ($.inArray(configuredVideoInput, enumVals) != -1) {
|
2021-05-09 21:43:22 +02:00
|
|
|
enumDefaultVal = configuredVideoInput.toString();
|
2021-04-04 12:43:29 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
updateJsonEditorSelection(conf_editor_screen.getEditor('root.framegrabber'),
|
|
|
|
'device_inputs', addSchemaElements, enumVals, enumTitelVals, enumDefaultVal, false);
|
|
|
|
}
|
2020-06-17 20:55:57 +02:00
|
|
|
|
2021-05-05 13:41:22 +02:00
|
|
|
if (conf_editor_screen.validate().length && !window.readOnlyMode) {
|
2021-04-04 12:43:29 +02:00
|
|
|
$('#btn_submit_screengrabber').attr('disabled', false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
conf_editor_screen.watch('root.framegrabber.device_inputs', () => {
|
|
|
|
var deviceSelected = conf_editor_screen.getEditor("root.framegrabber.available_devices").getValue();
|
|
|
|
var videoInputSelected = conf_editor_screen.getEditor("root.framegrabber.device_inputs").getValue();
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
//Update hidden input element
|
|
|
|
conf_editor_screen.getEditor("root.framegrabber.input").setValue(parseInt(videoInputSelected));
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
var addSchemaElements = {};
|
2020-12-29 15:54:32 +01:00
|
|
|
var enumVals = [];
|
|
|
|
var enumTitelVals = [];
|
|
|
|
var enumDefaultVal = "";
|
|
|
|
|
2021-05-03 21:32:12 +02:00
|
|
|
var deviceProperties = getPropertiesOfDevice("screen", deviceSelected);
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
var formats = deviceProperties.video_inputs[videoInputSelected].formats;
|
|
|
|
var formatIdx = 0;
|
2020-12-29 15:54:32 +01:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
var resolutions = formats[formatIdx].resolutions;
|
|
|
|
if (resolutions.length <= 1) {
|
|
|
|
addSchemaElements.access = "advanced";
|
|
|
|
} else {
|
|
|
|
resolutions.sort(compareTwoValues('width', 'height', 'asc'));
|
|
|
|
}
|
2020-12-29 15:54:32 +01:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
for (var i = 0; i < resolutions.length; i++) {
|
|
|
|
enumVals.push(i);
|
|
|
|
var resolutionText = resolutions[i].width + "x" + resolutions[i].height;
|
|
|
|
enumTitelVals.push(resolutionText);
|
|
|
|
}
|
2020-06-17 20:55:57 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
if (enumVals.length > 0) {
|
|
|
|
if (deviceSelected === configuredDevice) {
|
|
|
|
var configuredResolutionText = window.serverConfig.framegrabber.width + "x" + window.serverConfig.framegrabber.height;
|
|
|
|
var idx = $.inArray(configuredResolutionText, enumTitelVals)
|
|
|
|
if (idx != -1) {
|
2021-05-09 21:43:22 +02:00
|
|
|
enumDefaultVal = idx.toString();
|
2021-04-04 12:43:29 +02:00
|
|
|
}
|
2020-12-29 15:54:32 +01:00
|
|
|
}
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
updateJsonEditorSelection(conf_editor_screen.getEditor('root.framegrabber'),
|
|
|
|
'resolutions', addSchemaElements, enumVals, enumTitelVals, enumDefaultVal, false);
|
|
|
|
}
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-05-05 13:41:22 +02:00
|
|
|
if (conf_editor_screen.validate().length && !window.readOnlyMode) {
|
|
|
|
$('#btn_submit_screengrabber').attr('disabled', false);
|
2020-12-29 15:54:32 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
conf_editor_screen.watch('root.framegrabber.resolutions', () => {
|
|
|
|
var deviceSelected = conf_editor_screen.getEditor("root.framegrabber.available_devices").getValue();
|
|
|
|
var videoInputSelected = conf_editor_screen.getEditor("root.framegrabber.device_inputs").getValue();
|
|
|
|
var resolutionSelected = conf_editor_screen.getEditor("root.framegrabber.resolutions").getValue();
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
var addSchemaElements = {};
|
|
|
|
var enumVals = [];
|
|
|
|
var enumDefaultVal = "";
|
2018-12-27 23:11:32 +01:00
|
|
|
|
2021-05-03 21:32:12 +02:00
|
|
|
var deviceProperties = getPropertiesOfDevice("screen", deviceSelected);
|
2020-04-17 16:59:20 +02:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
var formats = deviceProperties.video_inputs[videoInputSelected].formats;
|
|
|
|
var formatIdx = 0;
|
|
|
|
|
|
|
|
//Update hidden resolution related elements
|
|
|
|
var width = parseInt(formats[formatIdx].resolutions[resolutionSelected].width);
|
|
|
|
conf_editor_screen.getEditor("root.framegrabber.width").setValue(width);
|
|
|
|
|
|
|
|
var height = parseInt(formats[formatIdx].resolutions[resolutionSelected].height);
|
|
|
|
conf_editor_screen.getEditor("root.framegrabber.height").setValue(height);
|
|
|
|
|
|
|
|
//Update crop rage depending on selected resolution
|
2021-02-17 23:26:39 +01:00
|
|
|
updateCropForWidth(conf_editor_screen, "root.framegrabber");
|
|
|
|
updateCropForHeight(conf_editor_screen, "root.framegrabber");
|
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
var fps = formats[formatIdx].resolutions[resolutionSelected].fps;
|
|
|
|
if (!fps) {
|
|
|
|
enumVals.push("NONE");
|
|
|
|
addSchemaElements.options = { "hidden": true };
|
|
|
|
} else {
|
|
|
|
fps.sort((a, b) => a - b);
|
|
|
|
for (var i = 0; i < fps.length; i++) {
|
|
|
|
enumVals.push(fps[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (enumVals.length <= 1) {
|
|
|
|
addSchemaElements.access = "expert";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (enumVals.length > 0) {
|
|
|
|
if (deviceSelected === configuredDevice) {
|
|
|
|
var configuredFps = window.serverConfig.framegrabber.fps;
|
|
|
|
if ($.inArray(configuredFps, enumVals) != -1) {
|
2021-05-09 21:43:22 +02:00
|
|
|
enumDefaultVal = configuredFps.toString();
|
2021-04-04 12:43:29 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
updateJsonEditorSelection(conf_editor_screen.getEditor('root.framegrabber'),
|
|
|
|
'framerates', addSchemaElements, enumVals, [], enumDefaultVal, false);
|
|
|
|
}
|
|
|
|
|
2021-05-05 13:41:22 +02:00
|
|
|
if (conf_editor_screen.validate().length && !window.readOnlyMode) {
|
2021-04-04 12:43:29 +02:00
|
|
|
$('#btn_submit_screengrabber').attr('disabled', false);
|
|
|
|
}
|
2021-02-17 23:26:39 +01:00
|
|
|
});
|
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
conf_editor_screen.watch('root.framegrabber.framerates', () => {
|
|
|
|
//Update hidden fps element
|
|
|
|
var fps = 0;
|
|
|
|
var framerates = conf_editor_screen.getEditor("root.framegrabber.framerates").getValue();
|
|
|
|
if (framerates !== "NONE") {
|
|
|
|
fps = parseInt(framerates);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Show Frameskipping only when more than 2 fps
|
|
|
|
if (fps > 2 && storedAccess === "expert") {
|
2021-05-03 21:32:12 +02:00
|
|
|
showInputOptions(["fpsSoftwareDecimation"], true);
|
2021-04-04 12:43:29 +02:00
|
|
|
}
|
|
|
|
else {
|
2021-05-03 21:32:12 +02:00
|
|
|
showInputOptions(["fpsSoftwareDecimation"], false);
|
2021-04-04 12:43:29 +02:00
|
|
|
}
|
|
|
|
conf_editor_screen.getEditor("root.framegrabber.fps").setValue(fps);
|
2021-02-17 23:26:39 +01:00
|
|
|
});
|
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
|
2021-02-17 23:26:39 +01:00
|
|
|
conf_editor_screen.watch('root.framegrabber.width', () => {
|
|
|
|
updateCropForWidth(conf_editor_screen, "root.framegrabber");
|
|
|
|
});
|
|
|
|
|
|
|
|
conf_editor_screen.watch('root.framegrabber.height', () => {
|
|
|
|
updateCropForHeight(conf_editor_screen, "root.framegrabber");
|
2020-12-29 15:54:32 +01:00
|
|
|
});
|
|
|
|
|
2021-02-14 12:36:21 +01:00
|
|
|
$('#btn_submit_screengrabber').off().on('click', function () {
|
2021-04-04 12:43:29 +02:00
|
|
|
var saveOptions = conf_editor_screen.getValue();
|
|
|
|
|
|
|
|
var instCaptOptions = window.serverConfig.instCapture;
|
|
|
|
instCaptOptions.systemEnable = true;
|
|
|
|
saveOptions.instCapture = instCaptOptions;
|
|
|
|
|
|
|
|
requestWriteConfig(saveOptions);
|
2021-02-14 11:39:03 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
// External Input Sources (Video-Grabbers)
|
|
|
|
|
|
|
|
var configuredDevice = "";
|
|
|
|
var discoveredInputSources = {};
|
|
|
|
var deviceProperties = {};
|
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_video = createJsonEditor('editor_container_videograbber', {
|
|
|
|
grabberV4L2: window.schema.grabberV4L2
|
|
|
|
}, true, true);
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_video.on('ready', function () {
|
|
|
|
// Trigger conf_editor_video.watch - 'root.grabberV4L2.enable'
|
|
|
|
var videoEnable = window.serverConfig.grabberV4L2.enable;
|
|
|
|
conf_editor_video.getEditor("root.grabberV4L2.enable").setValue(videoEnable);
|
|
|
|
});
|
2021-05-03 21:32:12 +02:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_video.on('change', function () {
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
if (!conf_editor_video.validate().length) {
|
2021-02-14 12:36:21 +01:00
|
|
|
var deviceSelected = conf_editor_video.getEditor("root.grabberV4L2.available_devices").getValue();
|
2021-05-11 18:08:34 +02:00
|
|
|
switch (deviceSelected) {
|
|
|
|
case "SELECT":
|
2021-05-12 22:40:22 +02:00
|
|
|
showInputOptionsForKey(conf_editor_video, "grabberV4L2", ["enable", "available_devices"], false);
|
2021-05-11 18:08:34 +02:00
|
|
|
break;
|
|
|
|
case "NONE":
|
2021-05-12 22:40:22 +02:00
|
|
|
showInputOptionsForKey(conf_editor_video, "grabberV4L2", ["enable", "available_devices"], false);
|
2021-05-11 18:08:34 +02:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
window.readOnlyMode ? $('#btn_submit_videograbber').attr('disabled', true) : $('#btn_submit_videograbber').attr('disabled', false);
|
|
|
|
break;
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
2021-05-11 18:08:34 +02:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$('#btn_submit_videograbber').attr('disabled', true);
|
|
|
|
}
|
|
|
|
});
|
2021-04-04 12:43:29 +02:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_video.watch('root.grabberV4L2.enable', () => {
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var videoEnable = conf_editor_video.getEditor("root.grabberV4L2.enable").getValue();
|
|
|
|
if (videoEnable) {
|
|
|
|
showInputOptionsForKey(conf_editor_video, "grabberV4L2", "enable", true);
|
|
|
|
if (window.showOptHelp) {
|
|
|
|
$('#videograbberHelpPanelId').show();
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
2021-05-11 18:08:34 +02:00
|
|
|
discoverInputSources("video");
|
|
|
|
}
|
|
|
|
else {
|
2021-05-12 22:40:22 +02:00
|
|
|
$('#btn_submit_videograbber').attr('disabled', false);
|
2021-05-11 18:08:34 +02:00
|
|
|
showInputOptionsForKey(conf_editor_video, "grabberV4L2", "enable", false);
|
|
|
|
$('#videograbberHelpPanelId').hide();
|
|
|
|
}
|
|
|
|
});
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_video.watch('root.grabberV4L2.available_devices', () => {
|
|
|
|
var deviceSelected = conf_editor_video.getEditor("root.grabberV4L2.available_devices").getValue();
|
|
|
|
if (deviceSelected === "SELECT" || deviceSelected === "NONE" || deviceSelected === "") {
|
|
|
|
$('#btn_submit_videograbber').attr('disabled', true);
|
2021-05-12 22:40:22 +02:00
|
|
|
showInputOptionsForKey(conf_editor_video, "grabberV4L2", ["enable","available_devices"], false);
|
2021-05-11 18:08:34 +02:00
|
|
|
}
|
|
|
|
else {
|
2021-05-12 22:40:22 +02:00
|
|
|
showInputOptionsForKey(conf_editor_video, "grabberV4L2", ["enable", "available_devices"], true);
|
2021-02-14 11:39:03 +01:00
|
|
|
var addSchemaElements = {};
|
|
|
|
var enumVals = [];
|
|
|
|
var enumTitelVals = [];
|
|
|
|
var enumDefaultVal = "";
|
|
|
|
|
2021-05-03 21:32:12 +02:00
|
|
|
var deviceProperties = getPropertiesOfDevice("video", deviceSelected);
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
//Update hidden input element
|
|
|
|
conf_editor_video.getEditor("root.grabberV4L2.device").setValue(deviceProperties.device);
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var video_inputs = deviceProperties.video_inputs;
|
|
|
|
if (video_inputs.length <= 1) {
|
|
|
|
addSchemaElements.access = "expert";
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
for (const video_input of video_inputs) {
|
|
|
|
enumVals.push(video_input.inputIdx);
|
|
|
|
enumTitelVals.push(video_input.name);
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (enumVals.length > 0) {
|
|
|
|
if (deviceSelected === configuredDevice) {
|
2021-05-11 18:08:34 +02:00
|
|
|
var configuredVideoInput = window.serverConfig.grabberV4L2.input;
|
|
|
|
if ($.inArray(configuredVideoInput, enumVals) != -1) {
|
|
|
|
enumDefaultVal = configuredVideoInput.toString();
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-14 12:36:21 +01:00
|
|
|
updateJsonEditorSelection(conf_editor_video.getEditor('root.grabberV4L2'),
|
2021-05-11 18:08:34 +02:00
|
|
|
'device_inputs', addSchemaElements, enumVals, enumTitelVals, enumDefaultVal, false, false);
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
|
2021-05-05 13:41:22 +02:00
|
|
|
if (conf_editor_video.validate().length && !window.readOnlyMode) {
|
2021-02-14 12:36:21 +01:00
|
|
|
$('#btn_submit_videograbber').attr('disabled', false);
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
2021-05-11 18:08:34 +02:00
|
|
|
}
|
|
|
|
});
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_video.watch('root.grabberV4L2.device_inputs', () => {
|
|
|
|
var deviceSelected = conf_editor_video.getEditor("root.grabberV4L2.available_devices").getValue();
|
|
|
|
var videoInputSelected = conf_editor_video.getEditor("root.grabberV4L2.device_inputs").getValue();
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var addSchemaElements = {};
|
|
|
|
var enumVals = [];
|
|
|
|
var enumTitelVals = [];
|
|
|
|
var enumDefaultVal = "";
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var deviceProperties = getPropertiesOfDevice("video", deviceSelected);
|
|
|
|
var formats = deviceProperties.video_inputs[videoInputSelected].formats;
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
addSchemaElements.access = "advanced";
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
for (var i = 0; i < formats.length; i++) {
|
|
|
|
if (formats[i].format) {
|
|
|
|
enumVals.push(formats[i].format);
|
|
|
|
enumTitelVals.push(formats[i].format.toUpperCase());
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
2021-05-11 18:08:34 +02:00
|
|
|
else {
|
|
|
|
enumVals.push("NONE");
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
2021-05-11 18:08:34 +02:00
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
if (enumVals.length > 0) {
|
|
|
|
if (deviceSelected === configuredDevice) {
|
|
|
|
var configuredEncoding = window.serverConfig.grabberV4L2.encoding;
|
|
|
|
if ($.inArray(configuredEncoding, enumVals) != -1) {
|
|
|
|
enumDefaultVal = configuredEncoding;
|
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
2021-05-11 18:08:34 +02:00
|
|
|
updateJsonEditorSelection(conf_editor_video.getEditor('root.grabberV4L2'),
|
|
|
|
'encoding', addSchemaElements, enumVals, enumTitelVals, enumDefaultVal, false);
|
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var enumVals = [];
|
|
|
|
var enumDefaultVal = "";
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var standards = deviceProperties.video_inputs[videoInputSelected].standards;
|
|
|
|
if (!standards) {
|
|
|
|
enumVals.push("NONE");
|
|
|
|
addSchemaElements.options = { "hidden": true };
|
|
|
|
} else {
|
|
|
|
enumVals = standards;
|
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
if (enumVals.length > 0) {
|
|
|
|
if (deviceSelected === configuredDevice) {
|
|
|
|
var configuredStandard = window.serverConfig.grabberV4L2.standard;
|
|
|
|
if ($.inArray(configuredStandard, enumVals) != -1) {
|
|
|
|
enumDefaultVal = configuredStandard;
|
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
updateJsonEditorSelection(conf_editor_video.getEditor('root.grabberV4L2'),
|
|
|
|
'standard', addSchemaElements, enumVals, [], enumDefaultVal, false);
|
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
if (conf_editor_video.validate().length && !window.readOnlyMode) {
|
|
|
|
$('#btn_submit_videograbber').attr('disabled', false);
|
|
|
|
}
|
|
|
|
});
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_video.watch('root.grabberV4L2.encoding', () => {
|
|
|
|
var deviceSelected = conf_editor_video.getEditor("root.grabberV4L2.available_devices").getValue();
|
|
|
|
var videoInputSelected = conf_editor_video.getEditor("root.grabberV4L2.device_inputs").getValue();
|
|
|
|
var formatSelected = conf_editor_video.getEditor("root.grabberV4L2.encoding").getValue();
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
//Update hidden input element
|
|
|
|
conf_editor_video.getEditor("root.grabberV4L2.input").setValue(parseInt(videoInputSelected));
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var addSchemaElements = {};
|
|
|
|
var enumVals = [];
|
|
|
|
var enumTitelVals = [];
|
|
|
|
var enumDefaultVal = "";
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var deviceProperties = getPropertiesOfDevice("video", deviceSelected);
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var formats = deviceProperties.video_inputs[videoInputSelected].formats;
|
|
|
|
var formatIdx = 0;
|
|
|
|
if (formatSelected !== "NONE") {
|
|
|
|
formatIdx = formats.findIndex(x => x.format === formatSelected);
|
|
|
|
}
|
2021-02-17 23:26:39 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var resolutions = formats[formatIdx].resolutions;
|
|
|
|
if (resolutions.length <= 1) {
|
|
|
|
addSchemaElements.access = "advanced";
|
|
|
|
} else {
|
|
|
|
resolutions.sort(compareTwoValues('width', 'height', 'asc'));
|
|
|
|
}
|
|
|
|
|
|
|
|
for (var i = 0; i < resolutions.length; i++) {
|
|
|
|
enumVals.push(i);
|
|
|
|
var resolutionText = resolutions[i].width + "x" + resolutions[i].height;
|
|
|
|
enumTitelVals.push(resolutionText);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (enumVals.length > 0) {
|
|
|
|
if (deviceSelected === configuredDevice) {
|
|
|
|
var configuredResolutionText = window.serverConfig.grabberV4L2.width + "x" + window.serverConfig.grabberV4L2.height;
|
|
|
|
var idx = $.inArray(configuredResolutionText, enumTitelVals)
|
|
|
|
if (idx != -1) {
|
|
|
|
enumDefaultVal = idx.toString();
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
updateJsonEditorSelection(conf_editor_video.getEditor('root.grabberV4L2'),
|
|
|
|
'resolutions', addSchemaElements, enumVals, enumTitelVals, enumDefaultVal, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (conf_editor_video.validate().length && !window.readOnlyMode) {
|
|
|
|
$('#btn_submit_videograbber').attr('disabled', false);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
conf_editor_video.watch('root.grabberV4L2.resolutions', () => {
|
|
|
|
var deviceSelected = conf_editor_video.getEditor("root.grabberV4L2.available_devices").getValue();
|
|
|
|
var videoInputSelected = conf_editor_video.getEditor("root.grabberV4L2.device_inputs").getValue();
|
|
|
|
var formatSelected = conf_editor_video.getEditor("root.grabberV4L2.encoding").getValue();
|
|
|
|
var resolutionSelected = conf_editor_video.getEditor("root.grabberV4L2.resolutions").getValue();
|
|
|
|
|
|
|
|
var addSchemaElements = {};
|
|
|
|
var enumVals = [];
|
|
|
|
var enumDefaultVal = "";
|
|
|
|
|
|
|
|
var deviceProperties = getPropertiesOfDevice("video", deviceSelected);
|
|
|
|
|
|
|
|
var formats = deviceProperties.video_inputs[videoInputSelected].formats;
|
|
|
|
var formatIdx = 0;
|
|
|
|
if (formatSelected !== "NONE") {
|
|
|
|
formatIdx = formats.findIndex(x => x.format === formatSelected);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Update hidden resolution related elements
|
|
|
|
var width = parseInt(formats[formatIdx].resolutions[resolutionSelected].width);
|
|
|
|
conf_editor_video.getEditor("root.grabberV4L2.width").setValue(width);
|
|
|
|
|
|
|
|
var height = parseInt(formats[formatIdx].resolutions[resolutionSelected].height);
|
|
|
|
conf_editor_video.getEditor("root.grabberV4L2.height").setValue(height);
|
|
|
|
|
|
|
|
//Update crop rage depending on selected resolution
|
|
|
|
updateCropForWidth(conf_editor_video, "root.grabberV4L2");
|
|
|
|
updateCropForHeight(conf_editor_video, "root.grabberV4L2");
|
|
|
|
|
|
|
|
var fps = formats[formatIdx].resolutions[resolutionSelected].fps;
|
|
|
|
if (!fps) {
|
|
|
|
enumVals.push("NONE");
|
|
|
|
addSchemaElements.options = { "hidden": true };
|
|
|
|
} else {
|
|
|
|
fps.sort((a, b) => a - b);
|
|
|
|
for (var i = 0; i < fps.length; i++) {
|
|
|
|
enumVals.push(fps[i]);
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
2021-05-11 18:08:34 +02:00
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
if (enumVals.length <= 1) {
|
|
|
|
addSchemaElements.access = "expert";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (enumVals.length > 0) {
|
|
|
|
if (deviceSelected === configuredDevice) {
|
|
|
|
var configuredFps = window.serverConfig.grabberV4L2.fps;
|
|
|
|
if ($.inArray(configuredFps, enumVals) != -1) {
|
|
|
|
enumDefaultVal = configuredFps.toString();
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
}
|
2021-05-11 18:08:34 +02:00
|
|
|
updateJsonEditorSelection(conf_editor_video.getEditor('root.grabberV4L2'),
|
|
|
|
'framerates', addSchemaElements, enumVals, [], enumDefaultVal, false);
|
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
if (conf_editor_video.validate().length && !window.readOnlyMode) {
|
|
|
|
$('#btn_submit_videograbber').attr('disabled', false);
|
|
|
|
}
|
|
|
|
});
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
conf_editor_video.watch('root.grabberV4L2.framerates', () => {
|
|
|
|
//Update hidden fps element
|
|
|
|
var fps = 0;
|
|
|
|
var framerates = conf_editor_video.getEditor("root.grabberV4L2.framerates").getValue();
|
|
|
|
if (framerates !== "NONE") {
|
|
|
|
fps = parseInt(framerates);
|
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
//Show Frameskipping only when more than 2 fps
|
|
|
|
if (fps > 2 && storedAccess === "expert") {
|
|
|
|
showInputOptions(["fpsSoftwareDecimation"], true);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
showInputOptions(["fpsSoftwareDecimation"], false);
|
|
|
|
}
|
|
|
|
conf_editor_video.getEditor("root.grabberV4L2.fps").setValue(fps);
|
|
|
|
});
|
2021-04-04 12:43:29 +02:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
$('#btn_submit_videograbber').off().on('click', function () {
|
|
|
|
var saveOptions = conf_editor_video.getValue();
|
2021-04-04 12:43:29 +02:00
|
|
|
|
2021-05-11 18:08:34 +02:00
|
|
|
var instCaptOptions = window.serverConfig.instCapture;
|
|
|
|
instCaptOptions.v4lEnable = true;
|
|
|
|
saveOptions.instCapture = instCaptOptions;
|
|
|
|
|
|
|
|
requestWriteConfig(saveOptions);
|
|
|
|
});
|
2021-02-14 11:39:03 +01:00
|
|
|
|
|
|
|
//////////////////////////////////////////////////
|
|
|
|
|
|
|
|
//create introduction
|
|
|
|
if (window.showOptHelp) {
|
2021-02-14 12:36:21 +01:00
|
|
|
createHint("intro", $.i18n('conf_grabber_fg_intro'), "editor_container_screengrabber");
|
2021-05-11 18:08:34 +02:00
|
|
|
createHint("intro", $.i18n('conf_grabber_v4l_intro'), "editor_container_videograbber");
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
|
add Hue EntertainmentAPI + Forwarder & other Fixes (#592)
* whitespaces + typo fixes
* JS / LGTM fixes
* SSDP Handler crash fix
* MessageForwarder handlePriorityChanges Slave fixes
* use aboutToQuit Signal
* complete rewriten Hue Entertainment API structure
combined Philips Hue and Entertainment API
with new MbedTLS based SSL UDP Provider
* add required cross-compile submodules
* logical rebuild fn: initLeds, setLights + new logs
-more detailed checks and error handling inside iniLeds and setLights
- logical script procedure before ProviderUdpSSL init
- first steps for multiple ProviderUdpSSL usage
- better fallback support to old RestAPI, if entertainment api is not supported
- just 4 u LordGrey: new log fn for cosmetic config outputs ;)
* add OSX CompileHowTo - undo from CrossCompileHowTo
* whitespace fixes
* lightID toString fix
* fix unsigned int E-API + debug output
* bugfixes, reworked black signal detection, wizard:
- change device config field light-ids from int to string -> real unsigned int fix
- add signal detection brightness minimum threshold value
0.0 for 0% brightness - 1.0 for 100% brightness to count for blacklight signal detection
reason: input may not 100% black, like mine - i have a deep dark gray input signal
-> my threshold value is set to 0.005 for 0.5% minimum brightness = 1 (from max 255) to count as black
- wizard optimations, with fallback without entertainment support (beta state)
- whitespace fixes
* cleanup + minor fixes
* change fixed Hue UPD SSL config to _devConfig paras
* Hotfix SSL Connection, new light models, wizard:
- Fix UPD SSL Connection failed Problems
- add new supported gamut C light models: LCG002, LCA001, LCA002, LCA003
- wizard: extend fallback support to classic mode + hints
* whitespace, typo fix
* uncheck useEntertainmentAPI, if noAPISupport detected + hint
* coredump fix -> add _blackLightsTimer nullptr init
* code cleanup / remove old debugs + whitespacefixes
* add gamut C LCP001, LCP002
* SSL UDP config made more flexible + remove qDebug
-> switch to hyerion.ng _log
-> replace logCommand with verbose
-> code cleanups etc...
* extended mbedtls debugging infos
* add adjustable ssl timeout settings
* error handling
* streamdebugger bugfixes
* UPDSSL psk / psk_identity bugfixes! + hue wizard fn typo fix +
- verbose option available without dependencies
- whitespace fixes
* Philips Hue Assistant now recognizes non-original bridges better...
+ Added note if no clientkey is set when using the entertainment API
+ User creation (+ clientkey) for non-original bridges can now also be used
+ Minor changes and bug fixes
* CMAKE mbedTLS detection
* minor bug fixes + code cleanups
* FindMbedTLS.cmake remove Path-Hints + wizard.js: ajax timeout handling
Test - content_grabber.js: run relevant code only, if V4L2_AVAIL is true:
conf_grabber don't displays other devices, if V4L2 is not available
* compile mbedtls via cmake as static lib
* remove libmbedtls-dev from compileHowto / scripts
* Fix Windows build
* Fix windows build (part 2)
* removed unnecessary osx x11 include directory path
* QTimer Shutdown bugfix
* cmake win32 fix + minor bugfixes
* cmake debug msg used mbedtls libs
* Bugfix: noSignalDetection wasn't switchedOn again
if no signal was previously detected
* Some code fixes based on alerts from lgtm.com
Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com>
2020-05-22 19:40:50 +02:00
|
|
|
removeOverlay();
|
2020-12-29 15:54:32 +01:00
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
// build dynamic screen input enum
|
|
|
|
var updateScreenSourcesList = function (type, discoveryInfo) {
|
2021-02-14 11:39:03 +01:00
|
|
|
var enumVals = [];
|
|
|
|
var enumTitelVals = [];
|
|
|
|
var enumDefaultVal = "";
|
2021-05-12 22:40:22 +02:00
|
|
|
var addSelect = false;
|
2021-02-14 11:39:03 +01:00
|
|
|
|
|
|
|
if (jQuery.isEmptyObject(discoveryInfo)) {
|
|
|
|
enumVals.push("NONE");
|
|
|
|
enumTitelVals.push($.i18n('edt_conf_grabber_discovered_none'));
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
for (const device of discoveryInfo) {
|
|
|
|
enumVals.push(device.device_name);
|
|
|
|
}
|
2021-04-04 12:43:29 +02:00
|
|
|
conf_editor_screen.getEditor('root.framegrabber').enable();
|
|
|
|
configuredDevice = window.serverConfig.framegrabber.available_devices;
|
2021-05-12 22:40:22 +02:00
|
|
|
|
2021-02-14 11:39:03 +01:00
|
|
|
if ($.inArray(configuredDevice, enumVals) != -1) {
|
|
|
|
enumDefaultVal = configuredDevice;
|
|
|
|
}
|
2021-05-12 22:40:22 +02:00
|
|
|
else {
|
|
|
|
addSelect = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (enumVals.length > 0) {
|
2021-04-04 12:43:29 +02:00
|
|
|
updateJsonEditorSelection(conf_editor_screen.getEditor('root.framegrabber'),
|
2021-05-12 22:40:22 +02:00
|
|
|
'available_devices', {}, enumVals, enumTitelVals, enumDefaultVal, addSelect, false);
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-04 12:43:29 +02:00
|
|
|
// build dynamic video input enum
|
|
|
|
var updateVideoSourcesList = function (type, discoveryInfo) {
|
|
|
|
var enumVals = [];
|
|
|
|
var enumTitelVals = [];
|
|
|
|
var enumDefaultVal = "";
|
|
|
|
var addSelect = false;
|
|
|
|
|
|
|
|
if (jQuery.isEmptyObject(discoveryInfo)) {
|
|
|
|
enumVals.push("NONE");
|
|
|
|
enumTitelVals.push($.i18n('edt_conf_grabber_discovered_none'));
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
for (const device of discoveryInfo) {
|
|
|
|
enumVals.push(device.device_name);
|
|
|
|
}
|
|
|
|
conf_editor_video.getEditor('root.grabberV4L2').enable();
|
|
|
|
configuredDevice = window.serverConfig.grabberV4L2.available_devices;
|
|
|
|
|
|
|
|
if ($.inArray(configuredDevice, enumVals) != -1) {
|
|
|
|
enumDefaultVal = configuredDevice;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
addSelect = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-03 21:32:12 +02:00
|
|
|
if (enumVals.length > 0) {
|
|
|
|
updateJsonEditorSelection(conf_editor_video.getEditor('root.grabberV4L2'),
|
|
|
|
'available_devices', {}, enumVals, enumTitelVals, enumDefaultVal, addSelect, false);
|
|
|
|
}
|
2021-04-04 12:43:29 +02:00
|
|
|
}
|
|
|
|
|
2021-02-14 11:39:03 +01:00
|
|
|
async function discoverInputSources(type, params) {
|
|
|
|
const result = await requestInputSourcesDiscovery(type, params);
|
|
|
|
|
|
|
|
var discoveryResult;
|
|
|
|
if (result && !result.error) {
|
|
|
|
discoveryResult = result.info;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
discoveryResult = {
|
|
|
|
"video_sources": []
|
|
|
|
}
|
|
|
|
}
|
2021-04-04 12:43:29 +02:00
|
|
|
|
|
|
|
switch (type) {
|
|
|
|
case "screen":
|
2021-05-03 21:32:12 +02:00
|
|
|
discoveredInputSources.screen = discoveryResult.video_sources;
|
|
|
|
updateScreenSourcesList(type, discoveredInputSources.screen);
|
2021-04-04 12:43:29 +02:00
|
|
|
break;
|
|
|
|
case "video":
|
2021-05-03 21:32:12 +02:00
|
|
|
discoveredInputSources.video = discoveryResult.video_sources;
|
|
|
|
updateVideoSourcesList(type, discoveredInputSources.video);
|
2021-04-04 12:43:29 +02:00
|
|
|
break;
|
|
|
|
}
|
2021-02-14 11:39:03 +01:00
|
|
|
}
|
|
|
|
|
2021-05-03 21:32:12 +02:00
|
|
|
function getPropertiesOfDevice(type, deviceName) {
|
2021-02-14 11:39:03 +01:00
|
|
|
deviceProperties = {};
|
2021-05-03 21:32:12 +02:00
|
|
|
for (const deviceRecord of discoveredInputSources[type]) {
|
2021-02-14 11:39:03 +01:00
|
|
|
if (deviceRecord.device_name === deviceName) {
|
|
|
|
deviceProperties = deviceRecord;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return deviceProperties;
|
|
|
|
}
|
2021-02-14 12:36:21 +01:00
|
|
|
|
2021-02-14 11:39:03 +01:00
|
|
|
});
|
2021-05-12 22:40:22 +02:00
|
|
|
|