NAME

Gapp::Layout - Define how widgets are displayed

SYNOPSIS

  package My::Custom::Layout;
  use Gapp::Layout;
  extends 'Gapp::Layout::Default';
  
  # center all entry texts
  style 'Gapp::Entry', sub {
      ( $layout, $widget ) = @_;
      $widget->properties->{xalign} ||= .5 ;
      $layout->parent->style_widget( $widget );
  };
  
  # add a widget to bottom of all vboxes
  build 'Gapp::VBox', sub {
      ( $layout, $widget ) = @_;
      $footer  = Gtk2::Label->new( 'footer!, 0, 0, 0 );        
      $widget->gtk_widget->pack_end( $footer,  );
      $layout->parent->build_widget( $widget );
  };
  
  # specify how buttons are packed into a button box
  add 'Gapp::Button', to 'Gapp::HButtonBox', sub {
      my ($l, $w, $c) = @_;
      $c->gtk_widget->pack_end(
          $w->gtk_widget,
          $w->expand,
          $w->fill,
          $w->padding
      );
  };

DESCRIPTION

Gapp::Layout is a library for building layouts. Creating a layout allows you to customize the appearance of your widgets across your program in one place. This also has the effect of keeping your gui design, application code, and data structures separate.

Layouts are sub-classable and provide fine grained control of your program apearance with a simple interface.

CREATING A LAYOUT

A layout is defined in a package. It is recomended that you inherit from Gapp::Layout::Default.

package My::Custom::Layout;
use Gapp::Layout;
extends 'Gapp::Layout::Default';

Stylers

Stylers are used to alter any of the Gapp::Widget attributes before the Gtk+ widget is constructed. The example below centers the the text in an entry field if no xalign has been set. If you want to alter the Gtk+ widget once it has been constructed, you want to use a builder.

# center all entry texts
style 'Gapp::Entry', sub {

  ( $layout, $widget ) = @_;

  $widget->{properties}{xalign} if ! defined $widget->{properties}{xalign};

  $layout->parent->style_widget( $widget );

};

Builders

Builders are used to customize the Gtk+ widget once it is has been. Use the builder to maniplulate things at the Gtk2 level.

# add a widget to bottom of all vboxes
build 'Gapp::VBox', sub {

    ( $layout, $widget ) = @_;

    $footer  = Gtk2::Label->new( 'footer!, 0, 0, 0 );

    $widget->gtk_widget->pack_end( $footer,  );

    $layout->parent->build_widget( $widget );

};

Packers

Packers are used to position widgets in containers.

# specify how buttons are packed into a button box
add 'Gapp::Button', to 'Gapp::HButtonBox', sub {
    my ( $layout, $widget, $container ) = @_;
    $container->gtk_widget->pack_end(
        $widget->gtk_widget,
        $widget->expand,
        $widget->fill,
        $widget->padding
    );
};

The above example is pretty specific, but you can define something much more general. Take the example below:

# widgets always fill/expand vboxs
add 'Gapp::Widget', to 'Gapp::VBox', sub {
    my ( $layout, $widget, $container ) = @_;
    $container->gtk_widget->pack_end(
        $widget->gtk_widget,
        1,
        1, #fill
        $widget->padding
    );
};

This will make any Gapp::Widget in a Gapp::VBox expand and fill. You could then override this, for a specific widget:

# widgets always fill/expand vboxs
add 'Gapp::Button', to 'Gapp::VBox', sub {
    my ( $layout, $widget, $container ) = @_;
    $container->gtk_widget->pack_end(
        $widget->gtk_widget,
        $widget->expand,
        $widget->fill,
        $widget->padding
    );
};

EXPORTED FUNCTIONS

add $widget_class, to $widget_class, \&add_func

Set the packer for this widget\container combination.

build $widget_class, \&build_func

Set the builder for this widget.

extends $class

Use this if you want to subclass another layout.

AUTHOR

Jeffrey Ray Hallock <jeffrey.hallock at gmail dot com>

COPYRIGHT

Copyright (c) 2011 Jeffrey Ray Hallock.
This program is free software; you can redistribute it and/or
modify it under the same terms as Perl itself.