We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
There was an error while loading. Please reload this page.
1 parent 5273199 commit df88986Copy full SHA for df88986
kvmd/apps/vnc/rfb/__init__.py
@@ -590,8 +590,8 @@ async def __handle_pointer_event(self) -> None:
590
move = (self._width, self._height, to_x, to_y)
591
if self.__mouse_move != move:
592
await self._on_mouse_move_event(
593
- tools.remap(to_x, 0, self._width, *MouseRange.RANGE),
594
- tools.remap(to_y, 0, self._height, *MouseRange.RANGE),
+ tools.remap(to_x, 0, self._width - 1, *MouseRange.RANGE),
+ tools.remap(to_y, 0, self._height - 1, *MouseRange.RANGE),
595
)
596
self.__mouse_move = move
597
kvmd/tools.py
@@ -33,7 +33,8 @@
33
34
# =====
35
def remap(value: int, in_min: int, in_max: int, out_min: int, out_max: int) -> int:
36
- return int((value - in_min) * (out_max - out_min) // (in_max - in_min) + out_min)
+ result = int((value - in_min) * (out_max - out_min) // ((in_max - in_min) or 1) + out_min)
37
+ return min(max(result, out_min), out_max)
38
39
40
web/share/js/kvm/mouse.js
@@ -380,8 +380,8 @@ export function Mouse(__getGeometry, __recordWsEvent) {
380
if (pos !== null && (pos.x !== __sent_pos.x || pos.y !== __sent_pos.y)) {
381
let geo = __getGeometry();
382
let to = {
383
- "x": tools.remap(pos.x, geo.x, geo.width, -32768, 32767),
384
- "y": tools.remap(pos.y, geo.y, geo.height, -32768, 32767),
+ "x": tools.remap(pos.x - geo.x, 0, geo.width - 1, -32768, 32767),
+ "y": tools.remap(pos.y - geo.y, 0, geo.height - 1, -32768, 32767),
385
};
386
tools.debug("Mouse: moved:", to);
387
__sendEvent("mouse_move", {"to": to});
web/share/js/kvm/ocr.js
@@ -137,10 +137,10 @@ export function Ocr(__getGeometry) {
137
let rel_bottom = Math.max(__start_pos.y, __end_pos.y) - rect.top + offset;
138
139
__sel = {
140
- "left": tools.remap(rel_left, geo.x, geo.width, 0, geo.real_width),
141
- "right": tools.remap(rel_right, geo.x, geo.width, 0, geo.real_width),
142
- "top": tools.remap(rel_top, geo.y, geo.height, 0, geo.real_height),
143
- "bottom": tools.remap(rel_bottom, geo.y, geo.height, 0, geo.real_height),
+ "left": tools.remap(rel_left - geo.x, 0, geo.width, 0, geo.real_width),
+ "right": tools.remap(rel_right - geo.x, 0, geo.width, 0, geo.real_width),
+ "top": tools.remap(rel_top - geo.y, 0, geo.height, 0, geo.real_height),
+ "bottom": tools.remap(rel_bottom - geo.y, 0, geo.height, 0, geo.real_height),
144
145
} else {
146
__sel = null;
web/share/js/tools.js
@@ -136,14 +136,9 @@ export var tools = new function() {
136
return `${hours}:${mins}:${secs}.${millis}`;
- self.remap = function(x, a1, b1, a2, b2) {
- let remapped = Math.round((x - a1) / b1 * (b2 - a2) + a2);
- if (remapped < a2) {
- return a2;
- } else if (remapped > b2) {
- return b2;
- }
- return remapped;
+ self.remap = function(value, in_min, in_max, out_min, out_max) {
+ let result = Math.round((value - in_min) * (out_max - out_min) / ((in_max - in_min) || 1) + out_min);
+ return Math.min(Math.max(result, out_min), out_max);
147
148
149
self.getRandomInt = function(min, max) {
0 commit comments