X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=SCX%2FGUI.pm;h=573843172d28fff1825f0bcbae8a0f8e4f362ddc;hb=3043b1b70f247549f10fa5e3ce713c2a80cd2200;hp=0945af80c0dcae3b86417a14db61408710195848;hpb=5b79d179640c5bd695557505853f55fd1a035aa4;p=slotcarman.git diff --git a/SCX/GUI.pm b/SCX/GUI.pm index 0945af8..5738431 100755 --- a/SCX/GUI.pm +++ b/SCX/GUI.pm @@ -22,7 +22,12 @@ sub new { 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; } @@ -166,5 +181,19 @@ sub leave_pit_lane { $self->set_laptime($row, '--'); } +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; + } +} + 1;