GNOME Bugzilla – Bug 624880
Rotate wacom touchscreen devices
Last modified: 2014-02-14 01:35:24 UTC
This report was originally filled at: https://bugs.edge.launchpad.net/ubuntu/+source/gnome-desktop/+bug/599478 When rotating the screen, touch inputs are not remapped correctly. This implements the rotation using a list of matching input devices for which screen rotation needs to trigger a remapping. For me, this works, except that remapped touch input on my lenovo x200 tablet seems to "snap" across the screen on a touch release when it is rotated, so ultimately, this patch is uncovering some other problem while fixing the rotation matching problem. [1]http://launchpadlibrarian.net/51043158/101_rotate-touch-devices.patch
We now do this in gnome-settings-daemon, for single screen setups. If we could figure out to which output the touchscreen was attached, it would make things easier.
And we should ignore the rotation functionality in the wacom plugin as well (and in the control-center front-end too).
(In reply to comment #1) > We now do this in gnome-settings-daemon, for single screen setups. In 3.0 or master? It doesn't work for me on a Thinkpad x61 tablet
(In reply to comment #3) > (In reply to comment #1) > > We now do this in gnome-settings-daemon, for single screen setups. > > In 3.0 or master? It doesn't work for me on a Thinkpad x61 tablet In master. For touchscreens. When using the "RotateTo" method (which is only used for automatic rotation, and the "Rotate" keyboard button.
For your X61 tablet, we're missing: - an event telling us that the swivel state has changed (either an absolute orientation, as is available for tablets with an accelerometer, or a toggled state where we deduce the orientation from the state, "laptop" -> normal, "reversed/tablet" -> 180, or something) - a whitelist of wacom touchscreen devices that we should rotate in the xrandr plugin (we currently only rotate evdev devices). The wacom plugin has a rotation option, and we want to make sure that the option is only applied to discrete tablets, not to builtin ones. For the latter, I would take a "hack" to make your device work, as long as we can replace this by more definitive code in the future.
the screen on my x61 died a month ago, so I can't help here
For reference, right now gsd-xrandr-manager.c has these functions: handle_rotate_windows() - Gets called when the XF86RotateWindows key gets pressed; rotates the RANDR output. I understand that this is a hardware key that says "rotate the screen" on tablets or such - is this correct? rotate_touchscreens() - Called by the above. This actually rotates the input device. From a quick look, these use helpers from gsd-input-helper.c to see whether a device is a touchscreen. The patch from the original bug is not attached here - can someone please take care of that?
(In reply to comment #7) > For reference, right now gsd-xrandr-manager.c has these functions: > > handle_rotate_windows() - Gets called when the XF86RotateWindows key gets > pressed; rotates the RANDR output. I understand that this is a hardware key > that says "rotate the screen" on tablets or such - is this correct? Yes, but that's not where the accelerometer plugs in. The accelerometer input is used in the orientation plugin. > rotate_touchscreens() - Called by the above. This actually rotates the input > device. > > From a quick look, these use helpers from gsd-input-helper.c to see whether a > device is a touchscreen. Yep, we need new functions to determine whether a device is a wacom touchscreen as well (we only know the type of stylus used for wacom touchscreen, not whether they're actual touchscreens). > The patch from the original bug is not attached here - can someone please take > care of that? It's not useful, we have code to rotate wacom tablets already in the wacom plugin (which we can copy/paste). We need to make sure that external wacom tablets follow the orientation preference from the wacom tool, and that wacom touchscreens follow the screen's orientation.
Reassigning to Olivier as it's wacom related.
Thanks for taking the time to report this bug. This particular bug has already been reported into our bug tracking system, but we are happy to tell you that the problem has already been fixed. It should be solved in the next software version. You may want to check for a software upgrade. *** This bug has been marked as a duplicate of bug 709600 ***