X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=SCX%2FGUI.pm;h=371f919b85e0a6a0c134826686a70b64236583c3;hb=8f29704c1e17195a4e195872ed518dd6d2f0dd62;hp=da3f9f45eb6a9256625fe9dc37ae2191d0bce495;hpb=e85448fbe0a0384457115dc91638aa773fd9c5c0;p=slotcarman.git
diff --git a/SCX/GUI.pm b/SCX/GUI.pm
index da3f9f4..371f919 100755
--- a/SCX/GUI.pm
+++ b/SCX/GUI.pm
@@ -8,6 +8,7 @@ use utf8;
use Carp;
use Encode;
use Gtk2 '-init';
+use Gtk2::Gdk::Keysyms;
use Glib qw(TRUE FALSE);
our $BASE_SIZE;
@@ -26,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;
@@ -60,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 && $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";
@@ -81,7 +120,7 @@ sub set_font_sizes {
if ($self->{img_height} <= 80) {
$self->{label_size} = 10;
- $self->{value_size} = 18;
+ $self->{value_size} = 16;
$self->{lap_size} = 24;
} elsif ($self->{img_height} <= 100) {
$self->{label_size} = 12;
@@ -110,6 +149,9 @@ 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))
];
@@ -194,15 +236,18 @@ sub set_image {
}
sub set_throttle {
- my ($self, $row, $val) = @_;
+ my ($self, $row, $val, $button) = @_;
$val = 13 if !defined $val;
- $self->set_image('image_throttle', $row, 'throttle', $val);
+ $self->set_image('image_throttle', $row,
+ $button ? 'throttle_button' : 'throttle', $val);
}
sub set_fuel {
my ($self, $row, $val) = @_;
+ return if $val > 8;
+
$self->set_image('image_fuel', $row, 'fuel', $val || 0);
}
@@ -221,16 +266,21 @@ sub set_lap {
}
sub set_distance {
- my ($self, $row, $time, $lap_diff, $time_diff) = @_;
+ my ($self, $row, $time, $lap_diff, $time_diff, $greyout) = @_;
my $text = '--';
if (defined $time) {
$text = format_race_time($time);
} elsif (defined $time_diff) {
- $text = 'â' . format_lap_time($time_diff);
+ $text = '+' . format_lap_time($time_diff);
} elsif (defined $lap_diff) {
- $text = 'â' . $lap_diff . ' laps';
+ $text = '+' . $lap_diff
+ . ($lap_diff == 1 ? ' lap' : ' laps');
+ }
+
+ if ($greyout) {
+ $text = '' . $text . '';
}
$self->set_label('label_distance', $row, $text);
@@ -242,16 +292,14 @@ sub set_laptime {
$self->set_label('label_laptime', $row, format_lap_time($text));
}
-sub set_avg_lap {
- my ($self, $row, $text) = @_;
-
- $self->set_label('label_avg_lap', $row, format_lap_time($text));
-}
-
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 = '' . $text . '';
+ }
+ $self->set_label('label_best_lap', $row, $text);
}
sub set_name {