Client-side decoration explained

Client-side decoration (CSD) is the concept of allowing a graphical application software to be responsible for drawing its own window decorations, historically the responsibility of the window manager.[1]

Sometimes client-side decoration is used to refer to the applications that don't have a traditional title bar. However, this is a misuse of the phrase, as even applications that have a basic title bar can be client side decorated.[2]

By using client-side decoration rather than traditional server-side decoration, applications are able to draw their own title bar, which allows for a wide range of possibilities to customize window decorations and add additional functionality (graphical control elements) into what otherwise would be a typical window manager bar with much empty space in the maximized windows.[3]

Terminology

The term Client-Side Decoration comes from the X Window System, where a client is the application which renders a window and sends it to the X server that controls the display. The alternative is called Server-Side Decoration (SSD) even though on X the decoration is drawn by the window manager, which is not actually the "server". Those terms are also used in Wayland, where a client is the application, which renders a window and sends it to the Wayland server, which controls the display and also functions as a compositing window manager.

Implementations

Widget toolkits

GTK

GTK was the first GUI toolkit on Linux that implemented client-side decoration using the GtkHeaderBar widget.[4]

GtkHeaderBar merges the title bar, menu bar and tool bar into one unified horizontal bar in order to give more space to the application content, potentially reducing the amount of wasted space by showing empty bars. This can help to achieve a flexible UI and consistent UX across different computer form factors from desktop systems to small form factor devices by removing the traditional desktop-oriented parts from applications. These have first-class support in GNOME Shell and are widely used by GNOME applications.

UWP

Universal Windows Platform applications can choose to draw their own title bars.[5]

macOS

In macOS, AppKit applications use client-side decoration when using the NSWindow widget.[6]

Electron

Electron has the option to use a frame-less window (without toolbar, menu bar, tabs), however the application is responsible for drawing its own shadows.[7]

Deepin Tool Kit

Deepin Tool Kit is a small modified widget toolkit based on Qt5, it is used by Deepin Desktop Environment.

Applications

Notable applications with client-side decoration:

Display servers

Wayland

Wayland was designed to have client-side decorations (including the shadows of windows) by default, but has an optional protocol, known as xdg-decoration, which allows an application (client) to query whether the window manager supports server-side decoration and if so for a client to request it. Mutter, the compositor used by GNOME Shell, under Wayland only supports client side decoration,[8] whilst KWin supports both client and server side decoration.

Limitations

If the application hangs, the user cannot close it by clicking the close button in the window frame.[9]

History

See also

Notes and References

  1. Web site: Client-side decorations, continued. blogs.gnome.org. en-US. 2019-01-17.
  2. Web site: A small note on window decorations Florian Müllner. en-US. 2019-11-13.
  3. Web site: The CSD Initiative Is Pushing For Apps To Abandon Title Bars In Favor Of Header Bars - Phoronix . . 2018-01-28.
  4. Web site: GtkHeaderBar: GTK+ 3 Reference Manual . developer.gnome.org . 2019-01-17.
  5. Web site: Title bar customization - Windows UWP applications . mijacobs . docs.microsoft.com . en-us . 2019-01-17.
  6. Web site: NSWindow - AppKit Apple Developer Documentation . developer.apple.com . 2019-06-07.
  7. Web site: Frameless Window Electron . electronjs.org . en-US . 2019-01-17.
  8. Web site: Introducing the CSD Initiative – Space and Meaning. Bernard, Tobias. GNOME. 2018-01-28.
  9. Web site: Zahorodnii . Vlad . 2020-07-23 . CSD support in KWin . 2024-03-05 . Vlad Zahorodnii's Blog . en.
  10. Web site: GTK+ 3.10 released [LWN.net] ]. lwn.net . 2019-01-17.