Skip to content

Latest commit

 

History

History
112 lines (83 loc) · 3.58 KB

README.md

File metadata and controls

112 lines (83 loc) · 3.58 KB

Touchscreen Rotation and Calibration Matrix Script for Gnome

This script provides a terminal interface to rotate the display and calibrate the touchscreen input matrix on Wayland and X11 environments automatically.

Requirements

  • Python 3
  • gnome-randr and libinput (for Wayland)
  • sudo privileges for modifying udev rules
  • Users should be in the input group to avoid needing sudo for these operations
  • optional gdm-settings for login screen

Installation

Debian-based Distributions

  1. Install Python:

    sudo apt-get install python3
  2. Install Wayland Dependencies

    sudo apt-get install libinput-tools
  3. Install gnome-randr:

    • gnome-randr can be installed using Cargo, the Rust package manager. First, ensure you have Rust and Cargo installed. Follow the instructions at rust-lang.org, e.g.:
     curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
    • Once Rust and Cargo are installed, you can install gnome-randr by running:
      cargo install gnome-randr
  4. Add User to the input group:

      sudo usermod -a -G input USERNAME

Arch-based Distributions

  1. Install Python:

    sudo pacman -S python
  2. Install Wayland Dependencies

    sudo pacman -S libinput
  3. Install gnome-randr:

    • gnome-randr can be installed using Cargo, the Rust package manager. First, ensure you have Rust and Cargo installed. Follow the instructions at rust-lang.org, e.g.:

      curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
    • Once Rust and Cargo are installed, you can install gnome-randr by running:

      cargo install gnome-randr
  4. Add User to the input group:

    sudo usermod -aG input USERNAME

Usage

Run the script using Python:

python3 gptouch.py

Script Flow

  1. The script checks for the required dependencies (xrandr, xinput, gnome-randr, and libinput).
  2. It determines the active display output based on the session type (X11 or Wayland).
  3. It identifies the connected touchscreen device.
  4. It prompts the user to select the desired screen orientation.
  5. It applies the selected screen orientation.
  6. It updates the touchscreen calibration matrix and writes it to the udev rules, using sudo.
  7. It prompts the user to reboot the system to apply the changes.

Orientation Options

  • 1: Landscape (normal)
  • 2: Portrait (right side up)
  • 3: Portrait (left side up)
  • 4: Inverted (upside down)

Notes

  • Users should be in the input group to avoid needing sudo for libinnput.
  • The script requires sudo privileges to modify udev rules.
  • Use gdm-settings to apply rotation on login screen

Troubleshooting

  • Dependency Errors: Ensure all required packages are installed.
  • Display Not Found: Verify that your display is correctly connected and detected by the system.
  • Touchscreen Device Not Found: Check the connections and ensure user is in input group.

License

This project is licensed under the MIT License.

Acknowledgements

  • gnome-randr and libinput are used for Wayland display and input management.