]> www.fi.muni.cz Git - slotcarman.git/commitdiff
Highlight the best lap
authorJan "Yenya" Kasprzak <kas@fi.muni.cz>
Sun, 8 May 2011 21:01:16 +0000 (23:01 +0200)
committerJan "Yenya" Kasprzak <kas@fi.muni.cz>
Sun, 8 May 2011 21:01:16 +0000 (23:01 +0200)
SCX/Car.pm
SCX/GUI.pm
SCX/Track.pm

index 1a74c6b3a342b8d9439fa0c3151dbf586dc7d8c9..2bb67617e2222aaa9f164bc80d7d8e3c7d089ce9 100644 (file)
@@ -121,8 +121,9 @@ sub set_laptime {
        my ($self, $lap_time) = @_;
 
        if (!defined $lap_time) {
-               $self->gui->set_best_lap($self->{order}, undef);
                $self->{best_lap} = undef;
+               $self->{global_best_lap} = undef;
+               $self->print_best_lap;
        }
 
        return if $self->same('laptime', $lap_time);
@@ -137,10 +138,21 @@ sub set_laptime {
        return if defined $self->{best_lap} && $self->{best_lap} <= $lap_time;
 
        $self->{best_lap} = $lap_time;
-       my $global = $self->{track}->check_best_lap($lap_time,
+       $self->print_best_lap;
+       $self->{track}->notify_best_lap($self->{id}, $lap_time,
                $self->{driver});
+}
+
+sub print_best_lap {
+       my ($self) = @_;
+       $self->gui->set_best_lap($self->{order}, $self->{best_lap},
+               $self->{global_best_lap});
+}
+
+sub set_global_best {
+       my ($self, $val) = @_;
 
-       $self->gui->set_best_lap($self->{order}, $lap_time, $global);
+       $self->{global_best_lap} = $val ? 1 : undef;
 }
 
 sub set_driver {
@@ -179,12 +191,12 @@ sub set_order {
                $self->{button});
        $self->gui->set_lap($self->{order}, $self->{lap});
        $self->gui->set_laptime($self->{order}, $self->{laptime});
-       $self->gui->set_best_lap($self->{order}, $self->{best_lap});
        $self->gui->set_fuel($self->{order}, $self->{fuel});
        $self->gui->set_car_id($self->{order}, $self->{id} + 1);
        $self->gui->set_distance($self->{order},
                $self->{time_diff}, $self->{lap_diff}, $self->{grey_diff});
        $self->print_state;
+       $self->print_best_lap;
 }
 
 sub print_state {
index af9f769493d4ae7bdca18409ed15ac0589b79106..3ad230cfd5e08f4d8ff10196fdd00efabeed1d9b 100755 (executable)
@@ -293,9 +293,13 @@ sub set_laptime {
 }
 
 sub set_best_lap {
-       my ($self, $row, $text) = @_;
+       my ($self, $row, $text, $overall_best) = @_;
 
-       $self->set_label('label_best_lap', $row, format_lap_time($text));
+       $text = format_lap_time($text);
+       if ($overall_best) {
+               $text = '<span fgcolor="red">' . $text . '</span>';
+       }
+       $self->set_label('label_best_lap', $row, $text);
 }
 
 sub set_name {
index 6ed3d822581242fb96e88dc86d7c9f3b626196e3..097dde88cf565be597ed55bfda6b069f6b44956d 100644 (file)
@@ -145,8 +145,8 @@ sub print_rounds {
        $self->{gui}->rounds($msg);
 }
 
-sub check_best_lap {
-       my ($self, $time, $who) = @_;
+sub notify_best_lap {
+       my ($self, $id, $time, $who) = @_;
 
        return if !defined $time || $time == 0;
 
@@ -157,6 +157,11 @@ sub check_best_lap {
                || $time < $self->{best_lap}) {
                $self->{best_lap} = $time;
                $self->{gui}->best_lap($time, $who);
+
+               for my $car (0..5) {
+                       $self->car($car)->set_global_best($car == $id);
+                       $self->car($car)->print_best_lap;
+               }
                return 1;
        }
        return 0;