diff options
author | Devaev Maxim <[email protected]> | 2021-05-06 22:36:33 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2021-05-06 22:36:33 +0300 |
commit | 384b444c0269bf5e7bd0a9b53e764ff67d2c0006 (patch) | |
tree | adbe0e62ab0bbd05916e95cba1f3e53a35003c36 | |
parent | 3aa92a87d4df60d7a0fcc09bf3091e2110a48458 (diff) |
stream refactoring, passing janus state
-rw-r--r-- | web/share/js/kvm/session.js | 2 | ||||
-rw-r--r-- | web/share/js/kvm/stream.js | 117 |
2 files changed, 63 insertions, 56 deletions
diff --git a/web/share/js/kvm/session.js b/web/share/js/kvm/session.js index 9a8b33d3..de1df249 100644 --- a/web/share/js/kvm/session.js +++ b/web/share/js/kvm/session.js @@ -125,6 +125,8 @@ export function Session() { tools.featureSetEnabled($("webterm"), has_webterm); $("webterm-window").show_hook = show_hook; $("webterm-window").close_hook = close_hook; + + __streamer.setJanusEnabled(state.janus && (state.janus.enabled || state.janus.started)); }; var __formatTemp = function(temp) { diff --git a/web/share/js/kvm/stream.js b/web/share/js/kvm/stream.js index 9c714414..9b7aaae1 100644 --- a/web/share/js/kvm/stream.js +++ b/web/share/js/kvm/stream.js @@ -40,11 +40,13 @@ function _MjpegStreamer(set_active_callback, set_inactive_callback, set_info_cal var __timer = null; var __timer_retries = 0; + var __janus_enabled = null; + /************************************************************************/ self.ensureStream = function(state) { - if (state && state.streamer) { - __state = state.streamer; + if (state) { + __state = state; __findId(); if (__id.length > 0 && __id in __state.stream.clients_stat) { __setActive(); @@ -60,7 +62,10 @@ function _MjpegStreamer(set_active_callback, set_inactive_callback, set_info_cal self.stopStream = function() { self.ensureStream(null); - $("stream-image").src = "/share/png/blank-stream.png"; + let blank = "/share/png/blank-stream.png"; + if (!String.prototype.endsWith.call($("stream-image").src, blank)) { + $("stream-image").src = blank; + } }; var __setActive = function() { @@ -145,13 +150,12 @@ export function Streamer() { /************************************************************************/ + var __janus_enabled = null; var __mjpeg = null; - var __online = false; + var __state = null; var __resolution = {width: 640, height: 480}; - var __state_for_invisible = null; - var __init__ = function() { __mjpeg = new _MjpegStreamer(__setActive, __setInactive, __setInfo); @@ -168,75 +172,76 @@ export function Streamer() { tools.setOnClick($("stream-screenshot-button"), __clickScreenshotButton); tools.setOnClick($("stream-reset-button"), __clickResetButton); - $("stream-window").show_hook = function() { - if (__state_for_invisible !== null) { - self.setState(__state_for_invisible); - } - }; + $("stream-window").show_hook = () => __applyState(__state); + $("stream-window").close_hook = () => __applyState(null); }; /************************************************************************/ + self.setJanusEnabled = function(enabled) { + __janus_enabled = (!!window.RTCPeerConnection && enabled); + tools.info("Stream: Janus WebRTC Gateway state:", __janus_enabled); + self.setState(__state); + }; + self.setState = function(state) { - if (!wm.isWindowVisible($("stream-window"))) { - if (__state_for_invisible === null) { - __mjpeg.stopStream(); - } - __state_for_invisible = state; - state = null; - } else { - __state_for_invisible = null; + __state = state; + if (__janus_enabled !== null) { + __applyState(wm.isWindowVisible($("stream-window")) ? __state : null); } + }; + var __applyState = function(state) { if (state) { tools.featureSetEnabled($("stream-quality"), state.features.quality && (state.streamer === null || state.streamer.encoder.quality > 0)); tools.featureSetEnabled($("stream-resolution"), state.features.resolution); - } - - __online = (state && state.streamer && state.streamer.source.online); - if (state && state.streamer) { - if (!$("stream-quality-slider").activated) { - wm.setElementEnabled($("stream-quality-slider"), true); - if ($("stream-quality-slider").value !== state.streamer.encoder.quality) { - $("stream-quality-slider").value = state.streamer.encoder.quality; - __updateQualityValue(state.streamer.encoder.quality); + if (state.streamer) { + if (!$("stream-quality-slider").activated) { + wm.setElementEnabled($("stream-quality-slider"), true); + if ($("stream-quality-slider").value !== state.streamer.encoder.quality) { + $("stream-quality-slider").value = state.streamer.encoder.quality; + __updateQualityValue(state.streamer.encoder.quality); + } } - } - if (!$("stream-desired-fps-slider").activated) { - $("stream-desired-fps-slider").min = state.limits.desired_fps.min; - $("stream-desired-fps-slider").max = state.limits.desired_fps.max; - wm.setElementEnabled($("stream-desired-fps-slider"), true); - if ($("stream-desired-fps-slider").value !== state.streamer.source.desired_fps) { - $("stream-desired-fps-slider").value = state.streamer.source.desired_fps; - __updateDesiredFpsValue(state.streamer.source.desired_fps); + if (!$("stream-desired-fps-slider").activated) { + $("stream-desired-fps-slider").min = state.limits.desired_fps.min; + $("stream-desired-fps-slider").max = state.limits.desired_fps.max; + wm.setElementEnabled($("stream-desired-fps-slider"), true); + if ($("stream-desired-fps-slider").value !== state.streamer.source.desired_fps) { + $("stream-desired-fps-slider").value = state.streamer.source.desired_fps; + __updateDesiredFpsValue(state.streamer.source.desired_fps); + } } - } - let resolution_str = __makeStringResolution(state.streamer.source.resolution); - if (__makeStringResolution(__resolution) !== resolution_str) { - __resolution = state.streamer.source.resolution; - } + let resolution_str = __makeStringResolution(state.streamer.source.resolution); + if (__makeStringResolution(__resolution) !== resolution_str) { + __resolution = state.streamer.source.resolution; + } - if (state.features.resolution) { - if ($("stream-resolution-selector").resolutions !== state.limits.available_resolutions) { - let resolutions_html = ""; - for (let variant of state.limits.available_resolutions) { - resolutions_html += `<option value="${variant}">${variant}</option>`; - } - if (!state.limits.available_resolutions.includes(resolution_str)) { - resolutions_html += `<option value="${resolution_str}">${resolution_str}</option>`; + if (state.features.resolution) { + if ($("stream-resolution-selector").resolutions !== state.limits.available_resolutions) { + let resolutions_html = ""; + for (let variant of state.limits.available_resolutions) { + resolutions_html += `<option value="${variant}">${variant}</option>`; + } + if (!state.limits.available_resolutions.includes(resolution_str)) { + resolutions_html += `<option value="${resolution_str}">${resolution_str}</option>`; + } + $("stream-resolution-selector").innerHTML = resolutions_html; + $("stream-resolution-selector").resolutions = state.limits.available_resolutions; } - $("stream-resolution-selector").innerHTML = resolutions_html; - $("stream-resolution-selector").resolutions = state.limits.available_resolutions; + document.querySelector(`#stream-resolution-selector [value="${resolution_str}"]`).selected = true; + wm.setElementEnabled($("stream-resolution-selector"), true); } - document.querySelector(`#stream-resolution-selector [value="${resolution_str}"]`).selected = true; - wm.setElementEnabled($("stream-resolution-selector"), true); } - } - __mjpeg.ensureStream(state); + __mjpeg.ensureStream(state.streamer); + + } else { + __mjpeg.stopStream(); + } }; var __setActive = function() { @@ -264,7 +269,7 @@ export function Streamer() { let el_info = $("stream-info"); if (is_active) { let title = "Stream – "; - if (!__online) { + if (!online) { title += "no signal / "; } title += __makeStringResolution(__resolution); |