--- Screen.pm 2007/08/05 01:31:41 142 +++ Screen.pm 2007/08/05 16:58:01 155 @@ -49,6 +49,7 @@ ); #$app->grab_input( SDL_GRAB_QUERY ); $app->grab_input( SDL_GRAB_OFF ); + $app->title( ref($self) ); $self->app( $app ); @@ -65,8 +66,6 @@ my $green = SDL::Color->new( -r => 0x00, -g => 0xff, -b => 0x00 ); my $blue = SDL::Color->new( -r => 0x00, -g => 0x00, -b => 0xff ); -my $rect_mem = SDL::Rect->new( -x => 256, -y => 0, -width => 256, -height => 256 ); - =head2 mem_xy Helper to return x and y coordinates in memory map @@ -155,7 +154,7 @@ my $scale = $self->scale || confess "no scale?"; - my $rect = SDL::Rect->new( -x => 0, -y => 0, -width => 256 * $scale, -height => 256 * $scale ); + my $rect = SDL::Rect->new( -x => 0, -y => 0, -width => 256 * $scale, -height => 256 * $scale ); my $rect_screen = SDL::Rect->new( -x => 0, -y => 0, -width => 256 * $scale, -height => 256 * $scale ); if ( $scale > 1 ) { @@ -197,7 +196,9 @@ $vram->display_format; - my $rect = SDL::Rect->new( -x => 0, -y => 0, -width => 256, -height => 256 ); + my $rect = SDL::Rect->new( -x => 0, -y => 0, -width => 256, -height => 256 ); + my $rect_mem = SDL::Rect->new( -x => 256 * $self->scale, -y => 0, -width => 256, -height => 256 ); + $vram->blit( $rect, $app, $rect_mem ); $app->sync; @@ -236,7 +237,20 @@ my $event = $self->event || confess "no event?"; - $event->poll || return $pending_key; + if ( ! $event->poll ) { + return $pending_key unless $self->can('session_event'); + if ( my $h = $self->session_event('key_pressed') ) { + my ( $key, $state ) = %$h; + if ( $state ) { + $pending_key = $key; + $key_down->{$key}++; + } else { + undef $pending_key; + $key_down->{$key} = 0; + } + } + return $pending_key; + } my $type = $event->type(); @@ -254,15 +268,17 @@ } else { warn "SDL_KEYDOWN ($type) = '$k'", $just_checking ? ' fake' : '', "\n"; $pending_key = $k; + $self->record_session('key_pressed', { $k => 1 }); } } elsif ( $type == SDL_KEYUP ) { my $up = $event->key_name(); - $key_down->{$up} = 0; warn "SDL_KEYUP ($type) = '$up'", $just_checking ? ' fake' : '', "\n"; + $self->record_session('key_pressed', { $up => 0 }); + $key_down->{$up} = 0; undef $pending_key; } - warn "key_pressed = $pending_key\n" if $pending_key; + warn "key_pressed = $pending_key\n" if ( $pending_key ); return $pending_key; } @@ -308,4 +324,5 @@ under the same terms as Perl itself. =cut + 1;