mirror of
https://github.com/ZDoom/qzdoom.git
synced 2025-01-18 15:11:46 +00:00
- fixed: Translucency detection for GL textures was broken.
- fixed: Textures which are already scaled should not be upsampled. - fixed: The transparency check in the upscaling code checked the wrong modes for exclusion when handling translucent textures.
This commit is contained in:
parent
4267e3c40b
commit
37ac6ef9a0
2 changed files with 8 additions and 5 deletions
|
@ -263,6 +263,10 @@ unsigned char *gl_CreateUpsampledTextureBuffer ( const FTexture *inputTexture, u
|
|||
if ( inputTexture->bHasCanvas )
|
||||
return inputBuffer;
|
||||
|
||||
// already scaled?
|
||||
if (inputTexture->xScale >= FRACUNIT*2 && inputTexture->yScale >= FRACUNIT*2)
|
||||
return inputBuffer;
|
||||
|
||||
switch (inputTexture->UseType)
|
||||
{
|
||||
case FTexture::TEX_Sprite:
|
||||
|
@ -281,14 +285,14 @@ unsigned char *gl_CreateUpsampledTextureBuffer ( const FTexture *inputTexture, u
|
|||
|
||||
if (inputBuffer)
|
||||
{
|
||||
int type = gl_texture_hqresize;
|
||||
outWidth = inWidth;
|
||||
outHeight = inHeight;
|
||||
int type = gl_texture_hqresize;
|
||||
#ifdef HAVE_MMX
|
||||
// ASM-hqNx does not preserve the alpha channel so fall back to C-version for such textures
|
||||
if (!hasAlpha && type > 3 && type <= 6)
|
||||
if (!hasAlpha && type > 6 && type <= 9)
|
||||
{
|
||||
type += 3;
|
||||
type -= 3;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
|
@ -510,7 +510,7 @@ void FTexture::CheckTrans(unsigned char * buffer, int size, int trans)
|
|||
if (trans == -1)
|
||||
{
|
||||
DWORD * dwbuf = (DWORD*)buffer;
|
||||
if (gl_info.mIsTransparent == -1) for(int i=0;i<size;i++)
|
||||
for(int i=0;i<size;i++)
|
||||
{
|
||||
DWORD alpha = dwbuf[i]>>24;
|
||||
|
||||
|
@ -521,7 +521,6 @@ void FTexture::CheckTrans(unsigned char * buffer, int size, int trans)
|
|||
}
|
||||
}
|
||||
}
|
||||
gl_info.mIsTransparent = 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue