X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=SCX%2FGUI.pm;h=4f02edc74a4c682c1d4173d7f687195a268549b7;hb=8b83962ae36e5857f1da21b451b0acbb3a55a289;hp=93e76b74761baf51d441fc6c17d0d27561f31013;hpb=40f9541dab84b42d79b20b56154873ff479d5c03;p=slotcarman.git
diff --git a/SCX/GUI.pm b/SCX/GUI.pm
index 93e76b7..4f02edc 100755
--- a/SCX/GUI.pm
+++ b/SCX/GUI.pm
@@ -9,22 +9,13 @@ use Encode;
use Gtk2 '-init';
use Glib qw(TRUE FALSE);
-use SCX::Reader;
+our $BASE_SIZE;
sub new {
my ($class, $args) = @_;
my $self = {
- throttle_images => [
- load_image_set('img/throttle%d.svg', 13, 100)
- ],
- fuel_images => [
- load_image_set('img/fuel%d.svg', 8, 60)
- ],
- car_images => load_image_dir('img/SCXCars', 100),
- semaphore_images => [
- load_image_set('img/semaphore%d.svg', 5, 200)
- ],
+ img_height => $args->{img_height} || 100,
builder => Gtk2::Builder->new,
semaphore_win => Gtk2::Window->new('popup'),
semaphore_img => Gtk2::Image->new,
@@ -35,6 +26,8 @@ sub new {
$self->{builder}->add_from_file('slotcarman.glade');
$self->{builder}->connect_signals(undef);
+ $self->load_all_images;
+ $self->set_font_sizes;
my $pixbuf = $self->{semaphore_images}->[0];
$self->{semaphore_img}->set_from_pixbuf($pixbuf);
@@ -43,9 +36,14 @@ sub new {
$self->{semaphore_win}->set_type_hint('splashscreen');
$self->{semaphore_win}->set_position('center-on-parent');
$self->{semaphore_win}->set_transient_for(
- $self->{builder}->get_object('slotcarman')
+ $self->get_object('slotcarman')
);
+ $self->get_object('image_car1')->signal_connect(
+ 'size_allocate' => \&watch_resize,
+ $self,
+ );
+
return $self;
}
@@ -59,8 +57,67 @@ sub show {
sub delete_event { Gtk2->main_quit; }
+sub quit { Gtk2->main_quit; }
+
+sub fullscreen {
+ my ($self) = @_;
+
+ $self->get_object('slotcarman')->fullscreen;
+ my $h = $self->get_object('image_car1')->allocation->height;
+ print "h=$h\n";
+}
+
+sub watch_resize {
+ my ($window, $rectangle, $self) = @_;
+ print "w=", $rectangle->width, ", h=", $rectangle->height, "\n";
+ # TODO
+}
+
sub get_object { return shift->{builder}->get_object(@_); }
+sub set_font_sizes {
+ my ($self) = @_;
+
+ if ($self->{img_height} <= 80) {
+ $self->{label_font} = 10;
+ $self->{value_font} = 18;
+ $self->{lap_font} = 24;
+ } elsif ($self->{img_height} <= 100) {
+ $self->{label_font} = 12;
+ $self->{value_font} = 20;
+ $self->{lap_font} = 28;
+ } elsif ($self->{img_height} <= 120) {
+ $self->{label_font} = 14;
+ $self->{value_font} = 24;
+ $self->{lap_font} = 32;
+ } elsif ($self->{img_height} <= 150) {
+ $self->{label_font} = 16;
+ $self->{value_font} = 28;
+ $self->{lap_font} = 36;
+ } else {
+ $self->{label_font} = 18;
+ $self->{value_font} = 32;
+ $self->{lap_font} = 40;
+ }
+}
+
+sub load_all_images {
+ my ($self) = @_;
+
+ my $h = $self->{img_height};
+
+ $self->{throttle_images} = [
+ load_image_set('img/throttle%d.svg', 13, $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)
+ ];
+};
+
sub load_image_set {
my ($pattern, $limit, $height) = @_;
@@ -153,6 +210,15 @@ sub set_laptime {
$label->set_markup(''.$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(''.$text.'');
+}
+
sub set_best_lap {
my ($self, $row, $text, $global) = @_;
@@ -208,7 +274,7 @@ sub rounds {
my $label = $self->get_object("label_lap_global")
or die "Can't get label_lap_global";
- $label->set_markup('Lap: '.$text.'');
+ $label->set_markup(''.$text.'');
}
sub time {
@@ -216,7 +282,7 @@ sub time {
my $label = $self->get_object("label_time_global")
or die "Can't get label_time_global";
- $label->set_markup('Time: '.$text.'');
+ $label->set_markup(''.$text.'');
}
sub best_lap {
@@ -228,7 +294,7 @@ sub best_lap {
my $label = $self->get_object("label_best_lap_global")
or die "Can't get label_best_lap_global";
- $label->set_markup('Best lap: '.$text.'');
+ $label->set_markup(''.$text.'');
}
1;