wl_output¤
wayland.wl_output ¤
Compositor output region
An output describes part of the compositor geometry. The compositor works in the 'compositor coordinate system' and an output corresponds to a rectangular area in that space that is actually visible. This typically corresponds to a monitor that displays part of the compositor space. This object is published as global during start up, or when a monitor is hotplugged.
Methods:
-
release
–Release the output object
-
on_geometry
–Properties of the output.
-
on_mode
–Advertise available modes for the output.
-
on_done
–Sent all information about output.
-
on_scale
–Output scaling properties.
-
on_name
–Name of this output.
-
on_description
–Human-readable description of this output.
subpixel ¤
Subpixel geometry information
This enumeration describes how the physical pixels on an output are laid out.
-
unknown
–Unknown geometry -
none
–No geometry -
horizontal_rgb
–Horizontal rgb -
horizontal_bgr
–Horizontal bgr -
vertical_rgb
–Vertical rgb -
vertical_bgr
–Vertical bgr
transform ¤
Transformation applied to buffer contents
This describes transformations that clients and compositors apply to buffer contents.
The flipped values correspond to an initial flip around a vertical axis followed by rotation.
The purpose is mainly to allow clients to render accordingly and tell the compositor, so that for fullscreen surfaces, the compositor will still be able to scan out directly from client surfaces.
-
normal
–No transform -
transform_90
–90 degrees counter-clockwise -
transform_180
–180 degrees counter-clockwise -
transform_270
–270 degrees counter-clockwise -
flipped
–180 degree flip around a vertical axis -
flipped_90
–Flip and rotate 90 degrees counter-clockwise -
flipped_180
–Flip and rotate 180 degrees counter-clockwise -
flipped_270
–Flip and rotate 270 degrees counter-clockwise
mode ¤
events
geometry ¤
geometry(
x: int,
y: int,
physical_width: int,
physical_height: int,
subpixel: subpixel,
make: str,
model: str,
transform: transform,
) -> None
Properties of the output
The geometry event describes geometric properties of the output. The event is sent when binding to the output object and whenever any of the properties change.
The physical size can be set to zero if it doesn't make sense for this output (e.g. for projectors or virtual outputs).
The geometry event will be followed by a done event (starting from version 2).
Clients should use wl_surface.preferred_buffer_transform instead of the transform advertised by this event to find the preferred buffer transform to use for a surface.
Note: wl_output only advertises partial information about the output position and identification. Some compositors, for instance those not implementing a desktop-style output layout or those exposing virtual outputs, might fake this information. Instead of using x and y, clients should use xdg_output.logical_position. Instead of using make and model, clients should use name and description.
Parameters:
-
x
¤int
) –X position within the global compositor space
-
y
¤int
) –Y position within the global compositor space
-
physical_width
¤int
) –Width in millimeters of the output
-
physical_height
¤int
) –Height in millimeters of the output
-
subpixel
¤subpixel
) –Subpixel orientation of the output
-
make
¤str
) –Textual description of the manufacturer
-
model
¤str
) –Textual description of the model
-
transform
¤transform
) –Additional transformation applied to buffer contents during presentation
mode ¤
Advertise available modes for the output
The mode event describes an available mode for the output.
The event is sent when binding to the output object and there will always be one mode, the current mode. The event is sent again if an output changes mode, for the mode that is now current. In other words, the current mode is always the last mode that was received with the current flag set.
Non-current modes are deprecated. A compositor can decide to only advertise the current mode and never send other modes. Clients should not rely on non-current modes.
The size of a mode is given in physical hardware units of the output device. This is not necessarily the same as the output size in the global compositor space. For instance, the output may be scaled, as described in wl_output.scale, or transformed, as described in wl_output.transform. Clients willing to retrieve the output size in the global compositor space should use xdg_output.logical_size instead.
The vertical refresh rate can be set to zero if it doesn't make sense for this output (e.g. for virtual outputs).
The mode event will be followed by a done event (starting from version 2).
Clients should not use the refresh rate to schedule frames. Instead, they should use the wl_surface.frame event or the presentation-time protocol.
Note: this information is not always meaningful for all outputs. Some compositors, such as those exposing virtual outputs, might fake the refresh rate or the size.
Parameters:
done ¤
done() -> None
Sent all information about output
This event is sent after all other properties have been sent after binding to the output object and after any other property changes done after that. This allows changes to the output properties to be seen as atomic, even if they happen via multiple events.
scale ¤
Output scaling properties
This event contains scaling geometry information that is not in the geometry event. It may be sent after binding the output object or if the output scale changes later. The compositor will emit a non-zero, positive value for scale. If it is not sent, the client should assume a scale of 1.
A scale larger than 1 means that the compositor will automatically scale surface buffers by this amount when rendering. This is used for very high resolution displays where applications rendering at the native resolution would be too small to be legible.
Clients should use wl_surface.preferred_buffer_scale instead of this event to find the preferred buffer scale to use for a surface.
The scale event will be followed by a done event.
Parameters:
name ¤
Name of this output
Many compositors will assign user-friendly names to their outputs, show them to the user, allow the user to refer to an output, etc. The client may wish to know this name as well to offer the user similar behaviors.
The name is a UTF-8 string with no convention defined for its contents. Each name is unique among all wl_output globals. The name is only guaranteed to be unique for the compositor instance.
The same output name is used for all clients for a given wl_output global. Thus, the name can be shared across processes to refer to a specific wl_output global.
The name is not guaranteed to be persistent across sessions, thus cannot be used to reliably identify an output in e.g. configuration files.
Examples of names include 'HDMI-A-1', 'WL-1', 'X11-1', etc. However, do not assume that the name is a reflection of an underlying DRM connector, X11 connection, etc.
The name event is sent after binding the output object. This event is only sent once per output object, and the name does not change over the lifetime of the wl_output global.
Compositors may re-use the same output name if the wl_output global is destroyed and re-created later. Compositors should avoid re-using the same name if possible.
The name event will be followed by a done event.
Parameters:
description ¤
description(description: str) -> None
Human-readable description of this output
Many compositors can produce human-readable descriptions of their outputs. The client may wish to know this description as well, e.g. for output selection purposes.
The description is a UTF-8 string with no convention defined for its contents. The description is not guaranteed to be unique among all wl_output globals. Examples might include 'Foocorp 11" Display' or 'Virtual X11 output via :1'.
The description event is sent after binding the output object and whenever the description changes. The description is optional, and may not be sent at all.
The description event will be followed by a done event.
Parameters:
release ¤
release() -> None
Release the output object
Using this request a client can tell the server that it is not going to use the output object anymore.
on_geometry ¤
on_geometry(
x: int,
y: int,
physical_width: int,
physical_height: int,
subpixel: subpixel,
make: str,
model: str,
transform: transform,
) -> None
Properties of the output.
Override to handle wayland.wl_output.events.geometry
.
on_mode ¤
Advertise available modes for the output.
Override to handle wayland.wl_output.events.mode
.
on_done ¤
on_done() -> None
Sent all information about output.
Override to handle wayland.wl_output.events.done
.
on_scale ¤
on_scale(factor: int) -> None
Output scaling properties.
Override to handle wayland.wl_output.events.scale
.
on_name ¤
on_name(name: str) -> None
Name of this output.
Override to handle wayland.wl_output.events.name
.
on_description ¤
on_description(description: str) -> None
Human-readable description of this output.
Override to handle wayland.wl_output.events.description
.