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.8 by root, Tue Dec 25 07:39:18 2007 UTC vs.
Revision 1.17 by root, Sat Apr 3 02:58:24 2010 UTC

1package CFPlus::Item; 1package DC::Item;
2 2
3use strict; 3use common::sense;
4use utf8; 4
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) = @_;
13 13
14 my $desc = 14 my $desc =
15 $self->{nrof} < 2 15 $self->{nrof} < 2
16 ? $self->{name} 16 ? $self->{name}
17 : "$self->{nrof} × $self->{name_pl}"; 17 : "$self->{nrof} $self->{name_pl}";
18 18
19 $self->{flags} & F_OPEN 19 $self->{flags} & F_OPEN
20 and $desc .= " (open)"; 20 and $desc .= " (open)";
21 $self->{flags} & F_APPLIED 21 $self->{flags} & F_APPLIED
22 and $desc .= " (applied)"; 22 and $desc .= " (applied)";
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 my $desc = CFPlus::Item::desc_string $self; 175 my $desc = DC::Item::desc_string $self;
176 my $face_tooltip = "<b>$desc</b>\n\n$tooltip_std";
173 177
178 if (my $face = $self->{face_widget}) {
179 # already exists, so update if it changed
180 if ($face->{bg} != $bg) {
181 $face->{bg} = $bg;
182 $face->update;
183 }
184
185 $face->set_bg ($bg) if $face->{bg} != $bg;
186 $face->set_face ($self->{face}) if $face->{face} != $self->{face};
187 $face->set_anim ($self->{anim}) if $face->{anim} != $self->{anim};
188 $face->set_animspeed ($self->{animspeed}) if $face->{animspeed} != $self->{animspeed};
189
190 #$face->set_tooltip (
191 # "<b>Face/Animation.</b>\n"
192 # . "Item uses face #$self->{face}. "
193 # . ($self->{animspeed} ? "Item uses animation #$self->{anim} at " . (1 / $self->{animspeed}) . "fps. " : "Item is not animated. ")
194 # . "\n\n$tooltip_std"
195 #);
196 $face->set_tooltip ($face_tooltip);
197 } else {
198 # new object, create new face
174 $self->{face_widget} ||= new CFPlus::UI::Face 199 $self->{face_widget} = new DC::UI::Face
175 can_events => 1, 200 can_events => 1,
176 can_hover => 1, 201 can_hover => 1,
202 bg => $bg,
203 face => $self->{face},
177 anim => $self->{anim}, 204 anim => $self->{anim},
178 animspeed => $self->{animspeed}, # TODO# must be set at creation time 205 animspeed => $self->{animspeed}, # TODO# must be set at creation time
206 tooltip => $face_tooltip,
179 on_button_down => $button_cb, 207 on_button_down => $button_cb,
208 ;
180 ; 209 }
181 $self->{face_widget}{bg} = $bg;
182 $self->{face_widget}{face} = $self->{face};
183 $self->{face_widget}{anim} = $self->{anim};
184 $self->{face_widget}{animspeed} = $self->{animspeed};
185# $self->{face_widget}->set_tooltip (
186# "<b>Face/Animation.</b>\n"
187# . "Item uses face #$self->{face}. "
188# . ($self->{animspeed} ? "Item uses animation #$self->{anim} at " . (1 / $self->{animspeed}) . "fps. " : "Item is not animated. ")
189# . "\n\n$tooltip_std"
190# );
191 $self->{face_widget}->set_tooltip ("<b>$desc</b>\n\n$tooltip_std");
192 210
193 $self->{desc_widget} ||= new CFPlus::UI::Label 211 $self->{desc_widget} ||= new DC::UI::Label
194 can_events => 1, 212 can_events => 1,
195 can_hover => 1, 213 can_hover => 1,
196 ellipsise => 2, 214 ellipsise => 2,
197 align => -1, 215 align => 0,
198 216
199 on_button_down => $button_cb, 217 on_button_down => $button_cb,
200 on_tooltip_show => sub { 218 on_tooltip_show => sub {
201 my ($widget) = @_; 219 my ($widget) = @_;
202 220
203 $::CONN && $::CONN->ex ($self->{tag}, sub { 221 $::CONN && $::CONN->ex ($self->{tag}, sub {
204 my ($long_desc) = @_; 222 my ($long_desc) = @_;
205 223
206 $long_desc =~ s/\s+$//; 224 $long_desc = DC::Protocol::sanitise_xml ($long_desc);
207 225
208 $self->{long_desc} = $long_desc; 226 $self->{long_desc} = $long_desc;
209 $widget->set_tooltip ("<b>$long_desc</b>\n\n$tooltip_std"); 227 $widget->set_tooltip ("<b>$long_desc</b>\n\n$tooltip_std");
210 }); 228 });
211 }, 229 },
212 ; 230 ;
213 231
214 $self->{desc_widget}{bg} = $bg; 232 my $long_desc = $self->{long_desc} || $desc;
233
234 $self->{desc_widget}->set_bg ($bg) if $self->{desc_widget}{bg} != $bg;
215 $self->{desc_widget}->set_text ($desc); 235 $self->{desc_widget}->set_text ($desc);
216
217 my $long_desc = $self->{long_desc} || $desc;
218 $self->{desc_widget}->set_tooltip ("<b>$long_desc</b>\n\n$tooltip_std"); 236 $self->{desc_widget}->set_tooltip ("<b>$long_desc</b>\n\n$tooltip_std");
219 237
220 $self->{weight_widget} ||= new CFPlus::UI::Label 238 $self->{weight_widget} ||= new DC::UI::Label
221 can_events => 1, 239 can_events => 1,
222 can_hover => 1, 240 can_hover => 1,
223 ellipsise => 0, 241 ellipsise => 0,
224 align => 0,
225 on_button_down => $button_cb, 242 on_button_down => $button_cb,
226 ; 243 ;
227 $self->{weight_widget}{bg} = $bg; 244 $self->{weight_widget}{bg} = $bg;
228 $self->{weight_widget}->set_text (CFPlus::Item::weight_string $self); 245 $self->{weight_widget}->set_text (DC::Item::weight_string $self);
229 $self->{weight_widget}->set_tooltip ( 246 $self->{weight_widget}->set_tooltip (
230 "<b>Weight</b>.\n" 247 "<b>Weight</b>.\n"
231 . ($self->{weight} >= 0 ? "One item weighs $self->{weight}g. " : "You have no idea how much this weighs. ") 248 . ($self->{weight} >= 0 ? "One item weighs $self->{weight}g. " : "You have no idea how much this weighs. ")
232 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ") 249 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ")
233 . "\n\n$tooltip_std" 250 . "\n\n$tooltip_std"

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines