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=573843172d28fff1825f0bcbae8a0f8e4f362ddc;hpb=3043b1b70f247549f10fa5e3ce713c2a80cd2200;p=slotcarman.git diff --git a/SCX/GUI.pm b/SCX/GUI.pm index 5738431..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,13 +210,30 @@ sub set_laptime { $label->set_markup(''.$text.''); } -sub set_best_lap { +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) = @_; + ++$row; my $label = $self->get_object("label_best_lap$row") or die "Can't get label_best_lap$row"; - $label->set_markup(''.$text.''); + + if ($global) { + $global = ' foreground="#e00000"'; + } else { + $global = ''; + } + + $label->set_markup('' + .$text.''); } sub set_driver { @@ -178,7 +252,7 @@ sub enter_pit_lane { sub leave_pit_lane { my ($self, $row) = @_; - $self->set_laptime($row, '--'); + $self->set_laptime($row, 'GO!'); } sub show_semaphore { @@ -195,5 +269,33 @@ 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(''.$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(''.$text.''); +} + +sub best_lap { + my ($self, $time, $who) = @_; + + my $text = $time; + $text .= ' by ' . $who + if defined $who; + + my $label = $self->get_object("label_best_lap_global") + or die "Can't get label_best_lap_global"; + $label->set_markup(''.$text.''); +} + 1;