]> www.fi.muni.cz Git - slotcarman.git/blobdiff - SCX/GUI.pm
Race setup, car reordering.
[slotcarman.git] / SCX / GUI.pm
index 0945af80c0dcae3b86417a14db61408710195848..e782ba768e54e1f44477163759c65c85154da818 100755 (executable)
@@ -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,43 @@ 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;
+       }
+}
+
+sub rounds {
+       my ($self, $text) = @_;
+
+       my $label = $self->get_object("label_lap_global")
+               or die "Can't get label_lap_global";
+       $label->set_markup('<span font_desc="18" weight="bold">Lap '.$text.'</span>');
+}
+
+sub time {
+       my ($self, $text) = @_;
+
+       my $label = $self->get_object("label_time_global")
+               or die "Can't get label_time_global";
+       $label->set_markup('<span font_desc="18" weight="bold">Time '.$text.'</span>');
+}
+
+sub best_lap {
+       my ($self, $text) = @_;
+
+       my $label = $self->get_object("label_best_lap_global")
+               or die "Can't get label_best_lap_global";
+       $label->set_markup('<span font_desc="18" weight="bold">Best lap '.$text.'</span>');
+}
+
 1;