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.94 by elmex, Wed Jun 28 09:45:10 2006 UTC vs.
Revision 1.99 by elmex, Fri Jul 14 17:35:34 2006 UTC

234 [ 234 [
235 map s/^(\s*)// && [40 * length $1, length $_ ? $_ : " "], 235 map s/^(\s*)// && [40 * length $1, length $_ ? $_ : " "],
236 split /\n/, $pom->present ("CFClient::PodToPango") 236 split /\n/, $pom->present ("CFClient::PodToPango")
237 ] 237 ]
238} 238}
239
240package CFClient::Layout;
241
242$CFClient::OpenGL::SHUTDOWN_HOOK{"CFClient::Layout"} = sub {
243 reset_glyph_cache;
244};
239 245
240package CFClient::Item; 246package CFClient::Item;
241 247
242use strict; 248use strict;
243use Crossfire::Protocol::Constants; 249use Crossfire::Protocol::Constants;
327 $::CONN->send ("apply $self->{tag}"); 333 $::CONN->send ("apply $self->{tag}");
328 } elsif ($ev->{button} == 3) { 334 } elsif ($ev->{button} == 3) {
329 my @menu_items = ( 335 my @menu_items = (
330 ["examine", sub { $::CONN->send ("examine $self->{tag}") }], 336 ["examine", sub { $::CONN->send ("examine $self->{tag}") }],
331 ["mark", sub { $::CONN->send ("mark ". pack "N", $self->{tag}) }], 337 ["mark", sub { $::CONN->send ("mark ". pack "N", $self->{tag}) }],
338 ["ignite/thaw", # first try of an easier use of flint&steel
339 sub {
340 $::CONN->send ("mark ". pack "N", $self->{tag});
341 $::CONN->send ("command apply flint and steel");
342 }
343 ],
332 ["apply", sub { $::CONN->send ("apply $self->{tag}") }], 344 ["apply", sub { $::CONN->send ("apply $self->{tag}") }],
333 ( 345 (
334 $self->{flags} & F_LOCKED 346 $self->{flags} & F_LOCKED
335 ? ( 347 ? (
336 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) }], 348 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $self->{tag}) }],
404 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ") 416 . ($self->{nrof} ? "You have $self->{nrof} of it. " : "Item cannot stack with others of it's kind. ")
405 . "\n\n$tooltip_std" 417 . "\n\n$tooltip_std"
406 ); 418 );
407} 419}
408 420
409package CFClient::Binder;
410
411my @ALLOWED_MODIFIER_KEYS = (
412 CFClient::SDLK_LSHIFT,
413 CFClient::SDLK_LCTRL ,
414 CFClient::SDLK_LALT ,
415 CFClient::SDLK_LMETA ,
416
417 CFClient::SDLK_RSHIFT,
418 CFClient::SDLK_RCTRL ,
419 CFClient::SDLK_RALT ,
420 CFClient::SDLK_RMETA ,
421);
422
423my %ALLOWED_MODIFIERS = (
424 CFClient::KMOD_LSHIFT => "LSHIFT",
425 CFClient::KMOD_LCTRL => "LCTRL",
426 CFClient::KMOD_LALT => "LALT",
427 CFClient::KMOD_LMETA => "LMETA",
428
429 CFClient::KMOD_RSHIFT => "RSHIFT",
430 CFClient::KMOD_RCTRL => "RCTRL",
431 CFClient::KMOD_RALT => "RALT",
432 CFClient::KMOD_RMETA => "RMETA",
433);
434
435my %DIRECT_BIND_CHARS = map { $_ => 1 } qw/0 1 2 3 4 5 6 7 8 9/;
436my @DIRECT_BIND_KEYS = (
437 CFClient::SDLK_F1,
438 CFClient::SDLK_F2,
439 CFClient::SDLK_F3,
440 CFClient::SDLK_F4,
441 CFClient::SDLK_F5,
442 CFClient::SDLK_F6,
443 CFClient::SDLK_F7,
444 CFClient::SDLK_F8,
445 CFClient::SDLK_F9,
446 CFClient::SDLK_F10,
447 CFClient::SDLK_F11,
448 CFClient::SDLK_F12,
449 CFClient::SDLK_F13,
450 CFClient::SDLK_F14,
451 CFClient::SDLK_F15,
452);
453
454# this binding dialog asks for a key-combo to be pressed
455# and if successful it calls the $cb with $mod and $sym as args.
456sub open_binding_dialog {
457 my ($cb) = @_;
458
459 my $w = new CFClient::UI::FancyFrame
460 title => "Bind Action",
461 x => "center",
462 y => "center",
463 z => 1000;
464
465 $w->add (my $vb = new CFClient::UI::VBox);
466 $vb->add (new CFClient::UI::Label
467 text => "Press a modifier (CTRL, ALT and/or SHIFT) and a key."
468 ."You can only bind 0-9 and F1-F15 without modifiers."
469 );
470 $vb->add (my $entry = new CFClient::UI::Entry
471 text => "",
472 on_key_down => sub {
473 my ($entry, $ev) = @_;
474
475 my $mod = $ev->{mod};
476 my $sym = $ev->{sym};
477
478 # XXX: This seems a little bit hackisch to me, but i have to ignore them
479 if (grep { $_ == $sym } @ALLOWED_MODIFIER_KEYS) {
480 return;
481 }
482
483 if ($mod == CFClient::KMOD_NONE
484 and not $DIRECT_BIND_CHARS{chr ($ev->{unicode})}
485 and not grep { $sym == $_ } @DIRECT_BIND_KEYS)
486 {
487 $::STATUSBOX->add (
488 "Can't bind key ".CFClient::SDL_GetKeyName ($sym)
489 ." directly without modifier! It would damage the completer handling."
490 );
491 return;
492 }
493
494 $entry->grab_focus;
495
496 $cb->($mod, $sym);
497
498 $w->destroy
499 });
500
501 $entry->grab_focus;
502 $w->show;
503}
504
505sub keycombo_to_name {
506 my ($mod, $sym) = @_;
507
508 my $mods = join '+',
509 map { $ALLOWED_MODIFIERS{$_} }
510 grep { ($_ + 0) & ($mod + 0) }
511 keys %ALLOWED_MODIFIERS;
512 $mods .= "+" if $mods ne '';
513
514 return $mods . CFClient::SDL_GetKeyName ($sym);
515}
516
5171; 4211;
518 422
519=back 423=back
520 424
521=head1 AUTHOR 425=head1 AUTHOR

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines