]> www.fi.muni.cz Git - slotcarman.git/blobdiff - SCX/GUI.pm
Another attempt at pit lane handling.
[slotcarman.git] / SCX / GUI.pm
index a0fd69122f6a36a7521020bdac13268f2fc1ab56..93e76b74761baf51d441fc6c17d0d27561f31013 100755 (executable)
@@ -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 {
@@ -123,7 +141,7 @@ sub set_lap {
        ++$row;
        my $label = $self->get_object("label_lap$row")
                or die "Can't get label_lap$row";
-       $label->set_label($text);
+       $label->set_markup('<span font_desc="24" weight="bold">'.$text.'</span>');
 }
 
 sub set_laptime {
@@ -132,16 +150,24 @@ sub set_laptime {
        ++$row;
        my $label = $self->get_object("label_laptime$row")
                or die "Can't get label_laptime$row";
-       $label->set_label($text);
+       $label->set_markup('<span font_desc="18" weight="bold">'.$text.'</span>');
 }
 
 sub set_best_lap {
-       my ($self, $row, $text) = @_;
+       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_label($text);
+
+       if ($global) {
+               $global = ' foreground="#e00000"';
+       } else {
+               $global = '';
+       }
+
+       $label->set_markup('<span font_desc="18" weight="bold"'.$global.'>'
+               .$text.'</span>');
 }
 
 sub set_driver {
@@ -150,7 +176,59 @@ sub set_driver {
        ++$row;
        my $label = $self->get_object("label_name$row")
                or die "Can't get label_lap$row";
-       $label->set_label($text);
+       $label->set_markup('<span font_desc="18" weight="bold">'.$text.'</span>');
+}
+
+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('<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, $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('<span font_desc="18" weight="bold">Best lap: '.$text.'</span>');
 }
 
 1;