X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Ftexture.cpp;h=f1689145c8af9c5754569213a7561b0505e63b2c;hp=c367397fb76bb19d2392b17971b915b1a31ea9a8;hb=HEAD;hpb=84bc56b96c21c831104a22e0cbd0f3b72ab5d8c3 diff --git a/source/texture.cpp b/source/texture.cpp deleted file mode 100644 index c367397f..00000000 --- a/source/texture.cpp +++ /dev/null @@ -1,65 +0,0 @@ -#include -#include "texture.h" -#include "texunit.h" - -namespace Msp { -namespace GL { - -void Texture::bind() const -{ - if(!target) - throw InvalidState("Attempt to bind a texture without target"); - - const Texture *cur=TexUnit::current().get_texture(); - if(cur && cur->target!=target) - glDisable(cur->target); - if(!cur || cur->target!=target) - glEnable(target); - glBindTexture(target, id); - TexUnit::current().set_texture(this); -} - -void Texture::parameter(GLenum param, int value) -{ - maybe_bind(); - - glTexParameteri(target, param, value); -} - -void Texture::parameter(GLenum param, float value) -{ - maybe_bind(); - - glTexParameterf(target, param, value); -} - -Texture::~Texture() -{ - glDeleteTextures(1, &id); -} - -void Texture::unbind() -{ - const Texture *cur=TexUnit::current().get_texture(); - if(!cur) - return; - - glBindTexture(cur->target, 0); - glDisable(cur->target); - TexUnit::current().set_texture(0); -} - -Texture::Texture(): - target(0) -{ - glGenTextures(1, &id); -} - -void Texture::maybe_bind() const -{ - if(TexUnit::current().get_texture()!=this) - bind(); -} - -} // namespace GL -} // namespace Msp