Window


Object Hierarchy:

Hdy.Window Hdy.Window Hdy.Window Gtk.Window Gtk.Window Gtk.Window->Hdy.Window Gtk.Bin Gtk.Bin Gtk.Bin->Gtk.Window Gtk.Container Gtk.Container Gtk.Container->Gtk.Bin Gtk.Widget Gtk.Widget Gtk.Widget->Gtk.Container GLib.InitiallyUnowned GLib.InitiallyUnowned GLib.InitiallyUnowned->Gtk.Widget GLib.Object GLib.Object GLib.Object->GLib.InitiallyUnowned Atk.Implementor Atk.Implementor Atk.Implementor->Hdy.Window Atk.Implementor->Gtk.Window Atk.Implementor->Gtk.Bin Atk.Implementor->Gtk.Container Atk.Implementor->Gtk.Widget Gtk.Buildable Gtk.Buildable Gtk.Buildable->Hdy.Window Gtk.Buildable->Gtk.Window Gtk.Buildable->Gtk.Bin Gtk.Buildable->Gtk.Container Gtk.Buildable->Gtk.Widget

Description:

[ CCode ( type_id = "hdy_window_get_type ()" ) ]
[ Version ( since = "1.0" ) ]
public class Window : Window, Implementor, Buildable

A freeform window.

The `HdyWindow` widget is a subclass of [[email protected]] which has no titlebar area and provides rounded corners on all sides, ensuring they can never be overlapped by the content. This makes it safe to use headerbars in the content area as follows:

```xml <object class="HdyWindow"/> <child> <object class="GtkBox"> <property name="visible">True</property > <property name="orientation">vertical</property> <child> <object class="HdyHeaderBar"> <property name="visible">True</property> <property name="show-close-button">True</property> </object> </child> <child> <!-- ... --> </child> </object> </child> </object> ```

It's recommended to use [class@HeaderBar] with `HdyWindow`, as unlike [[email protected]] it remains draggable inside the window. Otherwise, [class@WindowHandle] can be used.

`HdyWindow` allows to easily implement titlebar autohiding by putting the headerbar inside a [[email protected]], and to show titlebar above content by putting it into a [[email protected]] instead of [[email protected]].

If the window has a [[email protected]], it may bring a slight performance regression when the window is not fullscreen, tiled or maximized.

Using [[email protected]_titlebar] and [[email protected]_titlebar] is not supported and will result in a crash.

CSS nodes

`HdyWindow` has a main CSS node with the name `window` and style classes `.background`, `.csd` and `.unified`.

The `.solid-csd` style class on the main node is used for client-side decorations without invisible borders.

`HdyWindow` also represents window states with the following style classes on the main node: `.tiled`, `.maximized`, `.fullscreen`.

It contains the subnodes decoration for window shadow and/or border, decoration-overlay for the sheen on top of the window, `widget.titlebar`, and deck, which contains the child inside the window.

All known sub-classes:

Namespace: Hdy
Package: libhandy-1

Content:

Creation methods:

Inherited Members:

All known members inherited from class Gtk.Window
All known members inherited from class Gtk.Bin
All known members inherited from class Gtk.Container
All known members inherited from class Gtk.Widget
All known members inherited from class GLib.Object
All known members inherited from interface Atk.Implementor
All known members inherited from interface Gtk.Buildable



2022 vala-language.org