X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;ds=inline;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;