4.5 KiB

Screen rotation

Configure the server to start in the desired orientation, there are many ways to achieve this, here are some examples:

!!! warning Rotation is handled by the OS and not by KlipperScreen, if you can't rotate your screen it's usually an issue with the OS configuration

Examples of rotation

???+ example "Universal xorg configuration"

#### Universal xorg configuration
Find the identifier use xrandr

```sh
DISPLAY=:0 xrandr
```

it will output something like:
```
Screen 0: minimum 320 x 200, current 1024 x 600, maximum 8192 x 8192
HDMI-1 connected primary 1024x600+0+0 (normal left inverted right x axis y axis) 800mm x 450mm
```

Take not that the screen is `HDMI-1` (it could be `HDMI-A-1` or many other names)

Create /usr/share/X11/xorg.conf.d/90-monitor.conf
```bash
sudo nano /usr/share/X11/xorg.conf.d/90-monitor.conf
```
Paste this section modifying the options to suit your needs:
```kconfig title="90-monitor.conf"
Section "Monitor"
    Identifier "HDMI-1"
    # This identifier would be the same as the name of the connector printed by xrandr
    # for example  "DVI-I-1 connected primary" means that the identifier is "DVI-I-1"
    # another example "Unknown19-1 connected primary" some GPIO screens identify as Unknown19

    Option "Rotate" "left"
    # Valid rotation options are normal,inverted,left,right

    Option "PreferredMode" "1920x1080"
    # May be necesary if you are not getting your prefered resolution.
EndSection
```
Save the file and restart KlipperScreen.

```bash
sudo service KlipperScreen restart
```

if KlipperScreen doesn't restart:
```bash
sudo reboot
```

you may have to adjust the [touch rotation](../Touch_issues/#touch-rotation-and-matrix)

??? example "Raspberry Pi using kernel cmdline"

#### Raspberry Pi using kernel cmdline
To set screen orientation when in console mode, you will need to edit the kernel command-line
to pass the required orientation to the system.

```bash
sudo nano /boot/firmware/cmdline.txt
```

To rotate by 90 degrees clockwise, add the following to the cmdline, making sure everything is on the same line,
do not add any carriage returns. Possible rotation values are 0, 90, 180 and 270.

For example a DSI screen:
```bash
video=DSI-1:800x480@60,rotate=90
```

To find the identifier on a terminal run:
```bash
DISPLAY=:0 xrandr
```
it will output something like:

```bash
Screen 0: minimum 320 x 200, current 1024 x 600, maximum 8192 x 8192
HDMI-1 connected primary 1024x600+0+0 (normal left inverted right x axis y axis) 800mm x 450mm
```

in this case the identifier is HDMI-1 and a simple cmdline arg would be something like:
```bash
video=HDMI-1:1024x600@60
```

To apply changes do a reboot:
```bash
sudo reboot
```
[Read the official docs for more info](https://www.raspberrypi.com/documentation/computers/config_txt.html)

[Raspberry Display docs](https://www.raspberrypi.com/documentation/accessories/display.html)

??? example "Raspberry Pi legacy mode (works with vc4-fkms-v3d)"

#### Raspberry Pi legacy mode (works with vc4-fkms-v3d)
add to config.txt
```bash
display_lcd_rotate=2
```

To apply changes do a reboot:
```bash
sudo reboot
```

!!! warning
    At the moment of writing Pi4 didn't support 90 and 270 degrees with this method,  [see the official docs](https://www.raspberrypi.com/documentation/computers/config_txt.html#display_hdmi_rotate)

| Value      | result |
| ---------- | ---------- |
| 0          | no rotation |
| 1          | rotate 90 degrees clockwise |
| 2          | rotate 180 degrees clockwise |
| 3          | rotate 270 degrees clockwise |
| 0x10000h   | horizontal flip |
| 0x20000    | vertical flip |

[Read the official docs for more info](https://www.raspberrypi.com/documentation/computers/config_txt.html)

??? example "Using a screen installed with goodtft-LCD-show"

####  Using a screen installed with goodtft-LCD-show
```bash
cd LCD-show/
sudo ./rotate.sh 90
```

??? example "Using Waveshare screen that is installed with LCD-show"

####  Using Waveshare screen that is installed with LCD-show
```bash
cd LCD-show/
sudo ./LCD43-show 270 lite
```

Touchscreen touch rotation

See touch rotation