-
-
Notifications
You must be signed in to change notification settings - Fork 305
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
Pointer events from other devices cause pen to jump #665
Comments
Thanks for the detailed report! This is definitely something that we can and should address, because most likely issue #534 is a manifestation of the same thing: multiple pointers "drawing" at the same time. It can also be a bit unexpected when the touch-drawing option is enabled, and users, out of habit, attempt to pinch-to-zoom but draw zip-zap lines instead (see issue #624) The fact that it is actually some touch-pads that emit "invalid" pointer-move events make a lot of sense, and explains why I couldn't replicate that issue. I assume it could also be if there are any oily or other capacitive substances on the touchpad. How would you approach it? The input used to be handled differently in the past, where each input type (stylus, mouse, touch) had its own gesture that denied the others when it handled events. But that had drawbacks, so Rnote switched to the "EventControllerLegacy" and we are now handling all events ourselves. We'd probably need to write a manual implementation of claiming/denying event sequences from the different sources ourselves, or what are your thoughts here? |
Thanks for pointing me to the other issue, didn't see it before. Definitely seems like the same thing.
Yes that could be the case for some. Unfortunately for me it seems to more be a problem with the combination of my touchpad and Kwin, since when using GNOME (Mutter) I do not have this issue.
I haven't really dug into the source code beyond the logging in canvas/src/input.rs yet and actually don't have much experience with Gtk at all, so my current idea might not be very feasible . My thought was to have complete multi-cursor support (as in you can draw with multiple input devices e.g. pen and mouse or pen and touch) by having separate cursors for each device (with a default cursor as a fallback if needed). I will look into the code later to understand how Rnote currently works and will respond with a more developed suggestion then. |
I have just looked in a bit more, and I think it should be possible to modify the |
I have done some work on #666 and I believe my initial approach is doable (as partially demonstrated by the current code).
I think your suggestion of writing a manual implementation of blocking events is probably best here to fully fix all related issues, after-all multi-brush support isn't a feature most people would use. What were the drawbacks of the denying by input type approach? |
I actually experienced something like #534 in Xournal++ as well a few times, but I couldn't reproduce it reliably (and do not experience it at all in Rnote, at least on X11). I agree about it originating somewhere lower-level and should be debugged more thoroughly.
The way it was implemented was using different gestures: GestureStylus for stylus input, and two GestureDrag. One for touch input configured with touch-only and one configured with exclusive for mouse input. The last also captured input in the "bubble" propagation phase, so that it didn't interfere with the other. So I believe it is best to keep the current raw handling of the events, but write blocking events based on some conditions ourselves. Is checking if gdk::Device is different robust enough? If yes, we could use that and combine this condition with PenProgress. I think that would work well, since this would require finishing all in-progress strokes/shape-building with the same input method (unless we actually want to allow switching the input method while being "in-progress") |
I see, I think I agree especially considering the current implementation seems cleaner to me anyway.
Under the hood I have opened #672 with this implementation, and it should also fix #624 . |
I added a comment in the PR. Just for reference, I saw this page in the wayland docs: https://wayland.freedesktop.org/libinput/doc/latest/touchpad-jumping-cursors.html |
I think this bug applies to me, but let me know if this deserves it's own issue. See below for a work-around which may hint at the root cause. Setup:
Jumps in drawing lines happens in the following ways:
A work-around that seems to work is to wait for the pen hover indicator before trying to draw new lines. I think the issue is that if you draw so quickly that the there is little time for the "pen hover" state to be detected before you are touching the screen, then something gets messed up. When I was working on a FreeRDP patch for stylus use, I also found state transitions realted to hovering to be a headache |
A nice workaround from #534 (comment) is to move the mouse outside the window. It works for me to move it to the titlebar. A possible automatic workaround, if on kde plasma, could be to call this under some condition:
it moves the mouse to (0,0). Hmm, could maybe be a kwin script that will do that if rnote is running, and if the mouse hasn't moved for 5 seconds or something. |
@cyclane Does the PR here help solve this issue? This is the only thing that is keeping this usable in Android through Termux-X11. Here are additional details from my setup termux/termux-x11#608 |
That PR partially solves the issue, but has not been merged because it's extremely inconsistent across different desktop linux installations and devices. So I'm really not sure how it would hold up on Android either. Unfortunately, last time I looked, I couldn't find a way to solve it without having to dig into gtk itself. |
@digitalsignalperson Yep that's definitely the same issue. Unfortunately it's so inconsistent across linux installations and devices though, that it's difficult to find a proper fix for it. |
@cyclane I moved from Debian 12 to Fedora 40 Xfce (+virgl) on my Termux setup and have not gotten the random jumps anymore. |
Describe the bug
Pointer events from other devices cause the pen to jump to the other device's pointer position, usually making an annoying mark on the page.
To Reproduce
Steps to reproduce the behaviour:
Expected behavior
Ideally the cursor might still visually jump, but not draw to a different pointer device's position.
Console Output
(with the log::debug macro in canvas/src/input.rs, also with pointer position (x, y) and length and index of elements vector):
(note the line with
pen_mode: None
and a very different pointer position).Screenshots
Desktop (please complete the following information):
Additional context
Why is this a problem?
Note to maintainer
From my understanding this is not an issue with Rnote, but rather with Kwin / GTK4 / something else lower-level, so you might not be interested adding a work-around.
If you can confirm this is not an issue with Rnote, I would be interested in implementing support for inputs from multiple input devices at the same time which should solve this issue without being too hacky of a work-around.
The text was updated successfully, but these errors were encountered: