summaryrefslogtreecommitdiff
path: root/web/share
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2024-03-17 10:46:26 +0200
committerMaxim Devaev <[email protected]>2024-03-17 10:46:26 +0200
commitaf68aba4b745f10a3e2aed64dc3aa66807cc94cc (patch)
tree597be39cd8869b988b88c2e24d60d6a2416a7fa7 /web/share
parent13b43355ca131e333b1a326817161ec68b67df6a (diff)
Issue #1076: Orientation options for H.264
Diffstat (limited to 'web/share')
-rw-r--r--web/share/js/kvm/stream.js18
-rw-r--r--web/share/js/kvm/stream_janus.js10
-rw-r--r--web/share/js/tools.js3
3 files changed, 27 insertions, 4 deletions
diff --git a/web/share/js/kvm/stream.js b/web/share/js/kvm/stream.js
index 9ae4565c..a5a13294 100644
--- a/web/share/js/kvm/stream.js
+++ b/web/share/js/kvm/stream.js
@@ -70,6 +70,19 @@ export function Streamer() {
tools.radio.setOnClick("stream-mode-radio", __clickModeRadio, false);
+ // Not getInt() because of radio is a string container.
+ // Also don't reset Janus at class init.
+ tools.radio.clickValue("stream-orient-radio", tools.storage.get("stream.orient", 0));
+ tools.radio.setOnClick("stream-orient-radio", function() {
+ if (__streamer.getMode() === "janus") { // Right now it's working only for H.264
+ let orient = parseInt(tools.radio.getValue("stream-orient-radio"));
+ tools.storage.setInt("stream.orient", orient);
+ if (__streamer.getOrientation() != orient) {
+ __resetStream();
+ }
+ }
+ }, false);
+
tools.slider.setParams($("stream-audio-volume-slider"), 0, 100, 1, 0, function(value) {
$("stream-video").muted = !value;
$("stream-video").volume = value / 100;
@@ -248,9 +261,12 @@ export function Streamer() {
}
__streamer.stopStream();
if (mode === "janus") {
- __streamer = new JanusStreamer(__setActive, __setInactive, __setInfo, !$("stream-video").muted);
+ __streamer = new JanusStreamer(__setActive, __setInactive, __setInfo,
+ tools.storage.getInt("stream.orient", 0), !$("stream-video").muted);
+ tools.feature.setEnabled($("stream-orient"), true);
} else { // mjpeg
__streamer = new MjpegStreamer(__setActive, __setInactive, __setInfo);
+ tools.feature.setEnabled($("stream-orient"), false);
tools.feature.setEnabled($("stream-audio"), false); // Enabling in stream_janus.js
}
if (wm.isWindowVisible($("stream-window"))) {
diff --git a/web/share/js/kvm/stream_janus.js b/web/share/js/kvm/stream_janus.js
index eff7b18b..8cc7744f 100644
--- a/web/share/js/kvm/stream_janus.js
+++ b/web/share/js/kvm/stream_janus.js
@@ -29,7 +29,7 @@ import {tools, $} from "../tools.js";
var _Janus = null;
-export function JanusStreamer(__setActive, __setInactive, __setInfo, __allow_audio) {
+export function JanusStreamer(__setActive, __setInactive, __setInfo, __orient, __allow_audio) {
var self = this;
var __stop = false;
@@ -45,6 +45,7 @@ export function JanusStreamer(__setActive, __setInactive, __setInfo, __allow_aud
var __state = null;
var __frames = 0;
+ self.getOrientation = () => __orient;
self.isAudioAllowed = () => __allow_audio;
self.getName = () => (__allow_audio ? "H.264 + Audio" : "H.264");
@@ -329,9 +330,12 @@ export function JanusStreamer(__setActive, __setInactive, __setInfo, __allow_aud
var __sendWatch = function() {
if (__handle) {
- __logInfo(`Sending WATCH(audio=${__allow_audio}) + FEATURES ...`);
+ __logInfo(`Sending WATCH(orient=${__orient}, audio=${__allow_audio}) + FEATURES ...`);
__handle.send({"message": {"request": "features"}});
- __handle.send({"message": {"request": "watch", "params": {"audio": __allow_audio}}});
+ __handle.send({"message": {"request": "watch", "params": {
+ "orientation": __orient,
+ "audio": __allow_audio,
+ }}});
}
};
diff --git a/web/share/js/tools.js b/web/share/js/tools.js
index ef21b69f..12291e48 100644
--- a/web/share/js/tools.js
+++ b/web/share/js/tools.js
@@ -392,6 +392,9 @@ export var tools = new function() {
},
"set": (key, value) => window.localStorage.setItem(key, value),
+ "getInt": (key, default_value) => parseInt(self.storage.get(key, default_value)),
+ "setInt": (key, value) => self.storage.set(key, value),
+
"getBool": (key, default_value) => !!parseInt(self.storage.get(key, (default_value ? "1" : "0"))),
"setBool": (key, value) => self.storage.set(key, (value ? "1" : "0")),