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

Comparing CV/bin/cv (file contents):
Revision 1.1 by root, Sun Nov 2 12:55:41 2003 UTC vs.
Revision 1.4 by root, Mon Nov 3 04:57:43 2003 UTC

1#!/opt/bin/perl 1#!/opt/bin/perl
2 2
3use Gtk2; 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;
7 8
8$VERSION = 0.1; 9$VERSION = 0.1;
9 10
10my $viewer; 11my $viewer;
11
12package schnauzer;
13
14use Glib::Object::Subclass Gtk2::Frame;
15
16sub INIT_INSTANCE {
17 my ($self) = @_;
18
19 $self->add (
20 $self->{list} = new Gtk2::SimpleList "Name" => "text"
21 );
22
23 $self->{list}->signal_connect (cursor_changed => sub {
24 my $row = scalar +($_[0]->get_selection->get_selected_rows)[0]->get_indices;
25 $viewer->load_image ($self->{files}[$row]);
26 });
27}
28
29sub set_files {
30 my ($self, $files) = @_;
31
32 $self->{files} = $files;
33
34 @{$self->{list}{data}} = ();
35
36 my ($dir, $file);
37
38 for (@$files) {
39 if (/^(.*)\/([^\/]*)$/s) {
40 ($dir, $file) = ($1, $2);
41 } else {
42 ($dir, $file) = (".", $_);
43 }
44
45 if (0) {
46 if ($file eq "." or $file eq "..") {
47 } elsif (-f "$dir/.xvpics/$file") {
48 print new_from_file Gtk2::Gdk::Pixbuf "$dir/.xvpics/$file";
49 } else {
50 }
51 }
52
53 push @{$self->{list}{data}}, [$file];
54 }
55}
56
57sub set_dir {
58 my ($self, $dir) = @_;
59
60 my @files;
61
62 opendir my $fh, $dir
63 or die "$dir: $!";
64
65 $self->set_files ([map "$dir/$_", readdir $fh]);
66}
67 12
68package cluster; 13package cluster;
69 14
70use Glib::Object::Subclass Gtk2::Window; 15use Glib::Object::Subclass Gtk2::Window;
71 16
86 $self->{list} = new Gtk2::SimpleList 31 $self->{list} = new Gtk2::SimpleList
87 "#" => "int", 32 "#" => "int",
88 "Name" => "text", 33 "Name" => "text",
89 ); 34 );
90 35
91 $self->{schnauzer} = new schnauzer; 36 $box->add ($self->{schnauzer} = new Gtk2::CV::Schnauzer);
92 $box->add (my $sw = new Gtk2::ScrolledWindow);
93 $sw->add_with_viewport ($self->{schnauzer} = new schnauzer);
94 37
95 $self->{list}->get_column(0)->set_sort_column_id(0); 38 $self->{list}->get_column(0)->set_sort_column_id(0);
96 $self->{list}->get_column(1)->set_sort_column_id(1); 39 $self->{list}->get_column(1)->set_sort_column_id(1);
97 40
98 $self->{list}->signal_connect (cursor_changed => sub { 41 $self->{list}->signal_connect (cursor_changed => sub {
150 } 93 }
151} 94}
152 95
153package main; 96package main;
154 97
155init Gtk2; 98sub new_schnauzer {
99 my $w = new Gtk2::Window;
100 $w->add (my $s = new Gtk2::CV::Schnauzer);
101
102 $s->signal_connect (activate => sub {
103 $viewer->load_image ($_[1]);
104 });
105 $s->signal_connect (key_press_event => \&std_keys);
106 $w->signal_connect (delete_event => sub { $_[0]->destroy });
107 $s->signal_connect (destroy => sub { %{$_[0]} = () });
108
109 $s->set_dir ("/root/pix");
110 $w->show_all;
111
112 $w;
113}
114
115sub std_keys {
116 my $key = $_[1]->keyval;
117
118 my $ctrl = grep $_ eq "control-mask", @{$_[1]->state};
119
120 if ($key == $Gtk2::Gdk::Keysyms{q}) {
121 main_quit Gtk2;
122 } elsif ($ctrl && $key == $Gtk2::Gdk::Keysyms{v}) {
123 new_schnauzer;
124 } else {
125 return 0;
126 }
127
128 1;
129}
156 130
157$viewer = new Gtk2::CV::ImageWindow; 131$viewer = new Gtk2::CV::ImageWindow;
158 132$viewer->signal_connect (key_press_event => \&std_keys);
133$viewer->signal_connect (delete_event => sub { main_quit Gtk2 });
159$viewer->show_all; 134$viewer->show_all;
160 135
161my $cluster = new cluster; 136my $cluster = new cluster;
162
1630 and do {
164 my $w = new Gtk2::Window;
165 $w->add (my $s = new schnauzer);
166 $s->set_dir ("/root/pix");
167 $w->show_all;
168};
169 137
170$cluster->analyse ("/fs/samsung/store-anime-done"); 138$cluster->analyse ("/fs/samsung/store-anime-done");
171$cluster->show_all; 139$cluster->show_all;
172 140
173#$viewer->set (path => "/fs/samsung/store-anime-done/yuumi_kazuaki_-_love_to_hajieki_to_sayonara_to_-_150.jpg"); 141#$viewer->set (path => "/fs/samsung/store-anime-done/yuumi_kazuaki_-_love_to_hajieki_to_sayonara_to_-_150.jpg");

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines