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

Comparing deliantra/Deliantra-Client/DC.pm (file contents):
Revision 1.57 by root, Sun May 21 00:02:00 2006 UTC vs.
Revision 1.68 by root, Thu May 25 21:48:22 2006 UTC

18 $VERSION = '0.1'; 18 $VERSION = '0.1';
19 19
20 use XSLoader; 20 use XSLoader;
21 XSLoader::load "CFClient", $VERSION; 21 XSLoader::load "CFClient", $VERSION;
22} 22}
23
24use utf8;
23 25
24use Carp (); 26use Carp ();
25use AnyEvent (); 27use AnyEvent ();
26use BerkeleyDB; 28use BerkeleyDB;
27 29
36sub gl_init { 38sub gl_init {
37 $GL_VERSION = gl_version * 1; 39 $GL_VERSION = gl_version * 1;
38 %GL_EXT = map +($_ => 1), split /\s+/, gl_extensions; 40 %GL_EXT = map +($_ => 1), split /\s+/, gl_extensions;
39 41
40 $GL_NPOT = $GL_EXT{GL_ARB_texture_non_power_of_two} || $GL_VERSION >= 2; 42 $GL_NPOT = $GL_EXT{GL_ARB_texture_non_power_of_two} || $GL_VERSION >= 2;
43 $GL_NPOT = 0 if gl_vendor =~ /ATI Technologies/; # ATI doesn't get it right...
41 44
42 glDisable GL_COLOR_MATERIAL; 45 glDisable GL_COLOR_MATERIAL;
43 glShadeModel GL_FLAT; 46 glShadeModel GL_FLAT;
44 glDisable GL_DITHER; 47 glDisable GL_DITHER;
45 glDisable GL_DEPTH_TEST; 48 glDisable GL_DEPTH_TEST;
51 54
52sub gl_check { 55sub gl_check {
53 return unless $GL_DEBUG; 56 return unless $GL_DEBUG;
54 57
55 if (my $error = glGetError) { 58 if (my $error = glGetError) {
59 my ($format, @args) = @_;
56 Carp::cluck sprintf "opengl error %x while %s", $error, &sprintf(@_); 60 Carp::cluck sprintf "opengl error %x while $format", $error, @args;
57 } 61 }
58} 62}
59 63
60sub find_rcfile($) { 64sub find_rcfile($) {
61 my $path; 65 my $path;
106 -Home => "$Crossfire::VARDIR/pclient", 110 -Home => "$Crossfire::VARDIR/pclient",
107 -Cachesize => 1_000_000, 111 -Cachesize => 1_000_000,
108 -ErrFile => "$Crossfire::VARDIR/pclient/errorlog.txt", 112 -ErrFile => "$Crossfire::VARDIR/pclient/errorlog.txt",
109# -ErrPrefix => "DATABASE", 113# -ErrPrefix => "DATABASE",
110 -Verbose => 1, 114 -Verbose => 1,
111 -Flags => DB_CREATE | DB_RECOVER_FATAL | DB_INIT_MPOOL | DB_INIT_LOCK | DB_INIT_TXN, 115 -Flags => DB_CREATE | DB_RECOVER | DB_INIT_MPOOL | DB_INIT_LOCK | DB_INIT_TXN,
112 or die "unable to create/open database home $Crossfire::VARDIR/pclient: $BerkeleyDB::Error"; 116 or die "unable to create/open database home $Crossfire::VARDIR/pclient: $BerkeleyDB::Error";
113 117
114sub db_table($) { 118sub db_table($) {
115 my ($table) = @_; 119 my ($table) = @_;
116 120
130 my ($pom) = @_; 134 my ($pom) = @_;
131 135
132 $pom->present ("CFClient::PodToPango") 136 $pom->present ("CFClient::PodToPango")
133} 137}
134 138
139sub pod_to_pango_list($) {
140 my ($pom) = @_;
141
142 [
143 map s/^(\s*)// && [40 * length $1, length $_ ? $_ : " "],
144 split /\n/, $pom->present ("CFClient::PodToPango")
145 ]
146}
147
135package CFClient::PodToPango; 148package CFClient::PodToPango;
136 149
137use base Pod::POM::View::Text; 150use base Pod::POM::View::Text;
138 151
139our $indent = 0; 152our $indent = 0;
167 180
168sub view_textblock { 181sub view_textblock {
169 ("\t" x ($indent / 2)) . "$_[1]\n\n" 182 ("\t" x ($indent / 2)) . "$_[1]\n\n"
170} 183}
171 184
185sub view_head1 {
186 "<span foreground='#ffff00' size='x-large'>" . $_[1]->title->present ($_[0]) . "</span>\n\n"
187 . $_[1]->content->present ($_[0])
188};
189
172sub view_head2 { 190sub view_head2 {
173 "<big>" . $_[1]->title->present ($_[0]) . "</big>\n\n" 191 "<span foreground='#ccccff' size='large'>" . $_[1]->title->present ($_[0]) . "</span>\n\n"
174 . $_[1]->content->present ($_[0]) 192 . $_[1]->content->present ($_[0])
175}; 193};
176 194
177sub view_over { 195sub view_over {
178 local $indent = $indent + $_[1]->indent; 196 local $indent = $indent + $_[1]->indent;
197 my ($db, $key, $data) = @_; 215 my ($db, $key, $data) = @_;
198 216
199 $DB_SYNC{$db} = AnyEvent->timer (after => 5, cb => sub { $db->db_sync }); 217 $DB_SYNC{$db} = AnyEvent->timer (after => 5, cb => sub { $db->db_sync });
200 218
201 $db->db_put ($key => $data) 219 $db->db_put ($key => $data)
220}
221
222package CFClient::Item;
223
224sub desc_string {
225 my ($self) = @_;
226
227 my $desc =
228 $self->{nrof} < 2
229 ? $self->{name}
230 : "$self->{nrof} × $self->{name_pl}";
231
232 $self->{flags} & Crossfire::Protocol::F_OPEN
233 and $desc .= " (open)";
234 $self->{flags} & Crossfire::Protocol::F_APPLIED
235 and $desc .= " (applied)";
236 $self->{flags} & Crossfire::Protocol::F_UNPAID
237 and $desc .= " (unpaid)";
238 $self->{flags} & Crossfire::Protocol::F_MAGIC
239 and $desc .= " (magic)";
240 $self->{flags} & Crossfire::Protocol::F_CURSED
241 and $desc .= " (cursed)";
242 $self->{flags} & Crossfire::Protocol::F_DAMNED
243 and $desc .= " (damned)";
244 $self->{flags} & Crossfire::Protocol::F_LOCKED
245 and $desc .= " *";
246
247 $desc
248}
249
250sub weight_string {
251 my ($self) = @_;
252
253 my $weight = ($self->{nrof} || 1) * $self->{weight};
254
255 $weight < 0 ? "?" : $weight * 0.001
256}
257
258sub update_widgets {
259 my ($self) = @_;
260
261 my $button_cb = sub {
262 my (undef, $ev, $x, $y) = @_;
263
264 if (($ev->{mod} & CFClient::KMOD_SHIFT) && $ev->{button} == 1) {
265 my $targ = $::CONN->{player}{tag};
266
267 if ($self->{container} == $::CONN->{player}{tag}) {
268 $targ = $::CONN->{open_container};
269 }
270
271 $::CONN->send ("move $targ $self->{tag} 0");
272 } elsif ($ev->{button} == 1) {
273 $::CONN->send ("examine $self->{tag}");
274 } elsif ($ev->{button} == 2) {
275 $::CONN->send ("apply $self->{tag}");
276 } elsif ($ev->{button} == 3) {
277 my @menu_items = (
278 ["examine", sub { $::CONN->send ("examine $self->{tag}") }],
279 ["mark", sub { $::CONN->send ("mark ". pack "N", $self->{tag}) }],
280 ["apply", sub { $::CONN->send ("apply $self->{tag}") }],
281 (
282 $self->{flags} & Crossfire::Protocol::F_LOCKED
283 ? (
284 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) }],
285 )
286 : (
287 ["lock", sub { $::CONN->send ("lock " . pack "CN", 1, $self->{tag}) }],
288 ["drop", sub { $::CONN->send ("move $::CONN->{open_container} $self->{tag} 0") }],
289 )
290 ),
291 );
292
293 CFClient::UI::Menu->new (items => \@menu_items)->popup ($ev);
294 }
295
296 1
297 };
298
299 my $tooltip_std = "<small>"
300 . "Left click - examine item\n"
301 . "Shift-Left click - " . ($self->{container} ? "move or drop" : "take") . " item\n"
302 . "Middle click - apply\n"
303 . "Right click - further options"
304 . "</small>\n";
305
306 $self->{face_widget} ||= new CFClient::UI::Face
307 can_events => 1,
308 can_hover => 1,
309 anim => $self->{anim},
310 animspeed => $self->{animspeed}, # TODO# must be set at creation time
311 connect_button_down => $button_cb,
312 ;
313 $self->{face_widget}{face} = $self->{face};
314 $self->{face_widget}{anim} = $self->{anim};
315 $self->{face_widget}{animspeed} = $self->{animspeed};
316 $self->{face_widget}->set_tooltip (
317 "<b>Face/Animation.</b>\n"
318 . "Item uses face #$self->{face}. "
319 . ($self->{animspeed} ? "Item uses animation #$self->{anim} at " . (1 / $self->{animspeed}) . "fps. " : "Item is not animated. ")
320 . "\n\n$tooltip_std"
321 );
322
323 $self->{desc_widget} ||= new CFClient::UI::Label
324 can_events => 1,
325 can_hover => 1,
326 ellipsise => 2,
327 align => -1,
328 connect_button_down => $button_cb,
329 ;
330 my $desc = CFClient::Item::desc_string $self;
331 $self->{desc_widget}->set_text ($desc);
332 $self->{desc_widget}->set_tooltip ("<b>$desc</b>.\n$tooltip_std");
333
334 $self->{weight_widget} ||= new CFClient::UI::Label
335 can_events => 1,
336 can_hover => 1,
337 ellipsise => 0,
338 align => 0,
339 connect_button_down => $button_cb,
340 ;
341 $self->{weight_widget}->set_text (CFClient::Item::weight_string $self);
342
343 $self->{weight_widget}->set_tooltip (
344 "<b>Weight</b>.\n"
345 . ($self->{weight} >= 0 ? "One item weighs $self->{weight}g. " : "You have no idea how much this weighs. ")
346 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ")
347 . "\n\n$tooltip_std"
348 );
202} 349}
203 350
204package CFClient::Texture; 351package CFClient::Texture;
205 352
206use strict; 353use strict;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines