Quick fix for switch textures with strange resolutions.
This commit is contained in:
parent
06f8c15b5d
commit
cfbf39fff6
@ -350,6 +350,19 @@ namespace FirstPlugin
|
||||
Console.WriteLine("MipOffsets " + SurfaceSize);
|
||||
Console.WriteLine("size " + size);
|
||||
|
||||
int powBlockShift = 0;
|
||||
if (STGenericTexture.IsCompressed(TexFormat) && mipLevel == 0)
|
||||
{
|
||||
if (width_ > 32 && height_ <= 40)
|
||||
powBlockShift += 1;
|
||||
if (width_ > 64 && height_ <= 84)
|
||||
powBlockShift += 1;
|
||||
if (width_ > 128 && height_ <= 168)
|
||||
powBlockShift += 1;
|
||||
if (width_ > 256 && height_ <= 340)
|
||||
powBlockShift += 1;
|
||||
}
|
||||
|
||||
tex.MipOffsets[mipLevel] = SurfaceSize;
|
||||
if (tex.TileMode == TileMode.LinearAligned)
|
||||
{
|
||||
@ -366,10 +379,12 @@ namespace FirstPlugin
|
||||
blockHeightShift += 1;
|
||||
|
||||
Pitch = TegraX1Swizzle.round_up(width__ * bpp, 64);
|
||||
SurfaceSize += Pitch * TegraX1Swizzle.round_up(height__, Math.Max(1, blockHeight >> blockHeightShift) * 8);
|
||||
SurfaceSize += Pitch * TegraX1Swizzle.round_up(height__, Math.Max(1, blockHeight >> (blockHeightShift + powBlockShift)) * 8);
|
||||
}
|
||||
|
||||
byte[] SwizzledData = TegraX1Swizzle.swizzle(width_, height_, depth_, blkWidth, blkHeight, blkDepth, target, bpp, (uint)tex.TileMode, (int)Math.Max(0, tex.BlockHeightLog2 - blockHeightShift), data_);
|
||||
int blockShift = blockHeightShift + powBlockShift;
|
||||
|
||||
byte[] SwizzledData = TegraX1Swizzle.swizzle(width_, height_, depth_, blkWidth, blkHeight, blkDepth, target, bpp, (uint)tex.TileMode, (int)Math.Max(0, tex.BlockHeightLog2 - blockShift), data_);
|
||||
mipmaps.Add(AlignedData.Concat(SwizzledData).ToArray());
|
||||
}
|
||||
tex.ImageSize = SurfaceSize;
|
||||
|
@ -103,6 +103,21 @@ namespace Toolbox.Library
|
||||
if (TegraX1Swizzle.pow2_round_up(TegraX1Swizzle.DIV_ROUND_UP(height, blkWidth)) < linesPerBlockHeight)
|
||||
blockHeightShift += 1;
|
||||
|
||||
int powBlockShift = 0;
|
||||
if (STGenericTexture.IsCompressed(texture.Format) && mipLevel == 0)
|
||||
{
|
||||
if (width > 32 && height <= 40)
|
||||
powBlockShift += 1;
|
||||
if (width > 64 && height <= 84)
|
||||
powBlockShift += 1;
|
||||
if (width > 128 && height <= 168)
|
||||
powBlockShift += 1;
|
||||
if (width > 256 && height <= 340)
|
||||
powBlockShift += 1;
|
||||
}
|
||||
|
||||
int blockShift = blockHeightShift + powBlockShift;
|
||||
|
||||
uint width__ = TegraX1Swizzle.DIV_ROUND_UP(width, blkWidth);
|
||||
uint height__ = TegraX1Swizzle.DIV_ROUND_UP(height, blkHeight);
|
||||
|
||||
@ -119,9 +134,9 @@ namespace Toolbox.Library
|
||||
try
|
||||
{
|
||||
Pitch = TegraX1Swizzle.round_up(width__ * bpp, 64);
|
||||
SurfaceSize += Pitch * TegraX1Swizzle.round_up(height__, Math.Max(1, blockHeight >> blockHeightShift) * 8);
|
||||
SurfaceSize += Pitch * TegraX1Swizzle.round_up(height__, Math.Max(1, blockHeight >> blockShift) * 8);
|
||||
|
||||
byte[] result = TegraX1Swizzle.deswizzle(width, height, depth, blkWidth, blkHeight, blkDepth, target, bpp, TileMode, (int)Math.Max(0, BlockHeightLog2 - blockHeightShift), data_);
|
||||
byte[] result = TegraX1Swizzle.deswizzle(width, height, depth, blkWidth, blkHeight, blkDepth, target, bpp, TileMode, (int)Math.Max(0, BlockHeightLog2 - blockShift), data_);
|
||||
//Create a copy and use that to remove uneeded data
|
||||
byte[] result_ = new byte[size];
|
||||
Array.Copy(result, 0, result_, 0, size);
|
||||
|
Loading…
x
Reference in New Issue
Block a user