Enable autorotate on a Microsoft Surface Pro Tablet running Linux. #complete
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Elf M. Sternberg 3fd0b12b60 Merge remote-tracking branch 'refs/remotes/origin/master' 6 years ago
autorotate Merge remote-tracking branch 'refs/remotes/origin/master' 6 years ago
DESCRIPTION.md STYLE Some feedback prompted me to add commentary. 6 years ago
README.md Re-wrote README to reflect current usage and installation. 6 years ago



This program autorotates the screen of a Microsoft Surface Pro 3 Tablet running Linux. It correctly performs the autorotation for all major pointer devices, including the stylus and eraser devices. It also enables palm rejection (meaning you can rest your hand on the screen while drawing) when the stylus and eraser devices are "in use" (which is defined by the digitizer as "within approximately 4cm of the screen").

This program is written in Python 2, which is included in all major Linux distributions by default. It has no additional dependencies.

It may run on other versions of the Microsoft Surface, but I haven't tested it on anything other than my own Surface Pro 3.


To install, just copy autorotate/autorotate.py to a directory in your $PATH.

Feel free to remove the '.py' extension; Linux doesn't use or need it. Also, remember to make the program executable:

chmod +x autorotate.py

(or whatever you choose to name it).

You may have to edit the first line of the autorotate script, if your distro's Python 2 install doesn't include a link to it via the command "python2".


Start script:

$ python2 /path/to/autorotate.py


The original geometry detection algorithms were written by Ayko Poel. My contribution consists of more robust device and device driver identification algorithms for the stylus and eraser, and a general modernization of the transform algorithm.