X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Ftexture.cpp;h=581ec705690d556320bc412577a7ad8e5f4d0adb;hp=97a73d9e6f59c81b3f8ca5f85f55219a02476da7;hb=08e19bc2b4eba572bc7699378cf55cd8772ac67e;hpb=93fa68debcd6e416a1b20f43077f7a79525aaecb diff --git a/source/texture.cpp b/source/texture.cpp index 97a73d9e..581ec705 100644 --- a/source/texture.cpp +++ b/source/texture.cpp @@ -1,3 +1,4 @@ +#include #include #include #include @@ -63,6 +64,8 @@ Texture::Texture(GLenum t, ResourceManager *m): { if(m) set_manager(m); + else if(ARB_direct_state_access) + glCreateTextures(target, 1, &id); else glGenTextures(1, &id); } @@ -78,12 +81,12 @@ Texture::~Texture() DataType Texture::get_alloc_type(PixelFormat fmt) { - return (fmt==DEPTH_COMPONENT ? UNSIGNED_SHORT : UNSIGNED_BYTE); + return (get_base_pixelformat(fmt)==DEPTH_COMPONENT ? UNSIGNED_SHORT : UNSIGNED_BYTE); } void Texture::update_parameter(int mask) const { - if(TexUnit::current().get_texture()!=this) + if(!ARB_direct_state_access && TexUnit::current().get_texture()!=this) { TexUnit *unit = TexUnit::find_unit(this); if(!unit) @@ -96,23 +99,39 @@ void Texture::update_parameter(int mask) const } if(mask&MIN_FILTER) - glTexParameteri(target, GL_TEXTURE_MIN_FILTER, min_filter); + set_parameter_i(GL_TEXTURE_MIN_FILTER, min_filter); if(mask&MAG_FILTER) - glTexParameteri(target, GL_TEXTURE_MAG_FILTER, mag_filter); + set_parameter_i(GL_TEXTURE_MAG_FILTER, mag_filter); if(mask&MAX_ANISOTROPY) - glTexParameteri(target, GL_TEXTURE_MAX_ANISOTROPY_EXT, max_anisotropy); + set_parameter_f(GL_TEXTURE_MAX_ANISOTROPY_EXT, max_anisotropy); if(mask&WRAP_S) - glTexParameteri(target, GL_TEXTURE_WRAP_S, wrap_s); + set_parameter_i(GL_TEXTURE_WRAP_S, wrap_s); if(mask&WRAP_T) - glTexParameteri(target, GL_TEXTURE_WRAP_T, wrap_t); + set_parameter_i(GL_TEXTURE_WRAP_T, wrap_t); if(mask&WRAP_R) - glTexParameteri(target, GL_TEXTURE_WRAP_R, wrap_r); + set_parameter_i(GL_TEXTURE_WRAP_R, wrap_r); if(mask&GENERATE_MIPMAP) - glTexParameteri(target, GL_GENERATE_MIPMAP, gen_mipmap); + set_parameter_i(GL_GENERATE_MIPMAP, gen_mipmap); if(mask&COMPARE) - glTexParameteri(target, GL_TEXTURE_COMPARE_MODE, (compare ? GL_COMPARE_R_TO_TEXTURE : GL_NONE)); + set_parameter_i(GL_TEXTURE_COMPARE_MODE, (compare ? GL_COMPARE_R_TO_TEXTURE : GL_NONE)); if(mask&COMPARE_FUNC) - glTexParameteri(target, GL_TEXTURE_COMPARE_FUNC, cmp_func); + set_parameter_i(GL_TEXTURE_COMPARE_FUNC, cmp_func); +} + +void Texture::set_parameter_i(GLenum param, int value) const +{ + if(ARB_direct_state_access) + glTextureParameteri(id, param, value); + else + glTexParameteri(target, param, value); +} + +void Texture::set_parameter_f(GLenum param, float value) const +{ + if(ARB_direct_state_access) + glTextureParameterf(id, param, value); + else + glTexParameterf(target, param, value); } void Texture::set_min_filter(TextureFilter f) @@ -172,20 +191,22 @@ void Texture::set_wrap_r(TextureWrap w) void Texture::set_generate_mipmap(bool gm) { - if(gm) + if(gm && !EXT_framebuffer_object) static Require _req(SGIS_generate_mipmap); gen_mipmap = gm; - if(get_gl_api()!=OPENGL_ES2) + if(!EXT_framebuffer_object) update_parameter(GENERATE_MIPMAP); } void Texture::auto_generate_mipmap() { - if(get_gl_api()==OPENGL_ES2) + // glGenerateMipmap is defined here + if(EXT_framebuffer_object) { - // glGenerateMipmap is defined here - static Require _req(EXT_framebuffer_object); - glGenerateMipmap(target); + if(ARB_direct_state_access) + glGenerateTextureMipmap(id); + else + glGenerateMipmap(target); } } @@ -290,10 +311,10 @@ void Texture::Loader::init() add("external_image", &Loader::external_image); add("filter", &Loader::filter); - add("max_anisotropy", &Loader::max_anisotropy); add("generate_mipmap", &Loader::generate_mipmap); add("image_data", &Loader::image_data); add("mag_filter", &Loader::mag_filter); + add("max_anisotropy", &Loader::max_anisotropy); add("min_filter", &Loader::min_filter); add("wrap", &Loader::wrap); add("wrap_r", &Loader::wrap_r); @@ -364,5 +385,12 @@ void Texture::Loader::wrap_t(TextureWrap w) obj.set_wrap_t(w); } + +bool is_mipmapped(TextureFilter filter) +{ + return (filter==NEAREST_MIPMAP_NEAREST || filter==NEAREST_MIPMAP_LINEAR || + filter==LINEAR_MIPMAP_NEAREST || filter==LINEAR_MIPMAP_LINEAR); +} + } // namespace GL } // namespace Msp