client-side for mouse wheel

This commit is contained in:
Devaev Maxim 2018-07-13 05:52:22 +00:00
parent 2a6883064d
commit 1f02b77f66
2 changed files with 19 additions and 5 deletions

View File

@ -145,9 +145,8 @@ class Server: # pylint: disable=too-many-instance-attributes
if key and state in [True, False]: if key and state in [True, False]:
await self.__hid.send_key_event(key, state) await self.__hid.send_key_event(key, state)
continue continue
elif event.get("event_type") in ["mouse_move", "mouse_button"]: elif event.get("event_type") in ["mouse_move", "mouse_button", "mouse_wheel"]:
pass pass
# logger.info("Mouse event: %s", event) # TODO
else: else:
logger.error("Invalid websocket event: %r", event) logger.error("Invalid websocket event: %r", event)
await ws.send_str(json.dumps({"msg_type": "echo", "msg": msg.data})) await ws.send_str(json.dumps({"msg_type": "echo", "msg": msg.data}))

View File

@ -47,8 +47,8 @@ function __installHidHandlers(ws) {
el_stream_image.onmouseup = (event) => __onMouseButton(ws, event, false); el_stream_image.onmouseup = (event) => __onMouseButton(ws, event, false);
el_stream_image.oncontextmenu = (event) => event.preventDefault(); el_stream_image.oncontextmenu = (event) => event.preventDefault();
el_stream_image.onmousemove = __onMouseMove; el_stream_image.onmousemove = __onMouseMove;
runKvmdSession.mouse_timer_id = setInterval(() => __handleMouseMove(ws), 100); el_stream_image.onwheel = (event) => __onMouseWheel(ws, event);
// TODO: https://learn.javascript.ru/mousewheel runKvmdSession.mouse_move_timer = setInterval(() => __handleMouseMove(ws), 100);
} }
function __clearHidHandlers() { function __clearHidHandlers() {
@ -60,7 +60,8 @@ function __clearHidHandlers() {
el_stream_image.onmouseup = null; el_stream_image.onmouseup = null;
el_stream_image.oncontextmenu = null; el_stream_image.oncontextmenu = null;
el_stream_image.onmousemove = null; el_stream_image.onmousemove = null;
clearInterval(runKvmdSession.mouse_timer_id); el_stream_image.onwheel = null;
clearInterval(runKvmdSession.mouse_move_timer);
} }
function __onKeyEvent(ws, event, state) { function __onKeyEvent(ws, event, state) {
@ -115,6 +116,20 @@ function __handleMouseMove(ws) {
} }
__handleMouseMove.old_pos = {x: 0, y:0}; __handleMouseMove.old_pos = {x: 0, y:0};
function __onMouseWheel(ws, event) {
// https://learn.javascript.ru/mousewheel
if (event.preventDefault) {
event.preventDefault();
}
ws.send(JSON.stringify({
event_type: "mouse_wheel",
delta: {
x: event.deltaX,
y: event.deltaY,
},
}));
}
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
function clickPowerButton() { function clickPowerButton() {