mirror of
https://github.com/Ryujinx/Ryujinx.git
synced 2025-01-25 10:41:56 -08:00
4da44e09cb
* Make all structs readonly when applicable. It should reduce amount of needless defensive copies * Make structs with trivial boilerplate equality code record structs * Remove unnecessary readonly modifiers from TextureCreateInfo * Make BitMap structs readonly too
72 lines
2.4 KiB
C#
72 lines
2.4 KiB
C#
using Ryujinx.Graphics.GAL;
|
|
|
|
namespace Ryujinx.Graphics.Gpu.Image
|
|
{
|
|
/// <summary>
|
|
/// Represents texture format information.
|
|
/// </summary>
|
|
readonly struct FormatInfo
|
|
{
|
|
/// <summary>
|
|
/// A default, generic RGBA8 texture format.
|
|
/// </summary>
|
|
public static FormatInfo Default { get; } = new FormatInfo(Format.R8G8B8A8Unorm, 1, 1, 4, 4);
|
|
|
|
/// <summary>
|
|
/// The format of the texture data.
|
|
/// </summary>
|
|
public Format Format { get; }
|
|
|
|
/// <summary>
|
|
/// The block width for compressed formats.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Must be 1 for non-compressed formats.
|
|
/// </remarks>
|
|
public int BlockWidth { get; }
|
|
|
|
/// <summary>
|
|
/// The block height for compressed formats.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Must be 1 for non-compressed formats.
|
|
/// </remarks>
|
|
public int BlockHeight { get; }
|
|
|
|
/// <summary>
|
|
/// The number of bytes occupied by a single pixel in memory of the texture data.
|
|
/// </summary>
|
|
public int BytesPerPixel { get; }
|
|
|
|
/// <summary>
|
|
/// The maximum number of components this format has defined (in RGBA order).
|
|
/// </summary>
|
|
public int Components { get; }
|
|
|
|
/// <summary>
|
|
/// Whenever or not the texture format is a compressed format. Determined from block size.
|
|
/// </summary>
|
|
public bool IsCompressed => (BlockWidth | BlockHeight) != 1;
|
|
|
|
/// <summary>
|
|
/// Constructs the texture format info structure.
|
|
/// </summary>
|
|
/// <param name="format">The format of the texture data</param>
|
|
/// <param name="blockWidth">The block width for compressed formats. Must be 1 for non-compressed formats</param>
|
|
/// <param name="blockHeight">The block height for compressed formats. Must be 1 for non-compressed formats</param>
|
|
/// <param name="bytesPerPixel">The number of bytes occupied by a single pixel in memory of the texture data</param>
|
|
public FormatInfo(
|
|
Format format,
|
|
int blockWidth,
|
|
int blockHeight,
|
|
int bytesPerPixel,
|
|
int components)
|
|
{
|
|
Format = format;
|
|
BlockWidth = blockWidth;
|
|
BlockHeight = blockHeight;
|
|
BytesPerPixel = bytesPerPixel;
|
|
Components = components;
|
|
}
|
|
}
|
|
} |