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.135 by root, Thu Dec 7 15:57:13 2006 UTC vs.
Revision 1.136 by root, Sat Dec 9 02:21:24 2006 UTC

309 309
310$CFPlus::OpenGL::SHUTDOWN_HOOK{"CFPlus::Layout"} = sub { 310$CFPlus::OpenGL::SHUTDOWN_HOOK{"CFPlus::Layout"} = sub {
311 reset_glyph_cache; 311 reset_glyph_cache;
312}; 312};
313 313
314package CFPlus::Item;
315
316use strict;
317use Crossfire::Protocol::Constants;
318
319my $last_enter_count = 1;
320
321sub desc_string {
322 my ($self) = @_;
323
324 my $desc =
325 $self->{nrof} < 2
326 ? $self->{name}
327 : "$self->{nrof} × $self->{name_pl}";
328
329 $self->{flags} & F_OPEN
330 and $desc .= " (open)";
331 $self->{flags} & F_APPLIED
332 and $desc .= " (applied)";
333 $self->{flags} & F_UNPAID
334 and $desc .= " (unpaid)";
335 $self->{flags} & F_MAGIC
336 and $desc .= " (magic)";
337 $self->{flags} & F_CURSED
338 and $desc .= " (cursed)";
339 $self->{flags} & F_DAMNED
340 and $desc .= " (damned)";
341 $self->{flags} & F_LOCKED
342 and $desc .= " *";
343
344 $desc
345}
346
347sub weight_string {
348 my ($self) = @_;
349
350 my $weight = ($self->{nrof} || 1) * $self->{weight};
351
352 $weight < 0 ? "?" : $weight * 0.001
353}
354
355sub do_n_dialog {
356 my ($cb) = @_;
357
358 my $w = new CFPlus::UI::Toplevel
359 on_delete => sub { $_[0]->destroy; 1 },
360 has_close_button => 1,
361 ;
362
363 $w->add (my $vb = new CFPlus::UI::VBox x => "center", y => "center");
364 $vb->add (new CFPlus::UI::Label text => "Enter item count:");
365 $vb->add (my $entry = new CFPlus::UI::Entry
366 text => $last_enter_count,
367 on_activate => sub {
368 my ($entry) = @_;
369 $last_enter_count = $entry->get_text;
370 $cb->($last_enter_count);
371 $w->hide;
372 $w->destroy;
373
374 0
375 },
376 on_escape => sub { $w->destroy; 1 },
377 );
378 $entry->grab_focus;
379 $w->show;
380}
381
382sub update_widgets {
383 my ($self) = @_;
384
385 # necessary to avoid cyclic references
386 Scalar::Util::weaken $self;
387
388 my $button_cb = sub {
389 my (undef, $ev, $x, $y) = @_;
390
391 my $targ = $::CONN->{player}{tag};
392
393 if ($self->{container} == $::CONN->{player}{tag}) {
394 $targ = $::CONN->{open_container};
395 }
396
397 if (($ev->{mod} & CFPlus::KMOD_SHIFT) && $ev->{button} == 1) {
398 $::CONN->send ("move $targ $self->{tag} 0")
399 if $targ || !($self->{flags} & F_LOCKED);
400 } elsif (($ev->{mod} & CFPlus::KMOD_SHIFT) && $ev->{button} == 2) {
401 $self->{flags} & F_LOCKED
402 ? $::CONN->send ("lock " . pack "CN", 0, $self->{tag})
403 : $::CONN->send ("lock " . pack "CN", 1, $self->{tag})
404 } elsif ($ev->{button} == 1) {
405 $::CONN->send ("examine $self->{tag}");
406 } elsif ($ev->{button} == 2) {
407 $::CONN->send ("apply $self->{tag}");
408 } elsif ($ev->{button} == 3) {
409 my $move_prefix = $::CONN->{open_container} ? 'put' : 'drop';
410 if ($self->{container} == $::CONN->{open_container}) {
411 $move_prefix = "take";
412 }
413
414 my $shortname = CFPlus::shorten $self->{name}, 14;
415
416 my @menu_items = (
417 ["examine", sub { $::CONN->send ("examine $self->{tag}") }],
418 ["mark", sub { $::CONN->send ("mark ". pack "N", $self->{tag}) }],
419 ["ignite/thaw", # first try of an easier use of flint&steel
420 sub {
421 $::CONN->send ("mark ". pack "N", $self->{tag});
422 $::CONN->send ("command apply flint and steel");
423 }
424 ],
425 ["inscribe", # first try of an easier use of flint&steel
426 sub {
427 &::open_string_query ("Text to inscribe", sub {
428 my ($entry, $txt) = @_;
429 $::CONN->send ("mark ". pack "N", $self->{tag});
430 $::CONN->send ("command use_skill inscription $txt");
431 });
432 }
433 ],
434 ["rename", # first try of an easier use of flint&steel
435 sub {
436 &::open_string_query ("Rename item to:", sub {
437 my ($entry, $txt) = @_;
438 $::CONN->send ("mark ". pack "N", $self->{tag});
439 $::CONN->send ("command rename to <$txt>");
440 }, $self->{name},
441 "If you input no name or erase the current custom name, the custom name will be unset");
442 }
443 ],
444 ["apply", sub { $::CONN->send ("apply $self->{tag}") }],
445 (
446 $self->{flags} & F_LOCKED
447 ? (
448 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) }],
449 )
450 : (
451 ["lock", sub { $::CONN->send ("lock " . pack "CN", 1, $self->{tag}) }],
452 ["$move_prefix all", sub { $::CONN->send ("move $targ $self->{tag} 0") }],
453 ["$move_prefix &lt;n&gt;",
454 sub {
455 do_n_dialog (sub { $::CONN->send ("move $targ $self->{tag} $_[0]") })
456 }
457 ]
458 )
459 ),
460 ["bind <i>apply $shortname</i> to a key" => sub { $::BIND_EDITOR->do_quick_binding (["apply $self->{name}"]) }],
461 );
462
463 CFPlus::UI::Menu->new (items => \@menu_items)->popup ($ev);
464 }
465
466 1
467 };
468
469 my $tooltip_std = "<small>"
470 . "Left click - examine item\n"
471 . "Shift-Left click - " . ($self->{container} ? "move or drop" : "take") . " item\n"
472 . "Middle click - apply\n"
473 . "Shift-Middle click - lock/unlock\n"
474 . "Right click - further options"
475 . "</small>\n";
476
477 my $bg = $self->{flags} & F_CURSED ? [1 , 0 , 0, 0.5]
478 : $self->{flags} & F_MAGIC ? [0.2, 0.2, 1, 0.5]
479 : undef;
480
481 $self->{face_widget} ||= new CFPlus::UI::Face
482 can_events => 1,
483 can_hover => 1,
484 anim => $self->{anim},
485 animspeed => $self->{animspeed}, # TODO# must be set at creation time
486 on_button_down => $button_cb,
487 ;
488 $self->{face_widget}{bg} = $bg;
489 $self->{face_widget}{face} = $self->{face};
490 $self->{face_widget}{anim} = $self->{anim};
491 $self->{face_widget}{animspeed} = $self->{animspeed};
492 $self->{face_widget}->set_tooltip (
493 "<b>Face/Animation.</b>\n"
494 . "Item uses face #$self->{face}. "
495 . ($self->{animspeed} ? "Item uses animation #$self->{anim} at " . (1 / $self->{animspeed}) . "fps. " : "Item is not animated. ")
496 . "\n\n$tooltip_std"
497 );
498
499 $self->{desc_widget} ||= new CFPlus::UI::Label
500 can_events => 1,
501 can_hover => 1,
502 ellipsise => 2,
503 align => -1,
504 on_button_down => $button_cb,
505 ;
506 my $desc = CFPlus::Item::desc_string $self;
507 $self->{desc_widget}{bg} = $bg;
508 $self->{desc_widget}->set_text ($desc);
509 $self->{desc_widget}->set_tooltip ("<b>$desc</b>.\n$tooltip_std");
510
511 $self->{weight_widget} ||= new CFPlus::UI::Label
512 can_events => 1,
513 can_hover => 1,
514 ellipsise => 0,
515 align => 0,
516 on_button_down => $button_cb,
517 ;
518 $self->{weight_widget}{bg} = $bg;
519 $self->{weight_widget}->set_text (CFPlus::Item::weight_string $self);
520 $self->{weight_widget}->set_tooltip (
521 "<b>Weight</b>.\n"
522 . ($self->{weight} >= 0 ? "One item weighs $self->{weight}g. " : "You have no idea how much this weighs. ")
523 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ")
524 . "\n\n$tooltip_std"
525 );
526}
527
5281; 3141;
529 315
530=back 316=back
531 317
532=head1 AUTHOR 318=head1 AUTHOR

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines