ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/DC/Item.pm
(Generate patch)

Comparing deliantra/Deliantra-Client/DC/Item.pm (file contents):
Revision 1.7 by elmex, Tue Aug 14 12:02:14 2007 UTC vs.
Revision 1.14 by root, Sun Jan 11 23:45:52 2009 UTC

1package CFPlus::Item; 1package DC::Item;
2 2
3use strict; 3use strict;
4use utf8; 4use utf8;
5use Encode; 5use Encode;
6 6
7use Crossfire::Protocol::Constants; 7use Deliantra::Protocol::Constants;
8 8
9my $last_enter_count = 1; 9my $last_enter_count = 1;
10 10
11sub desc_string { 11sub desc_string {
12 my ($self) = @_; 12 my ($self) = @_;
43} 43}
44 44
45sub do_n_dialog { 45sub do_n_dialog {
46 my ($cb) = @_; 46 my ($cb) = @_;
47 47
48 my $w = new CFPlus::UI::Toplevel 48 my $w = new DC::UI::Toplevel
49 on_delete => sub { $_[0]->destroy; 1 }, 49 on_delete => sub { $_[0]->destroy; 1 },
50 has_close_button => 1, 50 has_close_button => 1,
51 ; 51 ;
52 52
53 $w->add (my $vb = new CFPlus::UI::VBox x => "center", y => "center"); 53 $w->add (my $vb = new DC::UI::VBox x => "center", y => "center");
54 $vb->add (new CFPlus::UI::Label text => "Enter item count:"); 54 $vb->add (new DC::UI::Label text => "Enter item count:");
55 $vb->add (my $entry = new CFPlus::UI::Entry 55 $vb->add (my $entry = new DC::UI::Entry
56 text => $last_enter_count, 56 text => $last_enter_count,
57 on_activate => sub { 57 on_activate => sub {
58 my ($entry) = @_; 58 my ($entry) = @_;
59 $last_enter_count = $entry->get_text; 59 $last_enter_count = $entry->get_text;
60 $cb->($last_enter_count); 60 $cb->($last_enter_count);
67 ); 67 );
68 $entry->grab_focus; 68 $entry->grab_focus;
69 $w->show; 69 $w->show;
70} 70}
71 71
72my $bg_cursed = [1 , 0 , 0, 0.5];
73my $bg_magic = [0.2, 0.2, 1, 0.5];
74
72sub update_widgets { 75sub update_widgets {
73 my ($self) = @_; 76 my ($self) = @_;
74 77
75 # necessary to avoid cyclic references 78 # necessary to avoid cyclic references
76 CFPlus::weaken $self; 79 DC::weaken $self;
77 80
78 my $button_cb = sub { 81 my $button_cb = sub {
79 my (undef, $ev, $x, $y) = @_; 82 my (undef, $ev, $x, $y) = @_;
80 83
81 my $targ = $::CONN->{player}{tag}; 84 my $targ = $::CONN->{player}{tag};
82 85
83 if ($self->{container} == $::CONN->{player}{tag}) { 86 if ($self->{container} == $::CONN->{player}{tag}) {
84 $targ = $::CONN->{open_container}; 87 $targ = $::CONN->{open_container};
85 } 88 }
86 89
87 if (($ev->{mod} & CFPlus::KMOD_SHIFT) && $ev->{button} == 1) { 90 if (($ev->{mod} & DC::KMOD_SHIFT) && $ev->{button} == 1) {
88 $::CONN->send ("move $targ $self->{tag} 0") 91 $::CONN->send ("move $targ $self->{tag} 0")
89 if $targ || !($self->{flags} & F_LOCKED); 92 if $targ || !($self->{flags} & F_LOCKED);
90 } elsif (($ev->{mod} & CFPlus::KMOD_SHIFT) && $ev->{button} == 2) { 93 } elsif (($ev->{mod} & DC::KMOD_SHIFT) && $ev->{button} == 2) {
91 $self->{flags} & F_LOCKED 94 $self->{flags} & F_LOCKED
92 ? $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) 95 ? $::CONN->send ("lock " . pack "CN", 0, $self->{tag})
93 : $::CONN->send ("lock " . pack "CN", 1, $self->{tag}) 96 : $::CONN->send ("lock " . pack "CN", 1, $self->{tag})
94 } elsif ($ev->{button} == 1) { 97 } elsif ($ev->{button} == 1) {
95 $::CONN->send ("examine $self->{tag}"); 98 $::CONN->send ("examine $self->{tag}");
99 my $move_prefix = $::CONN->{open_container} ? 'put' : 'drop'; 102 my $move_prefix = $::CONN->{open_container} ? 'put' : 'drop';
100 if ($self->{container} == $::CONN->{open_container}) { 103 if ($self->{container} == $::CONN->{open_container}) {
101 $move_prefix = "take"; 104 $move_prefix = "take";
102 } 105 }
103 106
104 my $shortname = CFPlus::shorten $self->{name}, 14; 107 my $shortname = DC::shorten $self->{name}, 14;
105 108
106 my @menu_items = ( 109 my @menu_items = (
107 ["examine", sub { $::CONN->send ("examine $self->{tag}") }], 110 ["examine", sub { $::CONN->send ("examine $self->{tag}") }],
108 ["mark", sub { $::CONN->send ("mark ". pack "N", $self->{tag}) }], 111 ["mark", sub { $::CONN->send ("mark ". pack "N", $self->{tag}) }],
109 ["ignite/thaw", # first try of an easier use of flint&steel 112 ["ignite/thaw", # first try of an easier use of flint&steel
145 do_n_dialog (sub { $::CONN->send ("move $targ $self->{tag} $_[0]") }) 148 do_n_dialog (sub { $::CONN->send ("move $targ $self->{tag} $_[0]") })
146 } 149 }
147 ] 150 ]
148 ) 151 )
149 ), 152 ),
150 ["bind <i>apply $shortname</i> to a key" => sub { CFPlus::Macro::quick_macro ["apply $self->{name}"] }], 153 ["bind <i>apply $shortname</i> to a key" => sub { DC::Macro::quick_macro ["apply $self->{name}"] }],
151 ); 154 );
152 155
153 CFPlus::UI::Menu->new (items => \@menu_items)->popup ($ev); 156 DC::UI::Menu->new (items => \@menu_items)->popup ($ev);
154 } 157 }
155 158
156 1 159 1
157 }; 160 };
158 161
163 . "Middle click - apply\n" 166 . "Middle click - apply\n"
164 . "Shift-Middle click - lock/unlock\n" 167 . "Shift-Middle click - lock/unlock\n"
165 . "Right click - further options" 168 . "Right click - further options"
166 . "</small>\n"; 169 . "</small>\n";
167 170
168 my $bg = $self->{flags} & F_CURSED ? [1 , 0 , 0, 0.5] 171 my $bg = $self->{flags} & F_CURSED ? $bg_cursed
169 : $self->{flags} & F_MAGIC ? [0.2, 0.2, 1, 0.5] 172 : $self->{flags} & F_MAGIC ? $bg_magic
170 : undef; 173 : undef;
171 174
172 $self->{face_widget} ||= new CFPlus::UI::Face 175 my $desc = DC::Item::desc_string $self;
173 can_events => 1, 176 my $face_tooltip = "<b>$desc</b>\n\n$tooltip_std";
174 can_hover => 1, 177
175 anim => $self->{anim}, 178 if (my $face = $self->{face_widget}) {
176 animspeed => $self->{animspeed}, # TODO# must be set at creation time 179 if ($face->{bg} != $bg) {
177 on_button_down => $button_cb, 180 $face->{bg} = $bg;
178 ; 181 $face->update;
179 $self->{face_widget}{bg} = $bg; 182 }
180 $self->{face_widget}{face} = $self->{face}; 183
181 $self->{face_widget}{anim} = $self->{anim}; 184 $face->set_face ($self->{face}) if $face->{face} != $self->{face};
182 $self->{face_widget}{animspeed} = $self->{animspeed}; 185 $face->set_anim ($self->{anim}) if $face->{anim} != $self->{anim};
183 $self->{face_widget}->set_tooltip ( 186 $face->set_animspeed ($self->{animspeed}) if $face->{animspeed} != $self->{animspeed};
187
188 #$face->set_tooltip (
184 "<b>Face/Animation.</b>\n" 189 # "<b>Face/Animation.</b>\n"
185 . "Item uses face #$self->{face}. " 190 # . "Item uses face #$self->{face}. "
186 . ($self->{animspeed} ? "Item uses animation #$self->{anim} at " . (1 / $self->{animspeed}) . "fps. " : "Item is not animated. ") 191 # . ($self->{animspeed} ? "Item uses animation #$self->{anim} at " . (1 / $self->{animspeed}) . "fps. " : "Item is not animated. ")
187 . "\n\n$tooltip_std" 192 # . "\n\n$tooltip_std"
188 ); 193 #);
194 $face->set_tooltip ($face_tooltip);
195 } else {
196 $self->{face_widget} = new DC::UI::Face
197 can_events => 1,
198 can_hover => 1,
199 bg => $bg,
200 face => $self->{face},
201 anim => $self->{anim},
202 animspeed => $self->{animspeed}, # TODO# must be set at creation time
203 tooltip => $face_tooltip,
204 on_button_down => $button_cb,
205 ;
206 }
189 207
190 $self->{desc_widget} ||= new CFPlus::UI::Label 208 $self->{desc_widget} ||= new DC::UI::Label
191 can_events => 1, 209 can_events => 1,
192 can_hover => 1, 210 can_hover => 1,
193 ellipsise => 2, 211 ellipsise => 2,
194 align => -1, 212 align => 0,
195 213
196 on_button_down => $button_cb, 214 on_button_down => $button_cb,
197 on_tooltip_show => sub { 215 on_tooltip_show => sub {
198 my ($widget) = @_; 216 my ($widget) = @_;
199 217
200 $::CONN && $::CONN->ex ($self->{tag}, sub { 218 $::CONN && $::CONN->ex ($self->{tag}, sub {
201 my ($long_desc) = @_; 219 my ($long_desc) = @_;
202 220
203 $long_desc =~ s/\s+$//; 221 $long_desc = DC::Protocol::sanitise_xml ($long_desc);
204 222
205 $self->{long_desc} = $long_desc; 223 $self->{long_desc} = $long_desc;
206 $widget->set_tooltip ("<b>$long_desc</b>\n\n$tooltip_std"); 224 $widget->set_tooltip ("<b>$long_desc</b>\n\n$tooltip_std");
207 }); 225 });
208 }, 226 },
209 ; 227 ;
210 228
211 my $desc = CFPlus::Item::desc_string $self;
212 $self->{desc_widget}{bg} = $bg; 229 $self->{desc_widget}{bg} = $bg;
213 $self->{desc_widget}->set_text ($desc); 230 $self->{desc_widget}->set_text ($desc);
214 231
215 my $long_desc = $self->{long_desc} || $desc; 232 my $long_desc = $self->{long_desc} || $desc;
216 $self->{desc_widget}->set_tooltip ("<b>$long_desc</b>\n\n$tooltip_std"); 233 $self->{desc_widget}->set_tooltip ("<b>$long_desc</b>\n\n$tooltip_std");
217 234
218 $self->{weight_widget} ||= new CFPlus::UI::Label 235 $self->{weight_widget} ||= new DC::UI::Label
219 can_events => 1, 236 can_events => 1,
220 can_hover => 1, 237 can_hover => 1,
221 ellipsise => 0, 238 ellipsise => 0,
222 align => 0,
223 on_button_down => $button_cb, 239 on_button_down => $button_cb,
224 ; 240 ;
225 $self->{weight_widget}{bg} = $bg; 241 $self->{weight_widget}{bg} = $bg;
226 $self->{weight_widget}->set_text (CFPlus::Item::weight_string $self); 242 $self->{weight_widget}->set_text (DC::Item::weight_string $self);
227 $self->{weight_widget}->set_tooltip ( 243 $self->{weight_widget}->set_tooltip (
228 "<b>Weight</b>.\n" 244 "<b>Weight</b>.\n"
229 . ($self->{weight} >= 0 ? "One item weighs $self->{weight}g. " : "You have no idea how much this weighs. ") 245 . ($self->{weight} >= 0 ? "One item weighs $self->{weight}g. " : "You have no idea how much this weighs. ")
230 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ") 246 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ")
231 . "\n\n$tooltip_std" 247 . "\n\n$tooltip_std"

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines