dwww Home | Show directory contents | Find package

************************************
Hierarchical composition of a window
************************************

Interfaces in GtkAda are built in layers, as in Motif.  For instance, a typical
dialog is basically a Gtk_Window, that in turn contains a Gtk_Box, itself
divided into two boxes and a Gtk_Separator, and so on.

.. image:: boxes.png

Altough this may seem more complicated than setting absolute positions for
children, this is the simplest way to automatically handle the resizing of
windows. Each container that creates a layer knows how it should behave when it
is resized, and how it should move its children.  Thus almost everything is
handled automatically, and you don't have to do anything to support resizing.

If you really insist on moving the children to a specific position, look at the
`Gtk_Fixed` widget and its demo in :file:`testgtk/`. But you really should not
use this container, since you will then have to do everything by hand.

All the containers are demonstrated in :file:`testgtk/`, in the GtkAda
distribution. This should help you understand all the parameters associated
with the containers. It is very important to master these containers, since
using the appropriate containers will make building interfaces a lot easier.

If you look at the widget hierarchy (:ref:`Widgets_Hierarchy`), you can see
that a Gtk_Window inherits from Gtk_Bin, and thus can have only one child. In
most cases, the child of a Gtk_Window will thus be a Gtk_Box, which can have
any number of children.

Some widgets in GtkAda itself are built using this strategy, from the very
basic `Gtk_Button` to the more advanced `Gtk_File_Selection`.

For example, by default a Gtk_Button contains a Gtk_Label, which displays the
text of the button (like 'OK' or 'Cancel').

However, it is easy to put a pixmap in a button instead. When you create the
button, do not specify any label. Thus, no child will be added, and you can
give it your own. See :file:`testgtk/create_pixmap.adb` for an example on how
to do that.

Generated by dwww version 1.15 on Thu May 23 23:49:47 CEST 2024.