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

Comparing deliantra/Deliantra-Client/DC/Protocol.pm (file contents):
Revision 1.206 by elmex, Sun Dec 7 16:20:44 2008 UTC vs.
Revision 1.215 by root, Sat Apr 3 02:58:25 2010 UTC

1package DC::Protocol; 1package DC::Protocol;
2 2
3use utf8; 3use common::sense;
4use strict; 4
5use Guard ();
5 6
6use Deliantra::Protocol::Constants; 7use Deliantra::Protocol::Constants;
7 8
8use DC; 9use DC;
9use DC::DB; 10use DC::DB;
16 17
17our $TEX_DIALOGUE = new_from_resource DC::Texture 18our $TEX_DIALOGUE = new_from_resource DC::Texture
18 "dialogue.png", minify => 1, mipmap => 1; 19 "dialogue.png", minify => 1, mipmap => 1;
19 20
20our $TEX_NOFACE = new_from_resource DC::Texture 21our $TEX_NOFACE = new_from_resource DC::Texture
21 "noface.png", minify => 1, mipmap => 1; 22 "noface.png", minify => 1, mipmap => 1, wrap => 1;
22 23
23sub MIN_TEXTURE_UNUSED() { 1 }#d# 24sub MIN_TEXTURE_UNUSED() { 1 }#d#
24 25
25sub new { 26sub new {
26 my ($class, %arg) = @_; 27 my ($class, %arg) = @_;
277 my %wkw = ( 278 my %wkw = (
278 root => $DC::UI::ROOT, 279 root => $DC::UI::ROOT,
279 tooltip => $DC::UI::TOOLTIP, 280 tooltip => $DC::UI::TOOLTIP,
280 281
281 mapwidget => $::MAPWIDGET, 282 mapwidget => $::MAPWIDGET,
283 menubar => $::MENUBAR,
284 menupopup => $::MENUPOPUP,
285 pickup_enable => $::PICKUP_ENABLE,
282 buttonbar => $::BUTTONBAR, 286 buttonbar => $::BUTTONBAR,
283 metaserver => $::METASERVER, 287 metaserver => $::METASERVER,
284 buttonbar => $::BUTTONBAR, 288 buttonbar => $::BUTTONBAR,
285 login_button => $::LOGIN_BUTTON, 289 login_button => $::LOGIN_BUTTON,
286 quit_dialog => $::QUIT_DIALOG, 290 quit_dialog => $::QUIT_DIALOG,
303 307
304 floorbox => $::FLOORBOX, 308 floorbox => $::FLOORBOX,
305 help_window => $::HELP_WINDOW, 309 help_window => $::HELP_WINDOW,
306 message_window => $::MESSAGE_WINDOW, 310 message_window => $::MESSAGE_WINDOW,
307 message_dist => $::MESSAGE_DIST, 311 message_dist => $::MESSAGE_DIST,
308 statusbox => $::SDTATUSBOX, 312 statusbox => $::STATUSBOX,
309 313
310 inv => $::INV, 314 inv => $::INV,
311 invr => $::INVR, 315 invr => $::INVR,
312 invr_hb => $::INVR_HB, 316 invr_hb => $::INVR_HB,
313 ); 317 );
397 ? (($new & $_ ? "+" : "-") . $self->{spell_paths}{$_}) 401 ? (($new & $_ ? "+" : "-") . $self->{spell_paths}{$_})
398 : () 402 : ()
399 } 403 }
400 sort { $a <=> $b } keys %{$self->{spell_paths}}; 404 sort { $a <=> $b } keys %{$self->{spell_paths}};
401 405
402 join "", @diff 406 "\u$name: " . (join ", ", @diff)
403} 407}
404 408
405# all stats that are chacked against changes 409# all stats that are chacked against changes
406my @statchange = ( 410my @statchange = (
407 [&CS_STAT_STR => \&_stat_numdiff, "Str"], 411 [&CS_STAT_STR => \&_stat_numdiff, "Str"],
462 } 466 }
463 467
464 if ( 468 if (
465 my @diffs = map $_->[1]->($self, $_->[2], $prev->{$_->[0]}, $stats->{$_->[0]}), @statchange 469 my @diffs = map $_->[1]->($self, $_->[2], $prev->{$_->[0]}, $stats->{$_->[0]}), @statchange
466 ) { 470 ) {
467 my $msg = "<b>stat change</b>: " . (join " ", @diffs); 471 my $msg = "<b>stat change</b>: " . (join " ", map "($_)", @diffs);
468 $self->{statusbox}->add ($msg, group => "stat $msg", fg => [0.8, 1, 0.2, 1], timeout => 20); 472 $self->{statusbox}->add ($msg, group => "stat $msg", fg => [0.8, 1, 0.2, 1], timeout => 20);
469 } 473 }
470 474
471 $self->update_stats_window ($stats, $prev); 475 $self->update_stats_window ($stats, $prev);
472 476
510 514
511 $::GAUGES->{hp} ->set_value ($hp, $hp_m); 515 $::GAUGES->{hp} ->set_value ($hp, $hp_m);
512 $::GAUGES->{mana} ->set_value ($sp, $sp_m); 516 $::GAUGES->{mana} ->set_value ($sp, $sp_m);
513 $::GAUGES->{food} ->set_value ($fo, $fo_m); 517 $::GAUGES->{food} ->set_value ($fo, $fo_m);
514 $::GAUGES->{grace} ->set_value ($gr, $gr_m); 518 $::GAUGES->{grace} ->set_value ($gr, $gr_m);
515 $::GAUGES->{exp} ->set_text ("Exp: " . (::formsep ($stats->{+CS_STAT_EXP64})) 519 $::GAUGES->{exp} ->set_label ("Exp: " . (::formsep ($stats->{+CS_STAT_EXP64}))#d#
516 . " (lvl " . ($stats->{+CS_STAT_LEVEL} * 1) . ")"); 520 . " (lvl " . ($stats->{+CS_STAT_LEVEL} * 1) . ")");
517 $::GAUGES->{prg} ->set_value ($stats->{+CS_STAT_LEVEL}, $stats->{+CS_STAT_EXP64}); 521 $::GAUGES->{exp} ->set_value ($stats->{+CS_STAT_LEVEL}, $stats->{+CS_STAT_EXP64});
518 $::GAUGES->{range} ->set_text ($stats->{+CS_STAT_RANGE}); 522 $::GAUGES->{range} ->set_text ($stats->{+CS_STAT_RANGE});
519 my $title = $stats->{+CS_STAT_TITLE}; 523 my $title = $stats->{+CS_STAT_TITLE};
520 $title =~ s/^Player: //; 524 $title =~ s/^Player: //;
521 $::STATWIDS->{title} ->set_text ("Title: " . $title); 525 $::STATWIDS->{title} ->set_text ("Title: " . $title);
522 526
635 my $sw = $self->{skillwid}{$idx}; 639 my $sw = $self->{skillwid}{$idx};
636 $sw->[0]->set_text (::formsep ($val->[1])); 640 $sw->[0]->set_text (::formsep ($val->[1]));
637 $sw->[1]->set_text ($val->[0] * 1); 641 $sw->[1]->set_text ($val->[0] * 1);
638 $sw->[2]->set_value (@$val); 642 $sw->[2]->set_value (@$val);
639 643
640 $::GAUGES->{sklprg}->set_label ("$name %d%%"); 644 $::GAUGES->{skillexp}->set_label ("$name %d%%");
641 $::GAUGES->{sklprg}->set_value (@$val); 645 $::GAUGES->{skillexp}->set_value (@$val);
642 } 646 }
643} 647}
644 648
645sub user_send { 649sub user_send {
646 my ($self, $command) = @_; 650 my ($self, $command) = @_;
985 989
986 my $tex = $self->{texture}[$tile] ||= 990 my $tex = $self->{texture}[$tile] ||=
987 new DC::Texture 991 new DC::Texture
988 tile => $tile, 992 tile => $tile,
989 image => $data, delete_image => 1, 993 image => $data, delete_image => 1,
990 minify => 1, mipmap => 1; 994 minify => 1;
991 995
992 if (my $cbs = delete $self->{tile_cb}{$tile}) { 996 if (my $cbs = delete $self->{tile_cb}{$tile}) {
993 $_->($tex) for @$cbs; 997 $_->($tex) for @$cbs;
994 } 998 }
995} 999}
1000 my ($self, $num, $cb) = @_; 1004 my ($self, $num, $cb) = @_;
1001 1005
1002 push @{$self->{face_cb}{$num}}, $cb; 1006 push @{$self->{face_cb}{$num}}, $cb;
1003 1007
1004 defined wantarray 1008 defined wantarray
1005 ? DC::guard { 1009 ? Guard::guard {
1006 @{$self->{face_cb}{$num}} 1010 @{$self->{face_cb}{$num}}
1007 = grep $_ != $cb, 1011 = grep $_ != $cb,
1008 @{$self->{face_cb}{$num}}; 1012 @{$self->{face_cb}{$num}};
1009 } 1013 }
1010 : () 1014 : ()
1383 }); 1387 });
1384 1388
1385 $self->update_server_info; 1389 $self->update_server_info;
1386 1390
1387 $self->send_command ("output-rate $::CFG->{output_rate}") if $::CFG->{output_rate} > 0; 1391 $self->send_command ("output-rate $::CFG->{output_rate}") if $::CFG->{output_rate} > 0;
1388 $self->send_command ("pickup $::CFG->{pickup}"); 1392 $self->send_pickup ($::CFG->{pickup});
1389 1393
1390 $self->send_exti_msg (clientlog => sprintf "OpenGL Info: %s [%s]", 1394 $self->send_exti_msg (clientlog => sprintf "OpenGL Info: %s [%s]",
1391 DC::OpenGL::gl_vendor, DC::OpenGL::gl_version);#d# 1395 DC::OpenGL::gl_vendor, DC::OpenGL::gl_version);#d#
1392} 1396}
1393 1397

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines