X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=SCX%2FTrack.pm;h=bd6ceea620e9d3626cba484c34f5f9f8c094944d;hb=b2e460537776f9b9de508c28b8e769cf8e80c30d;hp=32f03f40555bcf95fd8d7586e5c4f7efe7fd54ed;hpb=9aec101d497a8b3549b7150b0371e18c4c843f6a;p=slotcarman.git diff --git a/SCX/Track.pm b/SCX/Track.pm index 32f03f4..bd6ceea 100644 --- a/SCX/Track.pm +++ b/SCX/Track.pm @@ -5,6 +5,7 @@ package SCX::Track; use strict; use Carp; +use Time::HiRes qw(gettimeofday); use Glib qw(TRUE FALSE); use SCX::Car; @@ -19,14 +20,17 @@ sub new { $self->{race_running} = 0; $self->{lap_counting_up} = 1; + bless $self, $class; + for my $i (0..5) { $self->{cars}->[$i] = SCX::Car->new({ gui => $self->{gui}, order => $i, + track => $self, }); } - bless $self, $class; + return $self; } sub car { return shift->{cars}->[shift]; } @@ -95,7 +99,23 @@ sub race_setup { for my $car (0..5) { $self->car($car)->set_order($car); + $self->car($car)->set_lap(0); + $self->car($car)->set_laptime(undef); + } +} + +sub check_best_lap { + my ($self, $time, $who) = @_; + + return if !defined $time || $time == 0; + + if (!defined $self->{best_lap} + || $time < $self->{best_lap}) { + $self->{best_lap} = $time; + $self->{gui}->best_lap(sprintf("%.2f", $time), $who); + return 1; } + return 0; } 1;