summaryrefslogtreecommitdiff
path: root/web/share
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2021-08-17 15:01:04 +0300
committerMaxim Devaev <[email protected]>2021-08-17 15:01:04 +0300
commit586c7d20778e1e30ea802f489a71c2d2dd0b18f6 (patch)
tree4cfa698e07142f9cadef94fc3b24d5f510be5b82 /web/share
parentb7cf7b4523c28bed43346bb593add7ff4bc993e1 (diff)
pikvm/pikvm#281: adjustable relative mouse sensitivity
Diffstat (limited to 'web/share')
-rw-r--r--web/share/css/navbar.css3
-rw-r--r--web/share/js/kvm/hid.js2
-rw-r--r--web/share/js/kvm/mouse.js17
-rw-r--r--web/share/js/tools.js2
4 files changed, 21 insertions, 3 deletions
diff --git a/web/share/css/navbar.css b/web/share/css/navbar.css
index 8aba82fc..bde319f9 100644
--- a/web/share/css/navbar.css
+++ b/web/share/css/navbar.css
@@ -137,6 +137,9 @@ ul#navbar li div.menu table.kv {
margin: 0 10px 0 10px;
font-size: 12px;
}
+ul#navbar li div.menu table.kv td {
+ text-align: left;
+}
ul#navbar li div.menu table.kv td.value {
font-weight: bold;
max-width: 310px;
diff --git a/web/share/js/kvm/hid.js b/web/share/js/kvm/hid.js
index 545a712d..bf508e0b 100644
--- a/web/share/js/kvm/hid.js
+++ b/web/share/js/kvm/hid.js
@@ -157,6 +157,7 @@ export function Hid(__getResolution) {
tools.feature.setEnabled($("hid-outputs-keyboard"), keyboard_outputs.length);
tools.feature.setEnabled($("hid-outputs-mouse"), mouse_outputs.length);
tools.feature.setEnabled($("hid-mouse-squash"), has_relative);
+ tools.feature.setEnabled($("hid-mouse-sens"), has_relative);
tools.feature.setEnabled($("hid-connect"), (state.connected !== null));
$("hid-connect-switch").checked = !!state.connected;
}
@@ -164,6 +165,7 @@ export function Hid(__getResolution) {
tools.radio.setEnabled("hid-outputs-keyboard-radio", (state && state.online && !state.busy));
tools.radio.setEnabled("hid-outputs-mouse-radio", (state && state.online && !state.busy));
tools.el.setEnabled($("hid-mouse-squash-switch"), (has_relative_squash && !state.busy));
+ tools.el.setEnabled($("hid-mouse-sens-slider"), (has_relative_squash && !state.busy));
tools.el.setEnabled($("hid-connect-switch"), (state && state.online && !state.busy));
if (state) {
diff --git a/web/share/js/kvm/mouse.js b/web/share/js/kvm/mouse.js
index cfc70bff..1c33e4c0 100644
--- a/web/share/js/kvm/mouse.js
+++ b/web/share/js/kvm/mouse.js
@@ -42,6 +42,7 @@ export function Mouse(__getResolution, __recordWsEvent) {
var __sent_pos = {x: 0, y: 0};
var __wheel_delta = {x: 0, y: 0};
var __relative_deltas = [];
+ var __relative_sens = 1.0;
var __stream_hovered = false;
@@ -61,6 +62,12 @@ export function Mouse(__getResolution, __recordWsEvent) {
$("stream-box").onwheel = __streamWheelHandler;
$("stream-box").ontouchstart = (event) => __streamTouchMoveHandler(event);
+ let sens_slider = $("hid-mouse-sens-slider");
+ tools.slider.setParams(sens_slider, 0.1, 1.9, 0.1, 1);
+ sens_slider.oninput = sens_slider.onchange = __updateRelativeSens;
+ sens_slider.value = tools.storage.get("hid.mouse.sens", 1.0);
+ __updateRelativeSens();
+
tools.storage.bindSimpleSwitch($("hid-mouse-squash-switch"), "hid.mouse.squash", true);
setInterval(__sendMove, 100);
@@ -97,6 +104,12 @@ export function Mouse(__getResolution, __recordWsEvent) {
__keypad.releaseAll();
};
+ var __updateRelativeSens = function() {
+ __relative_sens = parseFloat($("hid-mouse-sens-slider").value);
+ $("hid-mouse-sens-value").innerHTML = __relative_sens.toFixed(1);
+ tools.storage.set("hid.mouse.sens", __relative_sens);
+ };
+
var __streamHoveredHandler = function(hovered) {
if (__absolute) {
__stream_hovered = hovered;
@@ -188,8 +201,8 @@ export function Mouse(__getResolution, __recordWsEvent) {
};
} else if (__isRelativeCaptured()) {
let delta = {
- x: Math.min(Math.max(-127, event.movementX), 127),
- y: Math.min(Math.max(-127, event.movementY), 127),
+ x: Math.min(Math.max(-127, Math.floor(event.movementX * __relative_sens)), 127),
+ y: Math.min(Math.max(-127, Math.floor(event.movementY * __relative_sens)), 127),
};
if (__isRelativeSquashed()) {
__relative_deltas.push(delta);
diff --git a/web/share/js/tools.js b/web/share/js/tools.js
index 4bc5c90b..61ac3e1d 100644
--- a/web/share/js/tools.js
+++ b/web/share/js/tools.js
@@ -274,7 +274,7 @@ export var tools = new function() {
return {
"get": function(key, default_value) {
let value = window.localStorage.getItem(key);
- return (value !== null ? value : default_value);
+ return (value !== null ? value : `${default_value}`);
},
"set": (key, value) => window.localStorage.setItem(key, value),