1
0
mirror of synced 2025-01-19 09:17:30 +01:00

Quick fix for switch textures with strange resolutions.

This commit is contained in:
KillzXGaming 2020-07-15 19:01:56 -04:00
parent 06f8c15b5d
commit cfbf39fff6
2 changed files with 34 additions and 4 deletions

View File

@ -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;

View File

@ -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);