Archived
1
0
Fork 0
forked from Mirror/Ryujinx
This repository has been archived on 2024-10-11. You can view files and clone it, but cannot push or open issues or pull requests.
jinx/Ryujinx.Graphics.OpenGL/Image/TextureCopyUnscaled.cs

94 lines
3.1 KiB
C#
Raw Normal View History

2019-10-13 06:02:07 +00:00
using OpenTK.Graphics.OpenGL;
2019-12-29 17:41:50 +00:00
using Ryujinx.Common;
using Ryujinx.Graphics.GAL;
2019-10-13 06:02:07 +00:00
using System;
namespace Ryujinx.Graphics.OpenGL.Image
2019-10-13 06:02:07 +00:00
{
static class TextureCopyUnscaled
{
public static void Copy(
TextureCreateInfo srcInfo,
TextureCreateInfo dstInfo,
int srcHandle,
int dstHandle,
int srcLayer,
int dstLayer,
int srcLevel,
int dstLevel)
2019-10-13 06:02:07 +00:00
{
int srcWidth = srcInfo.Width;
int srcHeight = srcInfo.Height;
int srcDepth = srcInfo.GetDepthOrLayers();
int srcLevels = srcInfo.Levels;
2019-10-13 06:02:07 +00:00
int dstWidth = dstInfo.Width;
int dstHeight = dstInfo.Height;
int dstDepth = dstInfo.GetDepthOrLayers();
int dstLevels = dstInfo.Levels;
2019-10-13 06:02:07 +00:00
dstWidth = Math.Max(1, dstWidth >> dstLevel);
dstHeight = Math.Max(1, dstHeight >> dstLevel);
if (dstInfo.Target == Target.Texture3D)
{
dstDepth = Math.Max(1, dstDepth >> dstLevel);
}
2019-10-13 06:02:07 +00:00
// When copying from a compressed to a non-compressed format,
// the non-compressed texture will have the size of the texture
// in blocks (not in texels), so we must adjust that size to
// match the size in texels of the compressed texture.
if (!srcInfo.IsCompressed && dstInfo.IsCompressed)
2019-10-13 06:02:07 +00:00
{
dstWidth = BitUtils.DivRoundUp(dstWidth, dstInfo.BlockWidth);
dstHeight = BitUtils.DivRoundUp(dstHeight, dstInfo.BlockHeight);
2019-10-13 06:02:07 +00:00
}
else if (srcInfo.IsCompressed && !dstInfo.IsCompressed)
2019-10-13 06:02:07 +00:00
{
dstWidth *= srcInfo.BlockWidth;
dstHeight *= srcInfo.BlockHeight;
2019-10-13 06:02:07 +00:00
}
int width = Math.Min(srcWidth, dstWidth);
int height = Math.Min(srcHeight, dstHeight);
int depth = Math.Min(srcDepth, dstDepth);
int levels = Math.Min(srcLevels, dstLevels);
for (int level = 0; level < levels; level++)
{
// Stop copy if we are already out of the levels range.
if (level >= srcInfo.Levels || dstLevel + level >= dstInfo.Levels)
2019-10-13 06:02:07 +00:00
{
break;
}
GL.CopyImageSubData(
srcHandle,
srcInfo.Target.ConvertToImageTarget(),
srcLevel + level,
2019-10-13 06:02:07 +00:00
0,
0,
srcLayer,
dstHandle,
dstInfo.Target.ConvertToImageTarget(),
2019-10-13 06:02:07 +00:00
dstLevel + level,
0,
0,
dstLayer,
width,
height,
depth);
width = Math.Max(1, width >> 1);
2019-10-13 06:02:07 +00:00
height = Math.Max(1, height >> 1);
if (srcInfo.Target == Target.Texture3D)
2019-10-13 06:02:07 +00:00
{
depth = Math.Max(1, depth >> 1);
}
}
}
}
}