vcglib/wrap/glw/texture2d.h

254 lines
6.1 KiB
C
Raw Normal View History

2012-04-30 20:23:53 +02:00
#ifndef GLW_TEXTURE2D_H
#define GLW_TEXTURE2D_H
#include "./texture.h"
namespace glw
{
class Texture2DArguments : public TextureArguments
{
public:
typedef TextureArguments BaseType;
typedef Texture2DArguments ThisType;
GLsizei width;
GLsizei height;
GLenum dataFormat;
GLenum dataType;
const void * data;
TextureSampleMode sampler;
Texture2DArguments(void)
{
this->clear();
}
void clear(void)
{
BaseType::clear();
this->width = 0;
this->height = 0;
this->dataFormat = GL_NONE;
this->dataType = GL_NONE;
this->data = 0;
this->sampler.clear();
}
};
class Texture2D : public Texture
2012-04-30 20:23:53 +02:00
{
friend class Context;
2012-04-30 20:23:53 +02:00
public:
typedef Texture BaseType;
typedef Texture2D ThisType;
virtual Type type(void) const
{
return Texture2DType;
}
virtual int imageDimensions(void) const
{
return 2;
}
virtual bool isArray(void) const
{
return false;
}
void setImage(GLenum target, GLint unit, GLint level, GLsizei width, GLsizei height, GLenum dataFormat, GLenum dataType, const void * data)
{
(void)unit;
GLW_ASSERT(this->isValid());
glTexImage2D(target, level, this->m_format, width, height, 0, dataFormat, dataType, data);
}
void setSubImage(GLenum target, GLint unit, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum dataFormat, GLenum dataType, const void * data)
{
(void)unit;
GLW_ASSERT(this->isValid());
glTexSubImage2D(target, level, xoffset, yoffset, width, height, dataFormat, dataType, data);
}
2012-04-30 20:23:53 +02:00
void generateMipmap(GLenum target, GLint unit)
2012-04-30 20:23:53 +02:00
{
(void)unit;
GLW_ASSERT(this->isValid());
glGenerateMipmap(target);
2012-04-30 20:23:53 +02:00
}
void setSampleMode(GLenum target, GLint unit, const TextureSampleMode & sampler)
2012-04-30 20:23:53 +02:00
{
(void)unit;
GLW_ASSERT(this->isValid());
if (GLW_CARE_OF(sampler.minFilter)) glTexParameteri(target, GL_TEXTURE_MIN_FILTER, sampler.minFilter);
if (GLW_CARE_OF(sampler.magFilter)) glTexParameteri(target, GL_TEXTURE_MAG_FILTER, sampler.magFilter);
if (GLW_CARE_OF(sampler.wrapS )) glTexParameteri(target, GL_TEXTURE_WRAP_S, sampler.wrapS );
if (GLW_CARE_OF(sampler.wrapT )) glTexParameteri(target, GL_TEXTURE_WRAP_T, sampler.wrapT );
2012-04-30 20:23:53 +02:00
}
protected:
GLsizei m_width;
GLsizei m_height;
Texture2D(Context * ctx)
: BaseType (ctx)
, m_width (0)
, m_height (0)
2012-04-30 20:23:53 +02:00
{
;
}
bool create(const Texture2DArguments & args)
{
this->destroy();
GLint boundName = 0;
glGetIntegerv(GL_TEXTURE_BINDING_2D, &boundName);
glGenTextures(1, &(this->m_name));
glBindTexture(GL_TEXTURE_2D, this->m_name);
glTexImage2D(GL_TEXTURE_2D, 0, args.format, args.width, args.height, 0, args.dataFormat, args.dataType, args.data);
this->m_format = args.format;
this->m_width = args.width;
this->m_height = args.height;
this->setSampleMode(GL_TEXTURE_2D, 0, args.sampler);
glBindTexture(GL_TEXTURE_2D, boundName);
return true;
}
virtual void doDestroy(void)
{
BaseType::doDestroy();
this->m_format = GL_NONE;
this->m_width = 0;
this->m_height = 0;
}
virtual bool doIsValid(void) const
{
return ((this->m_format != GL_NONE) && (this->m_width > 0) && (this->m_height > 0));
}
2012-04-30 20:23:53 +02:00
};
namespace detail { template <> struct BaseOf <Texture2D> { typedef Texture Type; }; };
typedef detail::ObjectSharedPointerTraits <Texture2D> ::Type Texture2DPtr;
class SafeTexture2D : public SafeTexture
2012-04-30 20:23:53 +02:00
{
friend class Context;
friend class BoundTexture2D;
2012-04-30 20:23:53 +02:00
public:
typedef SafeTexture BaseType;
typedef SafeTexture2D ThisType;
2012-04-30 20:23:53 +02:00
SafeTexture2D(void)
: BaseType()
2012-04-30 20:23:53 +02:00
{
;
2012-04-30 20:23:53 +02:00
}
protected:
2012-04-30 20:23:53 +02:00
SafeTexture2D(const Texture2DPtr & texture2D)
: BaseType(texture2D)
2012-04-30 20:23:53 +02:00
{
;
2012-04-30 20:23:53 +02:00
}
const Texture2DPtr & object(void) const
2012-04-30 20:23:53 +02:00
{
return static_cast<const Texture2DPtr &>(BaseType::object());
2012-04-30 20:23:53 +02:00
}
Texture2DPtr & object(void)
2012-04-30 20:23:53 +02:00
{
return static_cast<Texture2DPtr &>(BaseType::object());
2012-04-30 20:23:53 +02:00
}
};
2012-04-30 20:23:53 +02:00
namespace detail { template <> struct BaseOf <SafeTexture2D> { typedef SafeTexture Type; }; };
namespace detail { template <> struct ObjectBase <SafeTexture2D> { typedef Texture2D Type; }; };
namespace detail { template <> struct ObjectSafe <Texture2D > { typedef SafeTexture2D Type; }; };
typedef detail::ObjectSharedPointerTraits <SafeTexture2D> ::Type Texture2DHandle;
class Texture2DBindingParams : public TextureBindingParams
{
public:
typedef TextureBindingParams BaseType;
typedef Texture2DBindingParams ThisType;
Texture2DBindingParams(void)
: BaseType()
2012-04-30 20:23:53 +02:00
{
;
2012-04-30 20:23:53 +02:00
}
Texture2DBindingParams(GLenum aUnit)
: BaseType(GL_TEXTURE_2D, aUnit)
2012-04-30 20:23:53 +02:00
{
;
2012-04-30 20:23:53 +02:00
}
};
2012-04-30 20:23:53 +02:00
class BoundTexture2D : public BoundTexture
{
friend class Context;
2012-04-30 20:23:53 +02:00
public:
typedef BoundTexture BaseType;
typedef BoundTexture2D ThisType;
BoundTexture2D(void)
: BaseType()
2012-04-30 20:23:53 +02:00
{
;
}
const Texture2DHandle & handle(void) const
2012-04-30 20:23:53 +02:00
{
return static_cast<const Texture2DHandle &>(BaseType::handle());
}
2012-04-30 20:23:53 +02:00
Texture2DHandle & handle(void)
{
return static_cast<Texture2DHandle &>(BaseType::handle());
}
2012-04-30 20:23:53 +02:00
protected:
2012-04-30 20:23:53 +02:00
BoundTexture2D(const Texture2DHandle & handle, const Texture2DBindingParams & params)
: BaseType(handle, params)
{
;
}
2012-04-30 20:23:53 +02:00
const Texture2DPtr & object(void) const
{
return this->handle()->object();
2012-04-30 20:23:53 +02:00
}
Texture2DPtr & object(void)
2012-04-30 20:23:53 +02:00
{
return this->handle()->object();
2012-04-30 20:23:53 +02:00
}
};
namespace detail { template <> struct ParamsOf <BoundTexture2D> { typedef Texture2DBindingParams Type; }; };
namespace detail { template <> struct BaseOf <BoundTexture2D> { typedef BoundObject Type; }; };
namespace detail { template <> struct ObjectBase <BoundTexture2D> { typedef Texture2D Type; }; };
namespace detail { template <> struct ObjectBound <Texture2D > { typedef BoundTexture2D Type; }; };
typedef detail::ObjectSharedPointerTraits <BoundTexture2D> ::Type BoundTexture2DHandle;
2012-04-30 20:23:53 +02:00
};
2012-04-30 20:23:53 +02:00
#endif // GLW_TEXTURE2D_H