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.