--- deliantra/Deliantra-Client/DC/OpenGL.pm 2006/05/26 18:28:23 1.2 +++ deliantra/Deliantra-Client/DC/OpenGL.pm 2007/08/19 14:09:28 1.10 @@ -1,24 +1,27 @@ -package CFClient::OpenGL; +package CFPlus::OpenGL; use strict; use Carp (); -use CFClient; +use CFPlus; our %GL_EXT; our $GL_VERSION; our $GL_NPOT; +our $GL_COMPRESS; +our $GL_BFSEP; # blendfuncseparate our $DEBUG = 1; our %INIT_HOOK; +our %SHUTDOWN_HOOK; sub import { my $caller = caller; no strict; - my $symtab = *{"main::CFClient::OpenGL::"}{HASH}; + my $symtab = *{"main::CFPlus::OpenGL::"}{HASH}; for (keys %$symtab) { *{"$caller\::$_"} = *$_ @@ -30,19 +33,53 @@ $GL_VERSION = gl_version * 1; %GL_EXT = map +($_ => 1), split /\s+/, gl_extensions; - $GL_NPOT = $GL_EXT{GL_ARB_texture_non_power_of_two} || $GL_VERSION >= 2; - $GL_NPOT = 0 if gl_vendor =~ /ATI Technologies/; # ATI doesn't get it right... + unless (defined $::CFG->{force_opengl11}) { + # try to find a suitable default + if ( + $GL_VERSION >= 2.0 + && (!$GL_EXT{GL_ARB_texture_non_power_of_two} + || !$GL_EXT{GL_EXT_blend_func_separate}) + ) { + $::CFG->{force_opengl11} = 1; + } else { + $::CFG->{force_opengl11} = 0; + } + } + + if ($::CFG->{force_opengl11}) { + $GL_VERSION = 1.1; + %GL_EXT = (); + } + + $GL_BFSEP = $GL_EXT{GL_EXT_blend_func_separate} || $GL_VERSION >= 2.0; + $GL_NPOT = $GL_EXT{GL_ARB_texture_non_power_of_two} || $GL_VERSION >= 2.0; + $GL_COMPRESS = $GL_EXT{GL_ARB_texture_compression} || $GL_VERSION >= 1.3; + + disable_GL_EXT_blend_func_separate + unless $GL_BFSEP; glDisable GL_COLOR_MATERIAL; glShadeModel GL_FLAT; glDisable GL_DITHER; glDisable GL_DEPTH_TEST; glDepthMask 0; - glHint GL_PERSPECTIVE_CORRECTION_HINT, GL_FASTEST; + + my $hint = $::FAST ? GL_FASTEST : GL_NICEST; + glHint GL_PERSPECTIVE_CORRECTION_HINT, $hint; + glHint GL_POINT_SMOOTH_HINT , $hint; + glHint GL_LINE_SMOOTH_HINT , $hint; + glHint GL_POLYGON_SMOOTH_HINT , $hint; + glHint GL_GENERATE_MIPMAP_HINT , $hint; + #glDrawBuffer GL_BACK; + #glReadBuffer GL_BACK; $_->() for values %INIT_HOOK; } +sub shutdown { + $_->() for values %SHUTDOWN_HOOK; +} + sub gl_check { return unless $DEBUG;