]> www.fi.muni.cz Git - slotcarman.git/blobdiff - SCX/Car.pm
More GUI work.
[slotcarman.git] / SCX / Car.pm
index e55676dc43b9dc0cc005fe10648107abfb1f3e63..75aa503c49167763e89eca986f2691f87ee1ca31 100644 (file)
@@ -3,35 +3,53 @@
 package SCX::Car;
 
 use strict;
+use Time::HiRes qw(gettimeofday);
 
 sub new {
        my ($class, $args) = @_;
 
        my $self = {
-               gui => $args->{gui},
-               throttle => -1,
-               fuel => -1,
-               order => $args->{order},
+               gui      => $args->{gui},
+               driver   => $args->{driver} || '--',    
+               throttle => undef,
+               fuel     => 0,
+               lap      => 0,
+               laptime  => 0,
+               avg_lap  => 0,
+               car_img  => $args->{car_img},
+               id       => $args->{id},
+               track    => $args->{track},
        };
 
        bless $self, $class;
 
-       $self->set_throttle(undef);
-       $self->set_fuel(undef);
-
        return $self;
 }
 
 sub gui { return shift->{gui}; }
 
+sub track { return shift->{track}; }
+
+sub same {
+       my ($self, $key, $val) = @_;
+
+       return 1 if !defined $self->{$key} && !defined $val
+               || (defined $self->{$key} && defined $val
+                       && $self->{$key} eq $val);
+
+       $self->{$key} = $val;
+       return undef;
+}
+
 sub set_throttle {
        my ($self, $val) = @_;
 
-       return if (!defined $self->{throttle} && !defined $val)
-               || (defined $self->{throttle} && defined $val
-                       && $self->{throttle} == $val);
+       return if $self->same('throttle', $val);
 
-       $self->{throttle} = $val;
+       if ($self->track->{start_in_progress} && $val) {
+               $self->{early_start} = 1;
+               $self->gui->set_driver('Early start!');
+       }
        $self->gui->set_throttle($self->{order}, $val);
 }
 
@@ -39,11 +57,7 @@ sub set_throttle {
 sub set_fuel {
        my ($self, $val) = @_;
 
-       return if (!defined $self->{fuel} && !defined $val)
-               || (defined $self->{fuel} && defined $val
-                       && $self->{fuel} == $val);
-
-       $self->{fuel} = $val;
+       return if $self->same('fuel', $val);
        $self->gui->set_fuel($self->{order}, $val);
 }
 
@@ -55,5 +69,104 @@ sub set_backbutton {
        # TODO
 }
 
+sub set_model {
+       my ($self, $name) = @_;
+
+       return if $self->same('car_img', $name);
+       $self->gui->set_car_icon($self->{order}, $name);
+}
+
+sub set_lap {
+       my ($self, $lap_nr) = @_;
+
+       return if $self->same('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 {
+       my ($self, $lap_time) = @_;
+
+       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
+                       )) {
+
+                       $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;
+       }
+
+       return if (!defined $self->{laptime} && !defined $lap_time)
+               || (defined $self->{laptime} && defined $lap_time
+                       && $self->{laptime} == $lap_time);
+
+       $self->{laptime} = $lap_time;
+
+       $self->gui->set_laptime($self->{order}, defined $lap_time
+               ? $lap_time : '--');
+}
+
+sub set_driver {
+       my ($self, $driver_name) = @_;
+
+       return if $self->same('driver', $driver_name);
+       $self->gui->set_name($self->{order}, $driver_name);
+}
+
+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->{order} = $pos;
+       
+       $self->gui->set_name($self->{order}, $self->{driver});
+       $self->gui->set_car_icon($self->{order}, $self->{car_icon});
+       $self->gui->set_throttle($self->{order}, $self->{throttle});
+       $self->gui->set_lap($self->{order}, defined $self->{lap}
+               ? $self->{lap} : '--');
+       $self->gui->set_laptime($self->{order}, defined $self->{laptime}
+               ? $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});
+}
+       
 1;