Skip to content

ScreenSplit

ScreenSplit(**config)

Bases: Layout

A layout that allows you to split the screen into separate areas, each of which can be assigned its own layout.

This layout is intended to be used on large monitors where separate layouts may be desirable. However, unlike creating virtual screens, this layout retains the full screen configuration meaning that full screen windows will continue to fill the entire screen.

Each split is defined as a dictionary with the following keys:

  • name: this is used with the ScreenSplit widget (see below)
  • rect: a tuple of (x, y, width, height) with each value being between 0 and 1. These are relative values based on the screen's dimensions e.g. a value of (0.5, 0, 0.5, 1) would define an area starting at the top middle of the screen and extending to the bottom left corner.
  • layout: the layout to occupy the defined split.
  • matches: (optional) list of Match objects which define which windows will open in the defined split.

Different splits can be selected by using the following lazy.layout.next_split() and lazy.layout.previous_split() commands.

To identify which split is active, users can use the ScreenSplit widget will show the name of the split and the relevant layout. Scrolling up and down on the widget will change the active split.

Note

While keybindings will be passed to the active split's layout, bindings using the .when(layout=...) syntax will not be applied as the primary layout is ScreenSplit.

Methods:

  • add_client

    Called whenever a window is added to the group.

  • add_defaults

    Add defaults to this object, overwriting any which already exist.

  • blur

    Called whenever focus is gone from this layout.

  • clone

    Duplicate a layout.

  • command

    Return the command with the given name.

  • commands

    Returns a list of possible commands for this object.

  • configure

    Configure the layout.

  • doc

    Returns the documentation for a specified command name.

  • eval

    Evaluates code in the same context as this function.

  • focus

    Called whenever the focus changes.

  • focus_first

    Called when the first client in Layout shall be focused.

  • focus_last

    Called when the last client in Layout shall be focused.

  • focus_next

    Called when the next client in Layout shall be focused.

  • focus_previous

    Called when the previous client in Layout shall be focused.

  • function

    Call a function with current object as argument.

  • hide

    Called when layout is being hidden.

  • info

    Returns a dictionary of layout information.

  • items

    Build a list of contained items for the given item class.

  • move_window_to_next_split

    Move current window to next split.

  • move_window_to_previous_split

    Move current window to previous split.

  • next

    Move to next client.

  • next_split

    Move to next split.

  • previous

    Move to previous client.

  • previous_split

    Move to previous client.

  • remove

    Called whenever a window is removed from the group.

  • select

    Return a selected object.

  • show

    Called when layout is being shown.

  • swap

    Swap the two given clients c1 and c2.

Attributes:

  • group (_Group) –

    Returns the group this layout is attached to.

group property

group: _Group

Returns the group this layout is attached to.

Layouts start out unattached, and are attached when the group is configured and each layout is cloned for every group.

add_client

add_client(win: Window) -> None

Called whenever a window is added to the group.

Called whether the layout is current or not. The layout should just add the window to its internal datastructures, without mapping or configuring.

add_defaults

add_defaults(defaults)

Add defaults to this object, overwriting any which already exist.

blur

blur() -> None

Called whenever focus is gone from this layout.

clone

clone(group: _Group) -> ScreenSplit

Duplicate a layout.

Make a copy of this layout. This is done to provide each group with a unique instance of every layout.

Parameters:

  • group (_Group) –

    Group to attach new layout instance to.

command

command(name: str) -> Callable | None

Return the command with the given name.

Parameters:

  • name (str) –

    The name of the command to fetch.

commands

commands()

Returns a list of possible commands for this object.

Used by qsh for command completion and online help

configure

configure(client: Window, screen_rect: ScreenRect) -> None

Configure the layout.

This method should:

  • Configure the dimensions and borders of a window using the .place() method.
  • Call either .hide() or .unhide() on the window.

doc

doc(name) -> str

Returns the documentation for a specified command name.

Used by qsh to provide online help.

eval

eval(code: str) -> tuple[bool, str | None]

Evaluates code in the same context as this function.

Return value is tuple (success, result), success being a boolean and result being a string representing the return value of eval, or None if exec was used instead.

focus

focus(client: Window) -> None

Called whenever the focus changes.

focus_first

focus_first() -> Window

Called when the first client in Layout shall be focused.

This method should:

  • Return the first client in Layout, if any.
  • Not focus the client itself, this is done by caller.

focus_last

focus_last() -> Window

Called when the last client in Layout shall be focused.

This method should:

  • Return the last client in Layout, if any.
  • Not focus the client itself, this is done by caller.

focus_next

focus_next(win: Window) -> Window

Called when the next client in Layout shall be focused.

This method should:

  • Return the next client in Layout, if any.
  • Return None if the next client would be the first client.
  • Not focus the client itself, this is done by caller.

Do not implement a full cycle here, because the Groups cycling relies on returning None here if the end of Layout is hit, such that Floating clients are included in cycle.

Parameters:

  • win (Window) –

    The currently focused client.

focus_previous

focus_previous(win: Window) -> Window

Called when the previous client in Layout shall be focused.

This method should:

  • Return the previous client in Layout, if any.
  • Return None if the previous client would be the last client.
  • Not focus the client itself, this is done by caller.

Do not implement a full cycle here, because the Groups cycling relies on returning None here if the end of Layout is hit, such that Floating clients are included in cycle.

Parameters:

  • win (Window) –

    The currently focused client.

function

function(function, *args, **kwargs) -> None

Call a function with current object as argument.

hide

hide() -> None

Called when layout is being hidden.

info

info() -> dict[str, Any]

Returns a dictionary of layout information.

items

items(name: str) -> tuple[bool, list[str | int] | None]

Build a list of contained items for the given item class.

Exposing this allows qsh to navigate the command graph.

Returns a tuple (root, items) for the specified item class, where:

root: True if this class accepts a "naked" specification without an
item seletion (e.g. "layout" defaults to current layout), and False
if it does not (e.g. no default "widget").

items: a list of contained items

move_window_to_next_split

move_window_to_next_split() -> None

Move current window to next split.

move_window_to_previous_split

move_window_to_previous_split() -> None

Move current window to previous split.

next

next() -> None

Move to next client.

next_split

next_split() -> None

Move to next split.

previous

previous() -> None

Move to previous client.

previous_split

previous_split() -> None

Move to previous client.

remove

remove(win: Window) -> None

Called whenever a window is removed from the group.

Called whether the layout is current or not. The layout should just de-register the window from its data structures, without unmapping the window.

Returns the "next" window that should gain focus or None.

select

select(selectors: list[SelectorType]) -> CommandObject

Return a selected object.

Recursively finds an object specified by a list of (name, selector) items.

Raises SelectError if the object does not exist.

show

show(_rect) -> None

Called when layout is being shown.

swap

swap(c1: Window, c2: Window) -> None

Swap the two given clients c1 and c2.