summaryrefslogtreecommitdiff
path: root/kvmd/web/js/mouse.js
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2018-08-31 17:48:36 +0300
committerDevaev Maxim <[email protected]>2018-08-31 17:48:36 +0300
commitecb866f57a983f22e67b74b0bef45a3f211a3d0f (patch)
tree1c37c80be5cce49a34bd18fcfc5a10e39794daeb /kvmd/web/js/mouse.js
parent1bf3506d2e72eba65d8c7d187151a51cf0abcf6d (diff)
testing mouse buttons for touch interface
Diffstat (limited to 'kvmd/web/js/mouse.js')
-rw-r--r--kvmd/web/js/mouse.js70
1 files changed, 34 insertions, 36 deletions
diff --git a/kvmd/web/js/mouse.js b/kvmd/web/js/mouse.js
index 9ee92053..30897233 100644
--- a/kvmd/web/js/mouse.js
+++ b/kvmd/web/js/mouse.js
@@ -21,8 +21,14 @@ function Mouse() {
$("stream-box").onmousemove = __moveHandler;
$("stream-box").onwheel = __wheelHandler;
- $("stream-box").ontouchstart = (event) => __touchHandler(event, true);
- $("stream-box").ontouchend = (event) => __touchHandler(event, false);
+ $("stream-box").ontouchstart = (event) => __touchMoveHandler(event);
+ Array.prototype.forEach.call(document.querySelectorAll("[data-mouse-button]"), function(el_button) {
+ var button = el_button.getAttribute("data-mouse-button");
+ el_button.onmousedown = () => __sendButton(button, true);
+ el_button.onmouseup = () => __sendButton(button, false);
+ el_button.ontouchstart = () => __sendButton(button, true);
+ el_button.ontouchend = () => __sendButton(button, false);
+ });
setInterval(__sendMove, 100);
};
@@ -58,8 +64,19 @@ function Mouse() {
}
};
- var __touchHandler = function(event, state) {
- if (state) {
+ var __buttonHandler = function(event, state) {
+ // https://www.w3schools.com/jsref/event_button.asp
+ event.preventDefault();
+ switch (event.button) {
+ case 0: __sendButton("left", state); break;
+ case 2: __sendButton("right", state); break;
+ }
+ };
+
+ var __touchMoveHandler = function(event) {
+ event.stopPropagation();
+ event.preventDefault();
+ if (event.touches[0].target && event.touches[0].target.getBoundingClientRect) {
var rect = event.touches[0].target.getBoundingClientRect();
__current_pos = {
x: Math.round(event.touches[0].clientX - rect.left),
@@ -67,38 +84,6 @@ function Mouse() {
};
__sendMove();
}
- var button = "left"; // TODO
- tools.debug("Mouse button", (state ? "pressed:" : "released:"), button);
- if (__ws) {
- __ws.send(JSON.stringify({
- event_type: "mouse_button",
- button: button,
- state: state,
- }));
- }
- event.stopPropagation();
- event.preventDefault();
- };
-
- var __buttonHandler = function(event, state) {
- // https://www.w3schools.com/jsref/event_button.asp
- var button = null;
- switch (event.button) {
- case 0: button = "left"; break;
- case 2: button = "right"; break;
- }
- if (button) {
- event.preventDefault();
- tools.debug("Mouse button", (state ? "pressed:" : "released:"), button);
- __sendMove();
- if (__ws) {
- __ws.send(JSON.stringify({
- event_type: "mouse_button",
- button: button,
- state: state,
- }));
- }
- }
};
var __moveHandler = function(event) {
@@ -109,6 +94,19 @@ function Mouse() {
};
};
+
+ var __sendButton = function(button, state) {
+ tools.debug("Mouse button", (state ? "pressed:" : "released:"), button);
+ __sendMove();
+ if (__ws) {
+ __ws.send(JSON.stringify({
+ event_type: "mouse_button",
+ button: button,
+ state: state,
+ }));
+ }
+ };
+
var __sendMove = function() {
var pos = __current_pos;
if (pos.x !== __sent_pos.x || pos.y !== __sent_pos.y) {