The Perl and Raku Conference 2025: Greenville, South Carolina - June 27-29 Learn more

NAME

Tk::GridColumns - Columns widget for Tk using Tk::grid

SYNOPSIS

my $gc = $top->GridColumns( ... );
...
$gc->refresh;

DESCRIPTION

A Tk::GridColumns is similar to a Tk::HList but its implementation gives you more freedom: The header and data information is stored in two array refs, so that you just have to adjust these and then ->refresh() the widget to make the changes visible. You can define how much space each column will take (grid: -weight). You can change almost everything: define your own item bindings ( Example: Editable), change the appearance of the widget very easily using default attributes for the column buttons and the data items (Example: Appearance), add scrollbars to the widget (Example: Scrolled), ...

Take a look at the example code to discover if this module is an appropriate solution for your tasks.

EXPORT

Nothing

EXAMPLES

Simple

#!/usr/bin/perl
use strict;
use Tk;
my $mw = tkinit( -title => 'Tk::GridColumns example -- Simple' );
my $gc = $mw->GridColumns(
-data => [ map { [ $_, chr 97 + rand $_*2 ] } 1 .. 10 ], # some data
-columns => \my @columns, # need to define columns after creating the
# object, because of the sort '-command'
)->pack(
-fill => 'both',
-expand => 1,
);
@columns = (
{
-text => 'Number',
-command => $gc->sort_cmd( 0, 'num' ),
},
{
-text => 'String',
-command => $gc->sort_cmd( 1, 'abc' ),
-weight => 1, # this columns gets the remaining space
},
);
$gc->refresh;
MainLoop;

Scrolled

#!/usr/bin/perl
use strict;
use Tk;
my $mw = tkinit( -title => 'Tk::GridColumns example -- Scrolled' );
$mw->geometry( "=300x200+100+100" );
my $gc = $mw->Scrolled(
'GridColumns' =>
-scrollbars => 'ose',
-data => [ map { [ $_, chr 97 + rand $_+5 ] } 1 .. 20 ],
-columns => \my @columns,
)->pack(
-fill => 'both',
-expand => 1,
)->Subwidget( 'scrolled' ); # do not forget this one ;)
@columns = (
{
-text => 'Number',
-command => $gc->sort_cmd( 0, 'num' ),
},
{
-text => 'String',
-command => $gc->sort_cmd( 1, 'abc' ),
-weight => 1,
},
);
$gc->refresh;
MainLoop;

Editable

#!/usr/bin/perl
use strict;
use Tk;
my $mw = tkinit( -title => 'Tk::GridColumns example -- Editable' );
my $gc = $mw->GridColumns(
-data => \my @data, # ease the data access
-columns => \my @columns,
-item_bindings => { '<Double-ButtonPress-1>' => \&edit_item },
)->pack(
-fill => 'both',
-expand => 1,
);
@columns = (
{
-text => 'Number',
-command => $gc->sort_cmd( 0, 'num' ),
},
{
-text => 'String',
-command => $gc->sort_cmd( 1, 'abc' ),
-weight => 1,
},
);
@data = map { [ $_, chr 97 + rand $_*2 ] } 1 .. 10;
$gc->refresh;
MainLoop;
sub edit_item {
my( $self, $w, $row, $col ) = @_;
$w->destroy; # destroy the widget that currently displays the data
my $entry = $self->Entry(
-textvariable => \$data[$row][$col],
-width => 0,
)->grid(
-row => $row+1,
-column => $col,
-sticky => 'nsew',
);
$entry->selectionRange( 0, 'end' );
$entry->focus; # so the user can instantly start editing
$entry->bind( '<Return>' => sub { $self->refresh_items } );
$entry->bind( '<FocusOut>' => sub { $self->refresh_items } );
} # edit_item

Appearance

#!/usr/bin/perl
use strict;
use Tk;
my $mw = tkinit( -title => 'Tk::GridColumns example -- Appearance' );
my $gc = $mw->GridColumns(
-data => [ map { [ $_, chr 97 + rand $_*2 ] } 1 .. 10 ],
-columns => \my @columns,
-bg => 'black',
-colattr => {
-fg => 'green', -bg => 'black',
-activeforeground => 'green',
-activebackground => 'black',
},
-itemattr => { -fg => 'green', -bg => 'black' },
)->pack(
-fill => 'both',
-expand => 1,
);
@columns = (
{
-text => 'Number',
-command => $gc->sort_cmd( 0, 'num' ),
},
{
-text => 'String',
-command => $gc->sort_cmd( 1, 'abc' ),
-weight => 1,
},
);
$gc->refresh;
MainLoop;

TODO

There is much work to do and now I found some time to update the module. And hopefully I will update it more often in the next months :)

* Selection:
- select() and deselect() that react on the -selectmode
- select_item(), select_row(), select_col() and the deselect() ones
- 'from' and 'to' parameters for the select() and deselect() routines
* Refreshing:
- refresh_item(), refresh_row(), refresh_col() so that you can refresh
only the parts that need to get refreshed
* more documentation

SEE ALSO

Tk, Tk::grid, Tk::Pane, Tk::Scrolled, Tk::HList, Tk::Columns, Tk::MListbox, Tk::Table, Tk::TableMatrix

AUTHOR

Matthias Wienand, <matthias.wienand@googlemail.com>

COPYRIGHT AND LICENSE

Copyright (C) 2009 by Matthias Wienand

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.10.0 or, at your option, any later version of Perl 5 you may have available.