--- deliantra/Deliantra-Client/DC/UI.pm 2006/04/20 21:28:51 1.143 +++ deliantra/Deliantra-Client/DC/UI.pm 2006/04/21 15:03:46 1.146 @@ -627,7 +627,7 @@ use CFClient::OpenGL; my @tex = - map { new_from_file CFClient::Texture CFClient::find_rcfile $_ } + map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } qw(d1_bg.png d1_border_top.png d1_border_right.png d1_border_left.png d1_border_bottom.png); sub new { @@ -1113,6 +1113,13 @@ delete $self->{texture}; } +sub set_fontsize { + my ($self, $fontsize) = @_; + + $self->{fontsize} = $fontsize; + $self->update; +} + sub _draw { my ($self) = @_; @@ -1346,7 +1353,7 @@ use CFClient::OpenGL; my @tex = - map { new_from_file CFClient::Texture CFClient::find_rcfile $_ } + map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } qw(b1_button_active.png); sub new { @@ -1403,7 +1410,7 @@ our @ISA = CFClient::UI::DrawBG::; my @tex = - map { new_from_file CFClient::Texture CFClient::find_rcfile $_ } + map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } qw(c1_checkbox_bg.png c1_checkbox_active.png); use CFClient::OpenGL; @@ -1462,6 +1469,65 @@ ############################################################################# +package CFClient::UI::Image; + +our @ISA = CFClient::UI::Base::; + +use CFClient::OpenGL; +use Carp qw/confess/; + +our %loaded_images; + +sub new { + my $class = shift; + + my $self = $class->SUPER::new (@_); + + $self->{image} or confess "Image has 'image' not set. This is a fatal error!"; + + $loaded_images{$self->{image}} ||= + new_from_file CFClient::Texture CFClient::find_rcfile $self->{image}, mipmap => 1; + + my $tex = $self->{tex} = $loaded_images{$self->{image}}; + + $self->{aspect} = $tex->{w} / $tex->{h}; + + $self +} + +sub size_request { + my ($self) = @_; + + ($self->{tex}->{w}, $self->{tex}->{h}) +} + +sub _draw { + my ($self) = @_; + + my $tex = $self->{tex}; + + my ($w, $h) = ($self->{w}, $self->{h}); + + if ($self->{rot90}) { + glRotate 90, 0, 0, 1; + glTranslate 0, -$self->{w}, 0; + + ($w, $h) = ($h, $w); + } + + glEnable GL_BLEND; + glBlendFunc GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA; + glEnable GL_TEXTURE_2D; + glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE; + + $tex->draw_quad (0, 0, $w, $h); + + glDisable GL_BLEND; + glDisable GL_TEXTURE_2D; +} + +############################################################################# + package CFClient::UI::VGauge; our @ISA = CFClient::UI::Base::; @@ -1470,19 +1536,19 @@ my %tex = ( food => [ - map { new_from_file CFClient::Texture CFClient::find_rcfile $_ } + map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } qw/g1_food_gauge_empty.png g1_food_gauge_full.png/ ], grace => [ - map { new_from_file CFClient::Texture CFClient::find_rcfile $_ } + map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } qw/g1_grace_gauge_empty.png g1_grace_gauge_full.png/ ], hp => [ - map { new_from_file CFClient::Texture CFClient::find_rcfile $_ } + map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } qw/g1_hp_gauge_empty.png g1_hp_gauge_full.png/ ], mana => [ - map { new_from_file CFClient::Texture CFClient::find_rcfile $_ } + map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } qw/g1_mana_gauge_empty.png g1_mana_gauge_full.png/ ], ); @@ -1595,6 +1661,14 @@ $self } +sub set_fontsize { + my ($self, $fsize) = @_; + + $self->{value}->set_fontsize ($fsize); + $self->{max} ->set_fontsize ($fsize); + $self->update; +} + sub set_value { my ($self, $val, $max) = @_; @@ -2029,6 +2103,10 @@ sub add { my ($self, $child) = @_; + # integerize window positions + $child->{x} = int $child->{x}; + $child->{y} = int $child->{y}; + $self->SUPER::add ($child); }