commit
1a81737d4f
|
@ -49,11 +49,11 @@ bool CTexture::BufferGL()
|
||||||
switch (mTexelFormat)
|
switch (mTexelFormat)
|
||||||
{
|
{
|
||||||
case ETexelFormat::Luminance:
|
case ETexelFormat::Luminance:
|
||||||
GLFormat = GL_LUMINANCE;
|
GLFormat = GL_R;
|
||||||
GLType = GL_UNSIGNED_BYTE;
|
GLType = GL_UNSIGNED_BYTE;
|
||||||
break;
|
break;
|
||||||
case ETexelFormat::LuminanceAlpha:
|
case ETexelFormat::LuminanceAlpha:
|
||||||
GLFormat = GL_LUMINANCE_ALPHA;
|
GLFormat = GL_RG;
|
||||||
GLType = GL_UNSIGNED_BYTE;
|
GLType = GL_UNSIGNED_BYTE;
|
||||||
break;
|
break;
|
||||||
case ETexelFormat::RGB565:
|
case ETexelFormat::RGB565:
|
||||||
|
@ -104,6 +104,13 @@ bool CTexture::BufferGL()
|
||||||
glTexParameteri(BindTarget, GL_TEXTURE_BASE_LEVEL, 0);
|
glTexParameteri(BindTarget, GL_TEXTURE_BASE_LEVEL, 0);
|
||||||
glTexParameteri(BindTarget, GL_TEXTURE_MAX_LEVEL, mNumMipMaps - 1);
|
glTexParameteri(BindTarget, GL_TEXTURE_MAX_LEVEL, mNumMipMaps - 1);
|
||||||
|
|
||||||
|
// Swizzling for luminance textures:
|
||||||
|
if (mTexelFormat == ETexelFormat::Luminance || mTexelFormat == ETexelFormat::LuminanceAlpha)
|
||||||
|
{
|
||||||
|
GLint SwizzleMask[] = {GL_RED, GL_RED, GL_RED, GLFormat == GL_RG ? GL_GREEN : GL_ONE};
|
||||||
|
glTexParameteriv(BindTarget, GL_TEXTURE_SWIZZLE_RGBA, SwizzleMask);
|
||||||
|
}
|
||||||
|
|
||||||
// Linear filtering on mipmaps:
|
// Linear filtering on mipmaps:
|
||||||
glTexParameteri(BindTarget, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
glTexParameteri(BindTarget, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
||||||
glTexParameteri(BindTarget, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_LINEAR);
|
glTexParameteri(BindTarget, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_LINEAR);
|
||||||
|
|
Loading…
Reference in New Issue