Keyboard shortcuts

Press or to navigate between chapters

Press S or / to search in the book

Press ? to show this help

Press Esc to hide this help

Outputs (Monitors)

Jay configures monitors through the [[outputs]] array. Each entry matches one or more connected displays and applies settings such as position, scale, mode, and color management.

Note

Output configuration defined in config.toml is only applied the first time a matching output is connected after the compositor starts. To change settings at runtime, use jay randr or the configure-output action.

Matching outputs

Every [[outputs]] entry requires a match field that selects which monitors the settings apply to. You can match by serial number, connector name, manufacturer, or model.

When match is a table, all specified fields must match (AND logic). When match is an array, any entry matching is sufficient (OR logic).

The serial number is a unique identifier that stays the same regardless of which port the monitor is plugged into:

[[outputs]]
match.serial-number = "33K03894SL0"
scale = 1.5

Run jay randr to find the serial number of your connected displays.

By connector name

[[outputs]]
match.connector = "DP-1"
scale = 1.25

Connector names (like DP-1, HDMI-A-1, eDP-1) can change if you move cables between ports.

By manufacturer and model

[[outputs]]
match = { manufacturer = "BNQ", model = "BenQ GW2480" }
scale = 1.25

When multiple fields appear in a single table, all must match.

Combining criteria (OR)

Use an array to match any of several outputs with the same settings:

[[outputs]]
match = [
    { serial-number = "33K03894SL0" },
    { serial-number = "ETW1M02062SL0" },
]
scale = 2.0

Naming outputs

Assign a name to reference an output from other parts of the config – for example, when mapping a tablet to a specific monitor or using shortcuts to reconfigure outputs at runtime:

[[outputs]]
name = "left"
match.serial-number = "33K03894SL0"
x = 0
y = 0

[[outputs]]
name = "right"
match.serial-number = "ETW1M02062SL0"
x = 1920
y = 0

Other rules can then reference these names:

# Map a drawing tablet to the left monitor
[[inputs]]
match.name = "Wacom Intuos Pro M Pen"
output.name = "left"
# Rotate a named output with a shortcut
[shortcuts]
alt-r = {
    type = "configure-output",
    output = {
        match.name = "right",
        transform = "rotate-90",
    },
}

Position

The x and y fields place outputs in compositor space. Coordinates are integers >= 0 and represent the top-left corner of the output:

[[outputs]]
match.serial-number = "33K03894SL0"
x = 0
y = 0

[[outputs]]
match.serial-number = "ETW1M02062SL0"
x = 2560
y = 0

Tip

The control center (alt-c by default) includes a visual output arrangement editor where you can drag monitors into position.

Scale

Set fractional scaling with a number greater than 0:

[[outputs]]
match.serial-number = "33K03894SL0"
scale = 1.5

Common values: 1.0 (no scaling), 1.25, 1.5, 2.0.

Transform

Rotate or flip the output. The available values are:

none
No transformation
rotate-90
Rotate 90 degrees counter-clockwise
rotate-180
Rotate 180 degrees
rotate-270
Rotate 270 degrees counter-clockwise
flip
Flip around the vertical axis
flip-rotate-90
Flip vertically, then rotate 90 degrees counter-clockwise
flip-rotate-180
Flip vertically, then rotate 180 degrees
flip-rotate-270
Flip vertically, then rotate 270 degrees counter-clockwise
[[outputs]]
match.serial-number = "33K03894SL0"
transform = "rotate-90"

Mode

Set the resolution and refresh rate with the mode field. If refresh-rate is omitted, the first available mode with the specified resolution is used:

[[outputs]]
match.serial-number = "33K03894SL0"
mode = {
    width = 2560,
    height = 1440,
    refresh-rate = 144.0,
}

Use jay randr to see all available modes for each output:

~$ jay randr show --modes

Variable Refresh Rate (VRR)

VRR (also known as FreeSync or Adaptive Sync) allows the display to vary its refresh rate to match the content being rendered, reducing stuttering and tearing.

Configure VRR with the vrr field:

[[outputs]]
match.serial-number = "33K03894SL0"
vrr = { mode = "variant1", cursor-hz = 90 }

VRR modes

never
VRR is always off (default)
always
VRR is always on
variant1
VRR is on when one or more applications are displayed fullscreen
variant2
VRR is on when exactly one application is displayed fullscreen
variant3
VRR is on when a single application is displayed fullscreen and describes its content type as video or game via the wp_content_type_v1 protocol

Cursor refresh rate

When VRR is active, cursor movement can cause the screen to spike to maximum refresh rate. The cursor-hz field limits cursor-triggered updates:

vrr = { mode = "always", cursor-hz = 90 }

Set cursor-hz = "none" for unbounded cursor updates (the default). A numeric value means the cursor is updated at that rate in Hz, or faster if the application is already driving updates above that rate.

