X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=SCX%2FGUI.pm;h=93e76b74761baf51d441fc6c17d0d27561f31013;hb=44baa43e3817096004883f4fac2d8008c96520a2;hp=9190fe39a328a4660dcb2e612d65893751aeea24;hpb=e22f8cbb94df063c77cc9ee5f5bae839e252777d;p=slotcarman.git diff --git a/SCX/GUI.pm b/SCX/GUI.pm index 9190fe3..93e76b7 100755 --- a/SCX/GUI.pm +++ b/SCX/GUI.pm @@ -5,6 +5,7 @@ package SCX::GUI; use strict; use utf8; +use Encode; use Gtk2 '-init'; use Glib qw(TRUE FALSE); @@ -18,9 +19,15 @@ sub new { load_image_set('img/throttle%d.svg', 13, 100) ], fuel_images => [ - load_image_set('img/fuel%d.svg', 8, 100) + load_image_set('img/fuel%d.svg', 8, 60) + ], + car_images => load_image_dir('img/SCXCars', 100), + semaphore_images => [ + load_image_set('img/semaphore%d.svg', 5, 200) ], builder => Gtk2::Builder->new, + semaphore_win => Gtk2::Window->new('popup'), + semaphore_img => Gtk2::Image->new, }; bless $self, $class; @@ -29,6 +36,16 @@ sub new { $self->{builder}->connect_signals(undef); + my $pixbuf = $self->{semaphore_images}->[0]; + $self->{semaphore_img}->set_from_pixbuf($pixbuf); + $self->{semaphore_img}->show; + $self->{semaphore_win}->add($self->{semaphore_img}); + $self->{semaphore_win}->set_type_hint('splashscreen'); + $self->{semaphore_win}->set_position('center-on-parent'); + $self->{semaphore_win}->set_transient_for( + $self->{builder}->get_object('slotcarman') + ); + return $self; } @@ -36,9 +53,12 @@ sub show { my ($self) = @_; my $window = $self->{builder}->get_object('slotcarman'); + $window->signal_connect(delete_event => \&delete_event); $window->show(); } +sub delete_event { Gtk2->main_quit; } + sub get_object { return shift->{builder}->get_object(@_); } sub load_image_set { @@ -57,6 +77,30 @@ sub load_image_set { return @rv; } +sub load_image_dir { + my ($dir, $height) = @_; + + my %rv; + for my $file (<$dir/*>) { + $file = Encode::decode('utf-8', $file); + my $name = $file; + $name =~ s/.*\///; + $name =~ s/\..*?$//; + $name =~ s/[-_]/ /g; + $name =~ s/\s+/ /g; + + + my $dummy = Gtk2::Gdk::Pixbuf->new_from_file($file) + or next; + + my $width = $dummy->get_width * $height / $dummy->get_height; + $rv{$name} = Gtk2::Gdk::Pixbuf->new_from_file_at_scale( + $file, $width, $height, TRUE + ); + } + return \%rv; +} + sub set_throttle { my ($self, $row, $val) = @_; @@ -77,5 +121,115 @@ sub set_fuel { $image->set_from_pixbuf($self->{fuel_images}->[$val]); } +sub set_car_icon { + my ($self, $row, $name) = @_; + + $row++; + my $pixbuf = $self->{car_images}->{$name}; + if (!$pixbuf) { + print "No car image for $name.\n"; + return; + } + + my $image = $self->get_object("image_car$row"); + $image->set_from_pixbuf($pixbuf); +} + +sub set_lap { + my ($self, $row, $text) = @_; + + ++$row; + my $label = $self->get_object("label_lap$row") + or die "Can't get label_lap$row"; + $label->set_markup(''.$text.''); +} + +sub set_laptime { + my ($self, $row, $text) = @_; + + ++$row; + my $label = $self->get_object("label_laptime$row") + or die "Can't get label_laptime$row"; + $label->set_markup(''.$text.''); +} + +sub set_best_lap { + my ($self, $row, $text, $global) = @_; + + ++$row; + my $label = $self->get_object("label_best_lap$row") + or die "Can't get label_best_lap$row"; + + if ($global) { + $global = ' foreground="#e00000"'; + } else { + $global = ''; + } + + $label->set_markup('' + .$text.''); +} + +sub set_driver { + my ($self, $row, $text) = @_; + + ++$row; + my $label = $self->get_object("label_name$row") + or die "Can't get label_lap$row"; + $label->set_markup(''.$text.''); +} + +sub enter_pit_lane { + my ($self, $row) = @_; + $self->set_laptime($row, 'PIT'); +} + +sub leave_pit_lane { + my ($self, $row) = @_; + $self->set_laptime($row, 'GO!'); +} + +sub show_semaphore { + my ($self, $num) = @_; + + my $win = $self->{semaphore_win}; + if (defined $num) { + my $img = $self->{semaphore_img}; + my $pixbuf = $self->{semaphore_images}->[$num]; + $img->set_from_pixbuf($pixbuf); + $win->show; + } else { + $win->hide; + } +} + +sub rounds { + my ($self, $text) = @_; + + my $label = $self->get_object("label_lap_global") + or die "Can't get label_lap_global"; + $label->set_markup('Lap: '.$text.''); +} + +sub time { + my ($self, $text) = @_; + + my $label = $self->get_object("label_time_global") + or die "Can't get label_time_global"; + $label->set_markup('Time: '.$text.''); +} + +sub best_lap { + my ($self, $time, $who) = @_; + + my $text = $time; + $text .= ' by ' . $who + if defined $who; + + my $label = $self->get_object("label_best_lap_global") + or die "Can't get label_best_lap_global"; + $label->set_markup('Best lap: '.$text.''); +} + 1;