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.17 by root, Fri Nov 7 03:07:01 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 {
14 $w->add (my $s = new Gtk2::CV::Schnauzer); 18 $w->add (my $s = new Gtk2::CV::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 (".");
20 $w->show_all;
21
22 $s; 23 $s;
23} 24}
25
26$schnauzer = new_schnauzer;
27
28my $mainwin = $schnauzer->get_toplevel;
24 29
25sub std_keys { 30sub std_keys {
26 my $key = $_[1]->keyval; 31 my $key = $_[1]->keyval;
27 my $state = $_[1]->state; 32 my $state = $_[1]->state;
28 33
29 my $ctrl = grep $_ eq "control-mask", @$state; 34 my $ctrl = grep $_ eq "control-mask", @$state;
30 35
31 if ($key == $Gtk2::Gdk::Keysyms{q}) { 36 if ($key == $Gtk2::Gdk::Keysyms{q}) {
32 main_quit Gtk2; 37 main_quit Gtk2;
33 } elsif ($ctrl && $key == $Gtk2::Gdk::Keysyms{v}) { 38 } elsif ($ctrl && $key == $Gtk2::Gdk::Keysyms{v}) {
34 new_schnauzer; 39 my $s = new_schnauzer;
40 $s->set_dir (".");
41 $s->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) {
52 $schnauzer->set_paths (\@ARGV); 67 $schnauzer->set_paths (\@ARGV);
53 } 68 }
69} else {
70 $schnauzer->set_dir (".");
54} 71}
55 72
56$viewer->show_all; 73$viewer->show_all;
57 74
58main Gtk2; 75main Gtk2;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines