2022-10-20 22:54:34 +02:00
|
|
|
# Table of contents
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
{{< toc format=html >}}
|
|
|
|
|
2022-10-20 22:54:34 +02:00
|
|
|
# General
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
The general config of a monitor looks like this
|
2022-10-19 15:22:42 +02:00
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=name,resolution,offset,scale
|
|
|
|
```
|
|
|
|
|
|
|
|
A common example:
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=DP-1,1920x1080@144,0x0,1
|
|
|
|
```
|
|
|
|
|
|
|
|
will tell Hyprland to make the monitor on `DP-1` a `1920x1080` display, at 144Hz,
|
|
|
|
`0x0` off from the top left corner, with a scale of 1 (unscaled).
|
|
|
|
|
|
|
|
{{< hint >}}
|
|
|
|
|
|
|
|
The offset is calculated with the scaled resolution, meaning if
|
|
|
|
you want your 4K monitor with scale 2 to the left of your 1080p one, you'd use
|
|
|
|
the offset `1920x0` for the second screen. (3840 / 2)
|
|
|
|
|
|
|
|
{{</ hint >}}
|
|
|
|
|
|
|
|
Please use the offset for its intended purpose before asking stupid questions
|
|
|
|
about "fixing" monitors being mirrored.
|
|
|
|
|
|
|
|
Leaving the name empty will define a fallback rule to use when no other rules
|
|
|
|
match.
|
|
|
|
|
|
|
|
You can use `preferred` as a resolution to use the display's preferred size, and
|
|
|
|
`auto` as an offset to let Hyprland decide on an offset for you.
|
|
|
|
|
|
|
|
Recommended rule for quickly plugging in random monitors:
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=,preferred,auto,1
|
|
|
|
```
|
|
|
|
|
|
|
|
Will make any monitor that was not specified with an explicit rule automatically
|
|
|
|
placed on the right of the other(s) with its preferred resolution.
|
|
|
|
|
2022-09-24 16:37:22 +02:00
|
|
|
Alternatively you can use the `highrr` or `highres` rules in order to get the
|
|
|
|
best possible resolution or refreshrate mix.
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
for a focus on refreshrate use this:
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=,highrr,auto,1
|
|
|
|
```
|
|
|
|
|
|
|
|
for a focus on resolution this:
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=,highres,auto,1
|
|
|
|
```
|
|
|
|
|
2022-10-05 11:24:22 +02:00
|
|
|
For more specific rules, you can also use the output's description
|
|
|
|
(see `hyprctl monitors`) like this:
|
|
|
|
|
|
|
|
```
|
|
|
|
monitor=desc:SDC 0x4154 (eDP-1),preferred,auto,1.5
|
|
|
|
```
|
|
|
|
|
2022-10-23 00:58:34 +02:00
|
|
|
## Disabling a monitor
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
To disable a monitor, use
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=name,disable
|
|
|
|
```
|
|
|
|
|
2022-10-20 22:54:34 +02:00
|
|
|
# Custom reserved area
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
If your workflow requires custom reserved area, you can add it with
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=name,addreserved,TOP,BOTTOM,LEFT,RIGHT
|
|
|
|
```
|
|
|
|
|
|
|
|
Where `TOP` `BOTTOM` `LEFT` `RIGHT` are integers in pixels of the reserved area
|
|
|
|
to add. This does stack on top of the calculated one, (e.g. bars) but you may
|
|
|
|
only use one of these rules per monitor in the config.
|
|
|
|
|
2022-10-20 22:54:34 +02:00
|
|
|
# Mirrored displays
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
If you want to mirror a display, add a `,mirror,[NAME]` at the end of the monitor
|
|
|
|
rule, examples:
|
2022-09-24 16:03:37 +02:00
|
|
|
|
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=DP-3,1920x1080@60,0x0,1,mirror,DP-2
|
|
|
|
monitor=,preferred,auto,1,mirror,DP-1
|
|
|
|
```
|
|
|
|
|
|
|
|
Please remember that mirroring displays will not "re-render" everything for your
|
2022-09-24 16:37:22 +02:00
|
|
|
second monitor, so if mirroring a 1080p screen onto a 4K one, the resolution
|
|
|
|
will still be 1080p on the 4K display. This also means squishing and stretching
|
2022-09-24 15:32:40 +02:00
|
|
|
will occur on non-matching resolutions.
|
|
|
|
|
2022-10-20 22:54:34 +02:00
|
|
|
# Rotating and the default workspace
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
{{< hint type=important >}}
|
|
|
|
|
|
|
|
The monitor transform and workspace keywords depend on a monitor rule set
|
2022-10-19 15:22:42 +02:00
|
|
|
specifically for the targeted monitor, and **_MUST_** be after it.
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
{{< /hint >}}
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
workspace=name,number
|
|
|
|
```
|
|
|
|
|
|
|
|
for example:
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
workspace=DP-1,1
|
|
|
|
```
|
|
|
|
|
|
|
|
will tell Hyprland to make the default workspace on DP-1 a number 1.
|
|
|
|
|
|
|
|
If you want to rotate a monitor, use
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
monitor=NAME,transform,TRANSFORM
|
|
|
|
```
|
|
|
|
|
|
|
|
where `NAME` is the name, and `TRANSFORM` is an integer, from 0 to 7,
|
|
|
|
corresponding to your transform of choice.
|
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-10-16 23:03:01 +02:00
|
|
|
normal (no transforms) -> 0
|
|
|
|
90 degrees -> 1
|
|
|
|
180 degrees -> 2
|
|
|
|
270 degrees -> 3
|
|
|
|
flipped -> 4
|
|
|
|
flipped + 90 degrees -> 5
|
|
|
|
flipped + 180 degrees -> 6
|
|
|
|
flipped + 270 degrees -> 7
|
2022-09-24 15:32:40 +02:00
|
|
|
```
|
|
|
|
|
2022-10-20 22:54:34 +02:00
|
|
|
# Binding workspaces to a monitor
|
2022-09-24 15:32:40 +02:00
|
|
|
|
|
|
|
A workspace can be bound to a monitor, meaning by default it will ALWAYS open
|
|
|
|
on the selected monitor. You can do this with
|
2022-10-19 15:22:42 +02:00
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
wsbind=WORKSPACE,MONITOR
|
|
|
|
```
|
|
|
|
|
|
|
|
for example:
|
2022-10-19 15:22:42 +02:00
|
|
|
|
2022-09-24 16:03:37 +02:00
|
|
|
```ini
|
2022-09-24 15:32:40 +02:00
|
|
|
wsbind=5,DP-1
|
|
|
|
wsbind=name:secret,DP-2
|
|
|
|
```
|