throttle => -1,
fuel => -1,
order => $args->{order},
+ track => $args->{track},
};
bless $self, $class;
sub gui { return shift->{gui}; }
+sub track { return shift->{track}; }
+
sub set_throttle {
my ($self, $val) = @_;
|| (defined $self->{throttle} && defined $val
&& $self->{throttle} == $val);
- if ($self->{in_pit_lane} && defined $val && $val > 3) {
- delete $self->{in_pit_lane};
- $self->gui->leave_pit_lane;
- }
-
$self->{throttle} = $val;
$self->gui->set_throttle($self->{order}, $val);
}
$self->{lap} = $lap_nr;
$self->gui->set_lap($self->{order}, defined $lap_nr ? $lap_nr : '--');
+ if ($self->track->{race_running} && $self->{lap} > 1) {
+ my $now = gettimeofday;
+ my $avg = ($now - $self->track->{race_running_since})
+ / ($self->{lap} - 1);
+ $self->{avg_lap} = $avg;
+ $self->gui->set_avg_lap($self->{order}, $avg);
+ } else {
+ $self->gui->set_avg_lap($self->{order}, '--');
+ }
}
sub set_laptime {
if (defined $lap_time) {
$lap_time = sprintf("%.2f", $lap_time);
- if ($lap_time > 1.0 && (
- !$self->{in_pit_lane} && !defined $self->{best_lap}
- || $self->{best_lap} > $lap_time
+ if ($lap_time > 1.0 && !$self->{in_pit_lane}
+ && (!defined $self->{best_lap}
+ || $self->{best_lap} > $lap_time
)) {
- $self->gui->set_best_lap($self->{order}, $lap_time);
$self->{best_lap} = $lap_time;
+ my $global = $self->{track}->check_best_lap($lap_time,
+ $self->{driver}
+ );
+ $self->gui->set_best_lap($self->{order}, $lap_time,
+ $global);
}
-
} else {
$self->gui->set_best_lap($self->{order}, '--');
$self->{best_lap} = undef;
sub enter_pit_lane {
my ($self) = @_;
+ return if $self->{in_pit_lane};
+
$self->{in_pit_lane} = 1;
$self->gui->enter_pit_lane;
}
+sub leave_pit_lane {
+ my ($self) = @_;
+
+ return if !$self->{in_pit_lane};
+
+ $self->{in_pit_lane} = 0;
+ $self->gui->leave_pit_lane;
+}
+
sub set_order {
my ($self, $pos) = @_;
? $self->{laptime} : '--');
$self->gui->set_best_lap($self->{order}, defined $self->{best_lap}
? $self->{best_lap} : '--');
+ $self->gui->set_avg_lap($self->{order}, defined $self->{avg_lap}
+ ? $self->{avg_lap} : '--');
$self->gui->set_fuel($self->{order}, $self->{fuel});
}