Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add high resolution scrolling to UHK-80, switch to standard defined implementation #1047

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

benedekkupper
Copy link
Contributor

@benedekkupper benedekkupper commented Dec 19, 2024

I have modified @rightaditya 's original implementation on the UHK-60, to instead follow the exact MS recommendation as laid out in the specs. Therefore this needs to be retested on UHK-60, especially with Linux host.

@mondalaci
Copy link
Member

Now scrolling is surely high resolution on both the UHK 60 and UHK 80. But the multiplier should be adjusted because I have to scroll a mile with my module, which only results in a couple of pixels scrolling on the screen.

@benedekkupper
Copy link
Contributor Author

We can freely choose what multipliers we use for both high-res and regular scrolling, we can even make it agent configurable. Simply change what VerticalScrollMultiplier() and HorizontalScrollMultiplier() are returning (currently they are 1 for regular and 120 for high-res scrolling).

@mhantsch
Copy link
Contributor

I can test it on Linux, Windows, and MacOS with UHK 60 and UHK 80, but can I ask you to choose a reasonable multiplier first before I do all the tests?

@mhantsch
Copy link
Contributor

mhantsch commented Dec 20, 2024

It should default to a multiplier which gives it the same scrolling characteristics as before the upgrade to high-res scrolling. I have @rightaditya 's high-res build on one UHK 60, and with these settings it behaves pretty perfectly:

image

@benedekkupper
Copy link
Contributor Author

It should default to a multiplier which gives it the same scrolling characteristics as before the upgrade to high-res scrolling. I have @rightaditya 's high-res build on one UHK 60, and with these settings it behaves pretty perfectly:

The multiplier values aren't changed from @rightaditya 's version, so if you see that the two versions (his and this MR) produce different behavior, let me know. The current version's intention is certainly to provide the same feel as before, that's why the scaling up by exactly the increased resolution. But since the scrolling mechanism itself is different, we will probably need some empirical tuning of this value.

@mhantsch
Copy link
Contributor

if you see that the two versions (his and this MR) produce different behavior, let me know

OK, understood. Will test in the next few days and let you know.

@mondalaci
Copy link
Member

I retested this, and scrolling is painfully slow on Linux and Windows, but it's a bit too quick on Mac :D Let's optimize for Linux and Windows first. Scrolling speed didn't change when changing scrollMultiplier to 120.f in processMouseKineticState.

@kareltucek Would you look into tweaking the multiplier?

@kareltucek
Copy link
Collaborator

Sure!

@benedekkupper
Copy link
Contributor Author

benedekkupper commented Dec 20, 2024

macOS doesn't support high resolution scrolling, so there should not be a difference with or without this feature (well except for the change in the full scale of the scrolling, but I doubt that that plays a significant role). I also tested on Android, also not supported (somewhat unsurprisingly).

@rightaditya
Copy link
Contributor

Just a note from when I was messing with this: I tried separating the multipliers so that they were independent for vertical and horizontal scrolling, but ultimately it was deemed unnecessary as, in practice, you can really only turn them on and off per-axis in Windows (it has no functionality to set the multiplier to different values, even if the device says it supports this). Turning it off on one axis but not the other ended up needing some adjustments to the axis-locking that were unnecessary complicated, so I ended up reverting the change and using just a single multiplier. Toggling high-res scrolling requires registry editing, and you have to go and look up the device's ID from Device Manager to figure out which entries to modify, so it seemed like it'd be exceptionally rare for anyone to actually use that capability.

Linux has no toggling ability, and IIRC it isn't something that could be fixed in userspace (e.g., by a compositor through libinput, etc.), as the relevant functionality isn't in the kernel either (from my looking through the high-resolution scrolling multiplier code, at any rate).

@benedekkupper's suggestion of making the multiplier Agent-configurable would get around some of this, but might require a device reboot for the OS to pick up on the changed value. The HID spec does have a mechanism for the device to report value changes to the OS, and I did test it out when I was implementing this, but IIRC neither Windows nor Linux did anything with it, so that functionality is likely unimplemented. (And I verified this for Linux.)

