]> www.fi.muni.cz Git - slotcarman.git/blobdiff - SCX/GUI.pm
Button reporting, fullscreen mode.
[slotcarman.git] / SCX / GUI.pm
index 4f02edc74a4c682c1d4173d7f687195a268549b7..08b4ea90354f1de859c069aaa0819d7e551fc0e0 100755 (executable)
@@ -5,8 +5,10 @@ package SCX::GUI;
 use strict;
 use utf8;
 
+use Carp;
 use Encode;
 use Gtk2 '-init';
+use Gtk2::Gdk::Keysyms;
 use Glib qw(TRUE FALSE);
 
 our $BASE_SIZE;
@@ -25,7 +27,7 @@ sub new {
 
        $self->{builder}->add_from_file('slotcarman.glade');
 
-       $self->{builder}->connect_signals(undef);
+       $self->{builder}->connect_signals($self);
        $self->load_all_images;
        $self->set_font_sizes;
 
@@ -59,14 +61,52 @@ sub delete_event { Gtk2->main_quit; }
 
 sub quit { Gtk2->main_quit; }
 
+use Data::Dumper;
+
+sub hotkey {
+       my ($window, $key, $self) = @_;
+
+       if ($key->keyval == $Gtk2::Gdk::Keysyms{F5}) {
+               if ($self->{fullscreen}) {
+                       leave_fullscreen($window, $self);
+               } else {
+                       fullscreen($window, $self);
+               }
+               return 1;
+       }
+       return 0;
+}
+
 sub fullscreen {
-       my ($self) = @_;
+       my ($widget, $self) = @_;
 
+       return if $self->{fullscreen};
+
+       $self->get_object('menubar1')->hide;
+       $self->get_object('statusbar1')->hide;
        $self->get_object('slotcarman')->fullscreen;
+
+       $self->{fullscreen} = 1;
        my $h = $self->get_object('image_car1')->allocation->height;
-       print "h=$h\n";
+       my $h1 = $self->get_object('slotcarman')->allocation->height;
+       print "h=$h, h1=$h1\n";
 }
-       
+
+sub leave_fullscreen {
+       my ($widget, $self) = @_;
+
+       return if !$self->{fullscreen};
+
+       $self->get_object('menubar1')->show;
+       $self->get_object('statusbar1')->show;
+       $self->get_object('slotcarman')->unfullscreen;
+
+       $self->{fullscreen} = undef;;
+       my $h = $self->get_object('image_car1')->allocation->height;
+       my $h1 = $self->get_object('slotcarman')->allocation->height;
+       print "h=$h, h1=$h1\n";
+}
+
 sub watch_resize {
        my ($window, $rectangle, $self) = @_;
        print "w=", $rectangle->width, ", h=", $rectangle->height, "\n";
@@ -79,25 +119,25 @@ sub set_font_sizes {
        my ($self) = @_;
 
        if ($self->{img_height} <= 80) {
-               $self->{label_font} = 10;
-               $self->{value_font} = 18;
-               $self->{lap_font} = 24;
+               $self->{label_size} = 10;
+               $self->{value_size} = 18;
+               $self->{lap_size} = 24;
        } elsif ($self->{img_height} <= 100) {
-               $self->{label_font} = 12;
-               $self->{value_font} = 20;
-               $self->{lap_font} = 28;
+               $self->{label_size} = 12;
+               $self->{value_size} = 20;
+               $self->{lap_size} = 28;
        } elsif ($self->{img_height} <= 120) {
-               $self->{label_font} = 14;
-               $self->{value_font} = 24;
-               $self->{lap_font} = 32;
+               $self->{label_size} = 14;
+               $self->{value_size} = 24;
+               $self->{lap_size} = 32;
        } elsif ($self->{img_height} <= 150) {
-               $self->{label_font} = 16;
-               $self->{value_font} = 28;
-               $self->{lap_font} = 36;
+               $self->{label_size} = 16;
+               $self->{value_size} = 28;
+               $self->{lap_size} = 36;
        } else {
-               $self->{label_font} = 18;
-               $self->{value_font} = 32;
-               $self->{lap_font} = 40;
+               $self->{label_size} = 18;
+               $self->{value_size} = 32;
+               $self->{lap_size} = 40;
        }
 }
 
@@ -109,12 +149,16 @@ sub load_all_images {
        $self->{throttle_images} = [
                load_image_set('img/throttle%d.svg', 13, $h)
        ];
+       $self->{throttle_button_images} = [
+               load_image_set('img/throttle%dbutton.svg', 12, $h)
+       ];
        $self->{fuel_images} = [
                        load_image_set('img/fuel%d.svg', 8, int(0.6 * $h))
        ];
-       $self->{car_images} = load_image_dir('img/SCXCars', $h),
-       $self->{semaphore_images} => [
-                       load_image_set('img/semaphore%d.svg', 5, 2 * $h)
+       $self->{car_images} = load_images_glob('img/SCXCars/*', $h);
+       $self->{state_images} = load_images_glob('img/state*.svg', $h);
+       $self->{semaphore_images} = [
+                       load_image_set('img/semaphore%d.svg', 5, 1.5 * $h)
        ];
 };
 
@@ -134,11 +178,11 @@ sub load_image_set {
        return @rv;
 }
 
-sub load_image_dir {
-       my ($dir, $height) = @_;
+sub load_images_glob {
+       my ($glob, $height) = @_;
 
        my %rv;
-       for my $file (<$dir/*>) {
+       for my $file (glob($glob)) {
                $file = Encode::decode('utf-8', $file);
                my $name = $file;
                $name =~ s/.*\///;
@@ -158,101 +202,111 @@ sub load_image_dir {
        return \%rv;
 }
 
+sub set_label {
+       my ($self, $prefix, $row, $text, $size) = @_;
+
+       ++$row if defined $row && $row =~ /\A\d+\z/xms;
+       $size //= 'value';
+
+       my $name = defined $row ? $prefix.$row : $prefix;
+       my $label = $self->get_object($name)
+               or croak "Can't get label named $name";
+       $label->set_markup('<span font_desc="' . $self->{$size.'_size'} . '"'
+               . ' weight="bold">' . $text . '</span>');
+}
+
+sub set_image {
+       my ($self, $prefix, $row, $imgset, $value) = @_;
+
+       return if !defined $value;
+
+       ++$row if defined $row && $row =~ /\A\d+\z/xms;
+
+       my $name = defined $row ? $prefix.$row : $prefix;
+
+       my $image = $self->get_object($name)
+               or croak "Can't get image named $name";
+
+       my $set = $self->{$imgset.'_images'};
+       my $pixbuf = (ref($set) eq 'ARRAY')
+               ? $set->[$value]
+               : $set->{$value};
+               
+       $image->set_from_pixbuf($pixbuf);
+}
+
 sub set_throttle {
-       my ($self, $row, $val) = @_;
+       my ($self, $row, $val, $button) = @_;
 
-       $row++;
        $val = 13 if !defined $val;
-
-       my $image = $self->get_object("image_throttle$row");
-       $image->set_from_pixbuf($self->{throttle_images}->[$val]);
+       $self->set_image('image_throttle', $row,
+               $button ? 'throttle_button' : 'throttle', $val);
 }
 
 sub set_fuel {
        my ($self, $row, $val) = @_;
 
-       $row++;
-       $val = 0 if !defined $val;
-
-       my $image = $self->get_object("image_fuel$row");
-       $image->set_from_pixbuf($self->{fuel_images}->[$val]);
+       $self->set_image('image_fuel', $row, 'fuel', $val || 0);
 }
 
 sub set_car_icon {
        my ($self, $row, $name) = @_;
 
-       $row++;
-       my $pixbuf = $self->{car_images}->{$name};
-       if (!$pixbuf) {
-               print "No car image for $name.\n";
-               return;
-       }
-
-       my $image = $self->get_object("image_car$row");
-       $image->set_from_pixbuf($pixbuf);
+       $self->set_image('image_car', $row, 'car', $name);
 }
 
 sub set_lap {
        my ($self, $row, $text) = @_;
 
-       ++$row;
-       my $label = $self->get_object("label_lap$row")
-               or die "Can't get label_lap$row";
-       $label->set_markup('<span font_desc="24" weight="bold">'.$text.'</span>');
+       $text = '--' if !defined $text;
+
+       $self->set_label('label_lap', $row, $text, 'lap');
+}
+
+sub set_distance {
+       my ($self, $row, $time, $lap_diff, $time_diff) = @_;
+
+       my $text = '--';
+
+       if (defined $time) {
+               $text = format_race_time($time);
+       } elsif (defined $time_diff) {
+               $text = '−' . format_lap_time($time_diff);
+       } elsif (defined $lap_diff) {
+               $text = '−' . $lap_diff . ' laps';
+       }
+
+       $self->set_label('label_distance', $row, $text);
 }
 
 sub set_laptime {
        my ($self, $row, $text) = @_;
 
-       ++$row;
-       my $label = $self->get_object("label_laptime$row")
-               or die "Can't get label_laptime$row";
-       $label->set_markup('<span font_desc="18" weight="bold">'.$text.'</span>');
+       $self->set_label('label_laptime', $row, format_lap_time($text));
 }
 
 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('<span font_desc="22" weight="bold">'.$text.'</span>');
+       $self->set_label('label_avg_lap', $row, format_lap_time($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";
-
-       if ($global) {
-               $global = ' foreground="#e00000"';
-       } else {
-               $global = '';
-       }
+       my ($self, $row, $text) = @_;
 
-       $label->set_markup('<span font_desc="18" weight="bold"'.$global.'>'
-               .$text.'</span>');
+       $self->set_label('label_best_lap', $row, format_lap_time($text));
 }
 
-sub set_driver {
+sub set_name {
        my ($self, $row, $text) = @_;
 
-       ++$row;
-       my $label = $self->get_object("label_name$row")
-               or die "Can't get label_lap$row";
-       $label->set_markup('<span font_desc="18" weight="bold">'.$text.'</span>');
+       $self->set_label('label_name', $row, $text);
 }
 
-sub enter_pit_lane {
-       my ($self, $row) = @_;
-       $self->set_laptime($row, 'PIT');
-}
+sub set_car_id {
+       my ($self, $row, $text) = @_;
 
-sub leave_pit_lane {
-       my ($self, $row) = @_;
-       $self->set_laptime($row, 'GO!');
+       $self->set_label('label_car_id', $row, $text);
 }
 
 sub show_semaphore {
@@ -272,29 +326,52 @@ sub show_semaphore {
 sub rounds {
        my ($self, $text) = @_;
 
-       my $label = $self->get_object("label_lap_global")
-               or die "Can't get label_lap_global";
-       $label->set_markup('<span font_desc="18" weight="bold">'.$text.'</span>');
+       $self->set_label('label_lap_global', undef, $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('<span font_desc="18" weight="bold">'.$text.'</span>');
+       $self->set_label('label_time_global', undef, format_race_time($text));
 }
 
 sub best_lap {
        my ($self, $time, $who) = @_;
 
-       my $text = $time;
+       my $text = format_lap_time($time);
        $text .= ' by ' . $who
                if defined $who;
+       $self->set_label('label_best_lap_global', undef, $text);
+}
+
+sub format_race_time {
+       my ($seconds) = @_;
+
+       return '--' if !defined $seconds;
+
+       my $hours = int($seconds / 3600);
+       $seconds -= 3600 * $hours;
+
+       my $mins = int($seconds / 60);
+       $seconds -= 60 * $mins;
+
+       return $hours
+               ? sprintf('%d:%02d:%04.1f', $hours, $mins, $seconds)
+               : sprintf('%d:%04.1f', $mins, $seconds);
+}
+
+sub format_lap_time {
+       my ($seconds) = @_;
+
+       return defined $seconds
+               ? sprintf('%.2f', $seconds)
+               : '--';
+}
+
+sub set_state {
+       my ($self, $num, $name) = @_;
 
-       my $label = $self->get_object("label_best_lap_global")
-               or die "Can't get label_best_lap_global";
-       $label->set_markup('<span font_desc="18" weight="bold">'.$text.'</span>');
+       $self->set_image('image_status', $num, 'state', 'state '.$name);
 }
 
 1;