You can also set default VRR settings for all outputs at the top level:

vrr = { mode = "variant1", cursor-hz = 90 }

Per-output settings override the top-level default.

Tearing

Tearing allows frames to be presented immediately instead of waiting for vertical blank, reducing input latency at the cost of visible tearing artifacts.

[[outputs]]
match.serial-number = "33K03894SL0"
tearing.mode = "variant3"

Tearing modes

never
Tearing is never enabled
always
Tearing is always enabled
variant1
Tearing is enabled when one or more applications are displayed fullscreen
variant2
Tearing is enabled when a single application is displayed fullscreen
variant3
Tearing is enabled when a single application is displayed and has requested tearing (default)

The default tearing mode is variant3. Like VRR, per-output settings override top-level defaults:

tearing.mode = "never"

Framebuffer format

The default framebuffer format is xrgb8888. You can change it to any DRM fourcc format:

[[outputs]]
match.serial-number = "33K03894SL0"
format = "rgb565"

Common formats include xrgb8888, argb8888, xbgr8888, abgr8888, rgb565, and many others. See the auto-generated specification for the full list.

HDR and color management

Jay supports HDR output through color space, transfer function, and brightness settings. These require the Vulkan renderer. For a conceptual overview and step-by-step guide, see HDR & Color Management.

Color space

[[outputs]]
match.serial-number = "33K03894SL0"
color-space = "bt2020"

Values: default (usually sRGB) or bt2020.

Transfer function (EOTF)

[[outputs]]
match.serial-number = "33K03894SL0"
transfer-function = "pq"

Values: default (usually gamma 2.2) or pq (Perceptual Quantizer, used for HDR10).

Brightness

Set SDR content brightness in cd/m^2 or use "default":

[[outputs]]
match.serial-number = "33K03894SL0"
brightness = 80

The default depends on the transfer function:

  • With default EOTF: the maximum brightness of the display, anchored at 80 cd/m^2. Setting a value below 80 creates HDR headroom.
  • With pq: 203 cd/m^2.

This setting has no effect unless the Vulkan renderer is in use.

Blend space

Controls how colors are blended when compositing overlapping surfaces:

[[outputs]]
match.serial-number = "33K03894SL0"
blend-space = "linear"
srgb
Classic desktop blending in sRGB space (default)
linear
Physically correct blending in linear light – produces brighter results

Native gamut

By default, Jay assumes displays use sRGB primaries (matching the behavior of most other compositors). In reality, many displays have a wider gamut.

Setting use-native-gamut = true tells Jay to use the primaries advertised in the display’s EDID. This can produce more accurate colors and allows color-managed applications to use the full gamut:

[[outputs]]
match.serial-number = "33K03894SL0"
use-native-gamut = true

This has no effect when the display is explicitly operating in a wide color space (e.g. BT.2020).

Connector configuration

The [[connectors]] array lets you enable or disable physical display connectors. This is useful for permanently disabling a port:

[[connectors]]
match.name = "eDP-1"
enabled = false

Connector configuration is applied when the connector is first discovered by the compositor, which typically happens only at startup.

Lid switch (auto-disable laptop screen)

On laptops, you can automatically disable the built-in display when the lid is closed using the [[inputs]] array. The lid switch is an input device:

[[inputs]]
match.name = "<lid switch name>"
on-lid-closed = {
    type = "configure-connector",
    connector = {
        match.name = "eDP-1",
        enabled = false,
    },
}
on-lid-opened = {
    type = "configure-connector",
    connector = {
        match.name = "eDP-1",
        enabled = true,
    },
}

Run jay input to find the name of your lid switch device. See the Input Devices chapter for more details.

Runtime changes

Output settings in config.toml are only applied when a display is first connected after compositor startup. For runtime changes, use the jay randr CLI or the configure-output action.

Listing outputs

~$ jay randr

This shows all connected outputs with their connector names, serial numbers, current modes, scales, transforms, and available modes.

Changing settings at runtime

~$ jay randr output <name-or-connector> scale 1.5
~$ jay randr output <name-or-connector> mode 2560 1440 144.0
~$ jay randr output <name-or-connector> position 1920 0
~$ jay randr output <name-or-connector> transform rotate-90
~$ jay randr output <name-or-connector> enable
~$ jay randr output <name-or-connector> disable

Using shortcuts

The configure-output action lets you change output settings from a keybinding:

[shortcuts]
alt-F7 = {
    type = "configure-output",
    output = {
        match.name = "right",
        transform = "none",
    },
}
alt-F8 = {
    type = "configure-output",
    output = {
        match.name = "right",
        transform = "rotate-90",
    },
}

Full reference

For the exhaustive list of all output fields, match criteria, and related types, see the auto-generated specification.