@mondalaci
Copy link
Member

Assuming a reasonable constant multiplier is used for high-res scrolling with both axes, I don't see the need to adjust it via Agent given that it already allows adjusting scroll speed.

@kareltucek
Copy link
Collaborator

kareltucek commented Jan 9, 2025

Closes #1039 .
Closes #1073 .

@kareltucek Would you look into tweaking the multiplier?

This got lost, sorry!

Will look into it "soon"!

@mondalaci
Copy link
Member

@kareltucek I'm unsure about the state of this issue. I assume that it should be tested with the to-be-implemented UltimateHackingKeyboard/agent#2487

In any case, the conflicts should be resolved.

@kareltucek
Copy link
Collaborator

State: unfinished, some changes live only on my disk atm. I need instructions on how to test it - it reports that smooth scrolling is on, but xev sees just one big scroll event every 15 or so reports, behaving as normal low res scrolling.

Once I push the final version It can be tested without agent. For maximum comfort however it should be released with the relevant Agent feature.

@mondalaci
Copy link
Member

Once this is ready for testing, I'll test it and try to give you instructions on how to test it on Linux.

@kareltucek
Copy link
Collaborator

kareltucek commented Jan 11, 2025

Well, feel free to test and merge.

On my computer, there is no change. I am still getting the old low-res scrolling behavior. Ubuntu 24.10, i3wm, XOrg. Tried with firefox, chromium, google-chrome.

$ xinput list-props 31
Device 'Ultimate Gadget Laboratories UHK 80 right half':
        Device Enabled (215):   1
        Coordinate Transformation Matrix (217): 1.000000, 0.000000, 0.000000, 0.000000, 1.000000, 0.000000, 0.000000, 0.000000, 1.000000
        libinput Natural Scrolling Enabled (343):       0
        libinput Natural Scrolling Enabled Default (344):       0
        libinput Scroll Methods Available (345):        0, 0, 1
        libinput Scroll Method Enabled (346):   0, 0, 0
        libinput Scroll Method Enabled Default (347):   0, 0, 0
        libinput Button Scrolling Button (348): 2
        libinput Button Scrolling Button Default (349): 2
        libinput Button Scrolling Button Lock Enabled (350):    0
        libinput Button Scrolling Button Lock Enabled Default (351):    0
        libinput Middle Emulation Enabled (352):        0
        libinput Middle Emulation Enabled Default (353):        0
        libinput Rotation Angle (326):  0.000000
        libinput Rotation Angle Default (327):  0.000000
        libinput Accel Speed (354):     0.000000
        libinput Accel Speed Default (355):     0.000000
        libinput Accel Profiles Available (356):        1, 1, 1
        libinput Accel Profile Enabled (357):   1, 0, 0
        libinput Accel Profile Enabled Default (358):   1, 0, 0
        libinput Accel Custom Fallback Points (359):    <no items>
        libinput Accel Custom Fallback Step (360):      0.000000
        libinput Accel Custom Motion Points (361):      <no items>
        libinput Accel Custom Motion Step (362):        0.000000
        libinput Accel Custom Scroll Points (363):      <no items>
        libinput Accel Custom Scroll Step (364):        0.000000
        libinput Left Handed Enabled (365):     0
        libinput Left Handed Enabled Default (366):     0
        libinput Send Events Modes Available (328):     1, 0
        libinput Send Events Mode Enabled (329):        0, 0
        libinput Send Events Mode Enabled Default (330):        0, 0
        Device Node (331):      "/dev/input/event257"
        Device Product ID (332):        14248, 9
        libinput Drag Lock Buttons (367):       <no items>
        libinput Horizontal Scroll Enabled (368):       1
        libinput Scrolling Pixel Distance (369):        15
        libinput Scrolling Pixel Distance Default (370):        15
        libinput High Resolution Wheel Scroll Enabled (371):    1

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants