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

Comparing deliantra/Deliantra-Client/DC/UI.pm (file contents):
Revision 1.17 by elmex, Sat Apr 8 13:34:19 2006 UTC vs.
Revision 1.18 by root, Sat Apr 8 13:36:26 2006 UTC

1package Crossfire::Client::Widget; 1package Crossfire::Client::Widget;
2 2
3use strict; 3use strict;
4
5use Scalar::Util;
6
4use SDL::OpenGL; 7use SDL::OpenGL;
5use SDL::OpenGL::Constants; 8use SDL::OpenGL::Constants;
6 9
7our $FOCUS; # the widget with current focus 10our $FOCUS; # the widget with current focus
8our @ACTIVE_WIDGETS; 11our @ACTIVE_WIDGETS;
19 bless { @_ }, $class 22 bless { @_ }, $class
20} 23}
21 24
22sub activate { 25sub activate {
23 push @ACTIVE_WIDGETS, $_[0]; 26 push @ACTIVE_WIDGETS, $_[0];
27 Scalar::Util::weaken $ACTIVE_WIDGETS[-1];
24} 28}
25 29
26sub deactivate { 30sub deactivate {
27 @ACTIVE_WIDGETS = 31 @ACTIVE_WIDGETS =
28 sort { $a->{z} <=> $b->{z} } 32 sort { $a->{z} <=> $b->{z} }
29 grep { $_ != $_[0] } 33 grep { $_ && $_ != $_[0] }
30 @ACTIVE_WIDGETS; 34 @ACTIVE_WIDGETS;
35}
36
37sub move {
38 my ($self, $x, $y, $z) = @_;
39 $self->{x} = $x;
40 $self->{y} = $y;
41 $self->{z} = $z if defined $z;
31} 42}
32 43
33sub size_request { 44sub size_request {
34 die "size_request is abtract"; 45 die "size_request is abtract";
35} 46}
78 my ($widget) = @_; 89 my ($widget) = @_;
79} 90}
80 91
81sub bbox { 92sub bbox {
82 my ($widget) = @_; 93 my ($widget) = @_;
94}
95
96sub DESTROY {
97 my ($self) = @_;
98
99 $self->deactivate;
83} 100}
84 101
85package Crossfire::Client::Widget::Container; 102package Crossfire::Client::Widget::Container;
86 103
87our @ISA = Crossfire::Client::Widget::; 104our @ISA = Crossfire::Client::Widget::;
286sub _draw { 303sub _draw {
287 my ($self) = @_; 304 my ($self) = @_;
288 305
289 my $tex = $self->{texture}; 306 my $tex = $self->{texture};
290 307
291 $self->{x}--;
292
293 glEnable GL_BLEND; 308 glEnable GL_BLEND;
294 glEnable GL_TEXTURE_2D; 309 glEnable GL_TEXTURE_2D;
295 glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE; 310 glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE;
296 glBindTexture GL_TEXTURE_2D, $tex->{name}; 311 glBindTexture GL_TEXTURE_2D, $tex->{name};
297 312
379 glDisable GL_BLEND; 394 glDisable GL_BLEND;
380} 395}
381 396
382my %DIR = ( 397my %DIR = (
383 SDLK_KP8, [1, "north"], 398 SDLK_KP8, [1, "north"],
384 SDLK_KP9, [2, "northest"], 399 SDLK_KP9, [2, "northeast"],
385 SDLK_KP6, [3, "east"], 400 SDLK_KP6, [3, "east"],
386 SDLK_KP3, [4, "southeast"], 401 SDLK_KP3, [4, "southeast"],
387 SDLK_KP2, [5, "south"], 402 SDLK_KP2, [5, "south"],
388 SDLK_KP1, [6, "southwest"], 403 SDLK_KP1, [6, "southwest"],
389 SDLK_KP4, [7, "west"], 404 SDLK_KP4, [7, "west"],
390 SDLK_KP7, [8, "northwest"], 405 SDLK_KP7, [8, "northwest"],
406
407 SDLK_UP, [1, "north"],
408 SDLK_RIGHT, [3, "east"],
409 SDLK_DOWN, [5, "south"],
410 SDLK_LEFT, [7, "west"],
391); 411);
392 412
393sub key_down { 413sub key_down {
394 my ($self, $ev) = @_; 414 my ($self, $ev) = @_;
395 415
398 418
399 if ($sym == SDLK_KP5) { 419 if ($sym == SDLK_KP5) {
400 $::CONN->send ("command stay fire"); 420 $::CONN->send ("command stay fire");
401 } elsif (exists $DIR{$sym}) { 421 } elsif (exists $DIR{$sym}) {
402 if ($mod & KMOD_SHIFT) { 422 if ($mod & KMOD_SHIFT) {
423 $self->{shft}++;
403 $::CONN->send ("command fire $DIR{$sym}[0]"); 424 $::CONN->send ("command fire $DIR{$sym}[0]");
404 } elsif ($mod & KMOD_CTRL) { 425 } elsif ($mod & KMOD_CTRL) {
426 $self->{ctrl}++;
405 $::CONN->send ("command run $DIR{$sym}[0]"); 427 $::CONN->send ("command run $DIR{$sym}[0]");
406 } else { 428 } else {
429 $::CONN->send ("command $DIR{$sym}[1]");
407 } 430 }
408 } 431 }
409} 432}
410 433
411sub key_up { 434sub key_up {
412 my ($self, $ev) = @_; 435 my ($self, $ev) = @_;
413 436
414 my $mod = $ev->key_mod; 437 my $mod = $ev->key_mod;
415 my $sym = $ev->key_sym; 438 my $sym = $ev->key_sym;
416 439
417 if (exists $DIR{$sym}) { 440 if (!($mod & KMOD_SHIFT) && delete $self->{shft}) {
418 if ($mod & KMOD_SHIFT) {
419 $::CONN->send ("command fire_stop"); 441 $::CONN->send ("command fire_stop");
420 } else { 442 }
443 if (!($mod & KMOD_CTRL ) && delete $self->{ctrl}) {
421 $::CONN->send ("command run_stop"); 444 $::CONN->send ("command run_stop");
422 }
423 } 445 }
424} 446}
425 447
4261; 4481;
427 449

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines