2024-02-20 21:16:07 +01:00
---
weight: 7
title: Window Rules
---
2022-10-23 16:39:10 +02:00
2024-02-20 21:16:07 +01:00
{{< callout type = warning > }}
2022-09-24 15:32:40 +02:00
2024-02-20 21:16:07 +01:00
Window rules (both V1 and V2) are **case sensitive** . (e.g. `firefox` ≠
`Firefox` )
2023-11-25 20:43:01 +01:00
2024-02-20 21:16:07 +01:00
{{< / callout > }}
2023-11-25 20:43:01 +01:00
2024-02-20 21:16:07 +01:00
## Window Rules V1
2022-10-23 16:39:10 +02:00
2024-02-20 21:16:07 +01:00
You can set window rules to achieve different behaviors from the active
container.
2022-09-24 15:32:40 +02:00
2024-02-20 21:16:07 +01:00
### Syntax
2022-09-24 15:32:40 +02:00
2022-09-24 16:03:37 +02:00
```ini
2022-09-24 15:32:40 +02:00
windowrule=RULE,WINDOW
```
2022-11-22 22:25:34 +01:00
- `RULE` is a [rule ](#rules ) (and a param if applicable)
2024-02-20 21:16:07 +01:00
- `WINDOW` is a [RegEx ](https://en.wikipedia.org/wiki/Regular_expression ),
either:
2022-10-23 16:39:10 +02:00
- plain RegEx (for matching a window class);
- `title:` followed by a regex (for matching a window's title)
2022-09-24 15:32:40 +02:00
2022-10-23 16:39:10 +02:00
### Examples
2022-09-24 15:32:40 +02:00
2022-09-24 16:03:37 +02:00
```ini
2022-09-24 15:32:40 +02:00
windowrule=float,^(kitty)$
windowrule=move 0 0,title:^(Firefox)(.*)$
```
2024-02-20 21:16:07 +01:00
## Window Rules V2
2022-09-24 15:32:40 +02:00
2024-02-20 21:16:07 +01:00
In order to allow more flexible rules, while retaining compatibility with the
above rule system, window rules V2 were implemented.
2022-09-24 15:32:40 +02:00
In V2, you are allowed to match multiple variables.
2022-10-23 16:39:10 +02:00
the `RULE` field is unchanged, but in the `WINDOW` field, you can put regexes
for multiple values like so:
2022-09-24 16:03:37 +02:00
```ini
2023-06-24 09:41:53 +02:00
windowrulev2 = float,class:(kitty),title:(kitty)
2022-09-24 15:32:40 +02:00
```
2024-02-20 21:16:07 +01:00
{{< callout type = info > }}
2023-06-24 09:41:53 +02:00
2024-04-21 16:35:48 +02:00
In the case of dynamic window titles such as browser windows, keep in mind how
2024-02-20 21:16:07 +01:00
powerful regex is.
2023-06-24 09:41:53 +02:00
2024-04-21 16:35:48 +02:00
For example, a window rule of:
2024-02-20 21:16:07 +01:00
`windowrule=opacity 0.3 override 0.3 override,title:(.*)(- Youtube)$` will match
_any_ window that contains a string of "- Youtube" after any other text. This
could be multiple browser windows or other applications that contain the string
for any reason.
2023-06-24 09:41:53 +02:00
2024-04-21 16:35:48 +02:00
For the `windowrulev2 = float,class:(kitty),title:(kitty)` example, the
2024-02-20 21:16:07 +01:00
`class:(kitty)` `WINDOW` field is what keeps the window rule specific to kitty
terminals.
{{< / callout > }}
2023-06-24 09:41:53 +02:00
2024-04-13 15:06:33 +02:00
For now, the supported fields for V2 are:
2022-10-23 16:39:10 +02:00
2022-09-24 16:03:37 +02:00
```ini
2024-05-28 23:38:33 +02:00
class - class regex
2022-09-24 15:32:40 +02:00
title - title regex
2024-03-31 03:25:14 +02:00
initialclass - initialClass regex
2024-04-13 15:06:33 +02:00
initialTitle - initialTitle regex
2024-05-28 23:38:33 +02:00
tag - tag name
2022-09-24 15:32:40 +02:00
xwayland - 0/1
floating - 0/1
2022-11-15 11:22:26 +01:00
fullscreen - 0/1
pinned - 0/1
2023-12-08 17:02:50 +01:00
focus - 0/1
2023-08-02 13:23:11 +02:00
workspace - id or name: and name
2024-03-19 22:04:09 +01:00
onworkspace - id, name: and name, or workspace selector (see Workspace Rules)
2022-09-24 15:32:40 +02:00
```
2022-10-23 16:39:10 +02:00
Keep in mind that you _have_ to declare at least one field, but not all.
2024-02-20 21:16:07 +01:00
{{< callout type = info > }}
2022-10-23 16:39:10 +02:00
2024-02-20 21:16:07 +01:00
To get more information about a window's class, title, XWayland status or its
size, you can use `hyprctl clients` .
2022-10-23 16:39:10 +02:00
2024-02-20 21:16:07 +01:00
{{< / callout > }}
2022-09-24 15:32:40 +02:00
2024-04-21 16:35:48 +02:00
{{< callout type = warning > }}
Please beware that `hyprctl clients` will display the field as **initialClass** while the WINDOW field in the configuration uses `initialclass` .
{{< / callout > }}
2022-09-24 15:32:40 +02:00
## Rules
2024-02-14 23:25:02 +01:00
### Static rules
2024-04-21 16:35:48 +02:00
Static rules are evaluated once when the window is opened and never again.
2024-02-14 23:25:02 +01:00
| Rule | Description |
| ---- | ----------- |
| float | floats a window |
| tile | tiles a window |
| fullscreen | fullscreens a window |
| fakefullscreen | fakefullscreens a window |
| maximize | maximizes a window |
2024-04-27 18:34:22 +02:00
| move \[x\] \[y\] | moves a floating window (x,y -> int or %, e.g. 20% or 100. You are also allowed to do `100%-` for the right/bottom anchor, e.g. `100%-20` . In addition, the option supports the subtraction of the window size with `100%-w-` , e.g. `100%-w-20` . This results in a gap at the right/bottom edge of the screen to the window with the defined subtracted size). Additionally, you can also do `cursor [x] [y]` where x and y are either pixels or percent. Percent is calculated from the window's size. Specify `onscreen` before other parameters to force the window into the screen (e.g. `move onscreen cursor 50% 50%` ) |
2024-02-14 23:25:02 +01:00
| size \[x\] \[y\] | resizes a floating window (x,y -> int or %, e.g. 20% or 100) |
| center (\[opt\]) | if the window is floating, will center it on the monitor. Set opt as 1 to respect monitor reserved area |
| pseudo | pseudotiles a window |
| monitor \[id\] | sets the monitor on which a window should open. `id` can be either id or name (either e.g. `1` or e.g. `DP-1` ) |
2024-03-17 13:44:39 +01:00
| workspace \[w\] | sets the workspace on which a window should open (for workspace syntax, see [dispatchers->workspaces ](../Dispatchers#workspaces )). You can also make \[w\] to `unset` , will unset all previous workspace rules applied to this window. You can also add `silent` after the workspace to make the window open silently. |
2024-02-14 23:25:02 +01:00
| nofocus | disables focus to the window |
| noinitialfocus | disables the initial focus to the window |
| forceinput | forces an XWayland window to receive input, even if it requests not to do so. (Might fix issues like e.g. Game Launchers not receiving focus for some reason) |
| windowdance | forces an XWayland window to never refocus, used for games/applications like Rhythm Doctor |
| pin | pins the window (i.e. show it on all workspaces) *note: floating only* |
| unset | removes all previously set rules for the given parameters. Please note it has to match EXACTLY. |
| nomaxsize | removes max size limitations. Especially useful with windows that report invalid max sizes (e.g. winecfg) |
| stayfocused | forces focus on the window as long as it's visible |
| group \[options\] | set window group properties. See the note below. |
2024-02-14 23:26:07 +01:00
| suppressevent \[types...\] | ignores specific events from the window. Events are space separated, and can be: `fullscreen` `maximize` `activate` `activatefocus` |
2024-02-14 23:25:02 +01:00
### Dynamic rules
Dynamic rules are re-evaluated every time a property changes.
| Rule | Description |
| ---- | ----------- |
2024-04-08 00:19:17 +02:00
| opacity \[a\] | additional opacity multiplier. Options for a: `float` -> sets an overall opacity OR `float float` -> sets activeopacity and inactiveopacity respectively, OR `float float float` -> sets activeopacity, inactiveopacity and fullscreenopacity respectively. |
2024-02-14 23:25:02 +01:00
| opaque | forces the window to be opaque (can be toggled with the toggleopaque dispatcher) |
2024-04-21 16:35:48 +02:00
| forcergbx | makes Hyprland ignore the alpha channel of all the window's surfaces, effectively making it _actually, fully 100% opaque_ |
2024-02-14 23:25:02 +01:00
| animation \[style\] (\[opt\]) | forces an animation onto a window, with a selected opt. Opt is optional. |
| rounding \[x\] | forces the application to have X pixels of rounding, ignoring the set default (in `decoration:rounding` ). Has to be an int. |
2024-03-08 15:53:16 +01:00
| minsize \[x\] \[y\] | sets the minimum size (x,y -> int) |
| maxsize \[x\] \[y\] | sets the maximum size (x,y -> int) |
2024-02-14 23:25:02 +01:00
| noblur | disables blur for the window |
| noborder | disables borders for the window |
| bordersize \[size\] | sets the border size |
| nodim | disables window dimming for the window |
| noshadow | disables shadows for the window |
| noanim | disables the animations for the window |
| keepaspectratio | forces aspect ratio when resizing window with the mouse |
2024-05-10 13:28:10 +02:00
| focusonactivate | whether Hyprland should focus an app that requests to be focused (an `activate` request) |
2024-03-17 13:44:39 +01:00
| bordercolor \[c\] | force the bordercolor of the window. Options for c: `color` /`color ... color angle` -> sets the active border color/gradient OR `color color` /`color ... color angle color ... color [angle]` -> sets the active and inactive border color/gradient of the window. See [variables->colors ](../Variables#variable-types ) for color definition. |
2024-02-18 00:55:32 +01:00
| idleinhibit \[mode\] | sets an idle inhibit rule for the window. If active, apps like `hypridle` will not fire. Modes: `none` , `always` , `focus` , `fullscreen` |
2024-02-14 23:25:02 +01:00
| dimaround | dims everything around the window . Please note this rule is meant for floating windows and using it on tiled ones may result in strange behavior. |
| xray \[on\] | sets blur xray mode for the window (0 for off, 1 for on, unset for default) |
2024-03-17 13:44:39 +01:00
| immediate | forces the window to allow to be torn. See [the Tearing page ](../Tearing ). |
2024-02-14 23:25:02 +01:00
| nearestneighbor | forces the window to use the nearest neigbor filtering. |
2024-05-28 23:38:33 +02:00
| tag \[name\] | apply tag to the window, use prefix `+` /`-` to set/unset flag, or no prefix to toggle the flag |
2023-09-22 11:18:04 +02:00
2024-02-20 21:16:07 +01:00
{{< callout type = info > }}
2023-09-22 11:18:04 +02:00
## `group` window rule options
- `set` \[`always` \] - Open window as a group.
- `new` - Shorthand of `barred set` .
2024-02-20 21:16:07 +01:00
- `lock` \[`always` \] - Lock the group that added this window. Use with `set` or
`new` (i.e. `new lock` ) to create a new locked group.
- `barred` - Do not add the window to the focused group. By default, a window
with a `group set` rule will be added to an active group if possible.
- `deny` - Do not allow window to be toggled as or added to group (see
`denywindowfromgroup` dispatcher).
2023-09-22 11:18:04 +02:00
- `invade` - Force open window in the locked group.
2024-02-20 21:16:07 +01:00
- `override` \[other options\] - Override other `group` rules, e.g. You can make
all windows in a particular workspace open as a group, and use
`group override barred` to make windows with specific titles open as normal
windows.
2023-09-22 11:18:04 +02:00
- `unset` - Clear all `group` rules.
The `group` rule without options is a shorthand for `group set` .
2024-02-20 21:16:07 +01:00
By default, `set` and `lock` only affect new windows once. The `always`
qualifier makes them always effective.
2023-09-22 11:18:04 +02:00
2024-02-20 21:16:07 +01:00
{{< / callout > }}
2022-09-24 15:32:40 +02:00
2024-05-28 23:38:33 +02:00
### Tags
Window may have several tags, either static or dynamic, dynamic tag will have a suffix of `*` .
You may check window tags with `hyprctl clients` .
Use `tagwindow` dispatcher to add a static tag to a window:
```
hyprctl dispatch tagwindow +code # add tag to current window
hyprctl dispatch tagwindow -- -code # remove tag from current window (use `--` to protect the leading `-` )
hyprctl dispatch tagwindow code # toggle the tag of current window
# or you can tag windows matched with a window regex
hyprctl dispatch tagwindow +music deadbeef
hyprctl dispatch tagwindow +media title:Celluloid
```
Use `tag` rule to add a dynamic tag to a window:
```ini
windowrulev2 = tag +term, class:(footclient) # add dynamic tag `term*` to window footclient
windowrulev2 = tag term, class:(footclient) # toggle dynamic tag `term*` for window footclient
windowrulev2 = tag +code, tag:cpp # add dynamic tag `code*` to window with tag `cpp`
windowrulev2 = opacity 0.8, tag:code # set opacity for window with tag `code` or `code*`
windowrulev2 = opacity 0.7, tag:cpp # window with tag `cpp` will match both `code` and `cpp` , the last one will override prior match
windowrulev2 = opacity 0.6, tag:term* # set opacity for window with tag `term*` only, `term` will not be matched
windowrulev2 = tag -code, tag:term # remove dynamic tag `code*` for window with tag `term` or `term*`
```
Or with keybind for convenience:
```ini
bind = $mod Ctrl, 2, tagwindow, alpha_0.2
bind = $mod Ctrl, 4, tagwindow, alpha_0.4
windowrulev2 = opacity 0.2 override, tag:alpha_0.2
windowrulev2 = opacity 0.4 override, tag:alpha_0.4
```
The `tag` rule can only manipulate dynamic tags, and the `tagwindow` dispatcher only work with static tags
(as once the dispatcher is called, dynamic tags will be cleared).
2022-10-23 16:39:10 +02:00
### Example Rules
2022-09-24 16:03:37 +02:00
```ini
2022-11-10 18:01:52 +01:00
windowrule = move 100 100,^(kitty)$ # moves kitty to 100 100
windowrule = animation popin,^(kitty)$ # sets the animation style for kitty
windowrule = noblur,^(firefox)$ # disables blur for firefox
windowrule = move cursor -50% -50%,^(kitty)$ # moves kitty to the center of the cursor
2022-11-15 11:22:26 +01:00
windowrulev2 = bordercolor rgb(FF0000) rgb(880808),fullscreen:1 # set bordercolor to red if window is fullscreen
2022-12-11 18:18:04 +01:00
windowrulev2 = bordercolor rgb(FFFF00),title:^(.*Hyprland.*)$ # set bordercolor to yellow when title contains Hyprland
2024-04-08 00:19:17 +02:00
windowrule = opacity 1.0 override 0.5 override 0.8 override,^(kitty)$ # set opacity to 1.0 active, 0.5 inactive and 0.8 fullscreen for kitty
2022-12-11 18:18:04 +01:00
windowrule = rounding 10,^(kitty)$ # set rounding to 10 for kitty
2024-03-14 19:27:43 +01:00
windowrulev2 = stayfocused, class:^(pinentry-) # fix pinentry losing focus
2022-09-24 15:32:40 +02:00
```
2022-10-23 16:39:10 +02:00
### Notes
2024-02-20 21:16:07 +01:00
Rules that are marked as _Dynamic_ will be reevaluated if the matching property
of the window changes. For instance, if a rule is defined that changes the
2024-04-21 16:35:48 +02:00
`bordercolor` of a window when it is floating, then the `bordercolor` will change to
2024-02-20 21:16:07 +01:00
the requested color when it is set to floating, and revert to the default color
when it is tiled again.
2022-11-15 11:22:26 +01:00
2024-02-20 21:16:07 +01:00
Rules will be processed from top to bottom, where the _last_ match will take
precedence. i.e.
2022-11-15 11:22:26 +01:00
```ini
windowrulev2 = opacity 0.8 0.8,class:^(kitty)$
windowrulev2 = opacity 0.5 0.5,floating:1
```
2024-05-28 23:38:33 +02:00
Here, all non-fullscreen kitty windows will have `opacity 0.8` , except if they are floating.
2024-04-21 16:35:48 +02:00
Otherwise, they will have `opacity 0.5` . The rest of the non-fullscreen floating windows will have `opacity 0.5` .
2022-11-15 11:22:26 +01:00
```ini
windowrulev2 = opacity 0.5 0.5,floating:1
windowrulev2 = opacity 0.8 0.8,class:^(kitty)$
```
2024-05-28 23:38:33 +02:00
Here, all kitty windows will have `opacity 0.8` , even if they are floating.
2024-04-21 16:35:48 +02:00
The rest of the floating windows will have `opacity 0.5` .
2022-11-15 11:22:26 +01:00
2024-02-20 21:16:07 +01:00
{{< callout type = info > }}
2022-09-24 15:32:40 +02:00
2024-05-28 23:38:33 +02:00
Opacity is a PRODUCT of all opacities by default. For example, setting `activeopacity` to 0.5
2024-04-21 16:35:48 +02:00
and `opacity` to 0.5 will result in a total opacity of 0.25. You are allowed
2024-02-20 21:16:07 +01:00
to set opacities over 1, but any opacity product over 1 will cause graphical
2024-04-21 16:35:48 +02:00
glitches. For example, using `0.5 * 2 = 1` is fine, but `0.5 * 4 = 2` will cause
graphical glitches. You can put `override` after an opacity value to override it to an exact value
rather than a multiplier. For example, to set active and inactive opacity to 0.8,
and make fullscreen windows fully opaque regardless of other opacity rules:
2024-04-08 00:19:17 +02:00
```ini
windowrulev2 = opacity 0.8 override 0.8 override 1.0 override,^(kitty)$
```
2023-01-25 16:36:45 +01:00
2024-02-20 21:16:07 +01:00
{{< / callout > }}
## Layer Rules
2024-04-21 16:35:48 +02:00
Some things in Wayland are not windows, but layers. That includes, for example:
app launchers, status bars, or wallpapers.
2023-01-25 16:36:45 +01:00
Those have specific rules separate from windows:
```ini
layerrule = rule, namespace
2023-03-18 00:35:17 +01:00
# or
layerrule = rule, address
2023-01-25 16:36:45 +01:00
```
2024-02-20 21:16:07 +01:00
where `rule` is the rule and `namespace` is the namespace regex (find namespaces
in `hyprctl layers` ) or `address` is an address in the form of `address:0x[hex]`
### Rules
2023-01-25 16:36:45 +01:00
| rule | description |
| --- | --- |
2024-04-21 16:35:48 +02:00
| unset | removes all layerRules previously set for a select namespace regex. Please note it has to match _exactly_ . |
2023-01-25 16:36:45 +01:00
| noanim | disables animations |
2023-03-18 00:16:59 +01:00
| blur | enables blur for the layer |
2024-03-25 17:09:38 +01:00
| blurpopups | enables blur for the popups |
2023-06-11 19:31:04 +02:00
| ignorealpha \[a\] | makes blur ignore pixels with opacity of `a` or lower. `a` is float value from 0 to 1. `a = 0` if unspecified. |
| ignorezero | makes blur ignore fully transparent pixels. Same as `ignorealpha 0` . |
2024-04-11 13:41:21 +02:00
| dimaround | dims everything behind the layer |
2023-08-09 22:05:00 +02:00
| xray \[on\] | sets the blur xray mode for a layer. 0 for off, 1 for on, unset for default. |
2024-02-28 16:02:22 +01:00
| animation \[style\] | allows you to set a specific animation style for this layer |