ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/CV/bin/cv
(Generate patch)

Comparing CV/bin/cv (file contents):
Revision 1.12 by root, Wed Nov 5 01:30:33 2003 UTC vs.
Revision 1.16 by root, Fri Nov 7 02:41:06 2003 UTC

3use Gtk2 -init; 3use Gtk2 -init;
4use Gtk2::Gdk::Keysyms; 4use Gtk2::Gdk::Keysyms;
5 5
6use Gtk2::CV::ImageWindow; 6use Gtk2::CV::ImageWindow;
7use Gtk2::CV::Schnauzer; 7use Gtk2::CV::Schnauzer;
8
9use Gtk2::CV;
10
11Gtk2::Rc->parse (Gtk2::CV::find_rcfile "gtkrc");
8 12
9my $viewer; 13my $viewer;
10my $schnauzer; 14my $schnauzer;
11 15
12sub new_schnauzer { 16sub new_schnauzer {
15 19
16 $s->signal_connect (activate => sub { $viewer->load_image ($_[1]) }); 20 $s->signal_connect (activate => sub { $viewer->load_image ($_[1]) });
17 $s->signal_connect_after (key_press_event => \&std_keys); 21 $s->signal_connect_after (key_press_event => \&std_keys);
18 22
19 $s->set_dir ("."); 23 $s->set_dir (".");
20 $w->show_all;
21 24
22 $s; 25 $s;
23} 26}
27
28$schnauzer = new_schnauzer;
29
30my $mainwin = $schnauzer->get_toplevel;
24 31
25sub std_keys { 32sub std_keys {
26 my $key = $_[1]->keyval; 33 my $key = $_[1]->keyval;
27 my $state = $_[1]->state; 34 my $state = $_[1]->state;
28 35
29 my $ctrl = grep $_ eq "control-mask", @$state; 36 my $ctrl = grep $_ eq "control-mask", @$state;
30 37
31 if ($key == $Gtk2::Gdk::Keysyms{q}) { 38 if ($key == $Gtk2::Gdk::Keysyms{q}) {
32 main_quit Gtk2; 39 main_quit Gtk2;
33 } elsif ($ctrl && $key == $Gtk2::Gdk::Keysyms{v}) { 40 } elsif ($ctrl && $key == $Gtk2::Gdk::Keysyms{v}) {
34 new_schnauzer; 41 new_schnauzer->get_toplevel->show_all;
35 } else { 42 } else {
43 $mainwin->show_all;
36 $schnauzer->handle_key ($key, $state); 44 $schnauzer->handle_key ($key, $state);
37 } 45 }
38 46
39 1; 47 1;
40} 48}
41 49
42$viewer = new Gtk2::CV::ImageWindow; 50$viewer = new Gtk2::CV::ImageWindow;
51
52$viewer->set_title ("CV");
53
43$viewer->signal_connect (key_press_event => \&std_keys); 54$viewer->signal_connect (key_press_event => \&std_keys);
44$viewer->signal_connect (delete_event => sub { main_quit Gtk2 }); 55$viewer->signal_connect (delete_event => sub { main_quit Gtk2 });
45 56
46$schnauzer = new_schnauzer; 57$viewer->signal_connect (button3_press_event => sub {
58 $mainwin->visible
59 ? $mainwin->hide
60 : $mainwin->show_all;
61});
47 62
48if (@ARGV) { 63if (@ARGV) {
49 $viewer->load_image ($ARGV[0]); 64 $viewer->load_image ($ARGV[0]);
50 65
51 if (@ARGV > 1) { 66 if (@ARGV > 1) {

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines