X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=SCX%2FGUI.pm;h=0e01d17ddce05bc35d7fbd41a3a2bf456f50bb6b;hb=cf325864a622b3c2457ca8524fc25f144cd5f7b6;hp=813d111fa73274e56a2f6ac8aa7cfe0e9adaca03;hpb=80b9a4da1e01cf9ceac139d8276bbb951077115a;p=slotcarman.git diff --git a/SCX/GUI.pm b/SCX/GUI.pm index 813d111..0e01d17 100755 --- a/SCX/GUI.pm +++ b/SCX/GUI.pm @@ -19,10 +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; @@ -31,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; } @@ -38,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 { @@ -135,13 +153,30 @@ sub set_laptime { $label->set_markup(''.$text.''); } -sub set_best_lap { +sub set_avg_lap { my ($self, $row, $text) = @_; + ++$row; + my $label = $self->get_object("label_avg_lap$row") + or die "Can't get label_avg_lap$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"; - $label->set_markup(''.$text.''); + + if ($global) { + $global = ' foreground="#e00000"'; + } else { + $global = ''; + } + + $label->set_markup('' + .$text.''); } sub set_driver { @@ -153,5 +188,57 @@ sub set_driver { $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(''.$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(''.$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(''.$text.''); +} + 1;