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.9 by root, Wed Dec 26 18:09:30 2007 UTC vs.
Revision 1.19 by root, Wed Nov 21 13:23:10 2012 UTC

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

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines