Fix incorrect scaling for absolute mouse coordinates
This commit is contained in:
parent
1eda45a81a
commit
b67600962a
6 changed files with 35 additions and 24 deletions
|
|
@ -145,8 +145,8 @@ public:
|
|||
void abs_mouse(input_t &input, const touch_port_t &touch_port, float x, float y) {
|
||||
auto touchscreen = ((input_raw_t *)input.get())->touch_input.get();
|
||||
|
||||
auto scaled_x = (int)std::lround((x + touch_port.offset_x) * ((float)target_touch_port.env_width / (float)touch_port.env_width));
|
||||
auto scaled_y = (int)std::lround((y + touch_port.offset_y) * ((float)target_touch_port.env_height / (float)touch_port.env_height));
|
||||
auto scaled_x = (int)std::lround((x + touch_port.offset_x) * ((float)target_touch_port.width / (float)touch_port.width));
|
||||
auto scaled_y = (int)std::lround((y + touch_port.offset_y) * ((float)target_touch_port.height / (float)touch_port.height));
|
||||
|
||||
libevdev_uinput_write_event(touchscreen, EV_ABS, ABS_X, scaled_x);
|
||||
libevdev_uinput_write_event(touchscreen, EV_ABS, ABS_Y, scaled_y);
|
||||
|
|
@ -470,7 +470,7 @@ evdev_t touchscreen() {
|
|||
input_absinfo absx {
|
||||
0,
|
||||
0,
|
||||
target_touch_port.env_width,
|
||||
target_touch_port.width,
|
||||
1,
|
||||
0,
|
||||
28
|
||||
|
|
@ -479,7 +479,7 @@ evdev_t touchscreen() {
|
|||
input_absinfo absy {
|
||||
0,
|
||||
0,
|
||||
target_touch_port.env_height,
|
||||
target_touch_port.height,
|
||||
1,
|
||||
0,
|
||||
28
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue