diff options
author | Devaev Maxim <[email protected]> | 2018-08-31 17:48:36 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2018-08-31 17:48:36 +0300 |
commit | ecb866f57a983f22e67b74b0bef45a3f211a3d0f (patch) | |
tree | 1c37c80be5cce49a34bd18fcfc5a10e39794daeb /kvmd/web/js/mouse.js | |
parent | 1bf3506d2e72eba65d8c7d187151a51cf0abcf6d (diff) |
testing mouse buttons for touch interface
Diffstat (limited to 'kvmd/web/js/mouse.js')
-rw-r--r-- | kvmd/web/js/mouse.js | 70 |
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) { |