mirror of https://github.com/SixLabors/ImageSharp
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
7.2 KiB
188 lines
7.2 KiB
namespace GenericImage
|
|
{
|
|
using System;
|
|
|
|
using GenericImage.PackedVectors;
|
|
|
|
/// <summary>
|
|
/// Encapsulates the basic properties and methods required to manipulate images
|
|
/// in different pixel formats.
|
|
/// </summary>
|
|
/// <typeparam name="TPacked">
|
|
/// The packed vector pixels format.
|
|
/// </typeparam>
|
|
public abstract class ImageBase<TPacked>
|
|
where TPacked : IPackedVector
|
|
{
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="ImageBase{TPacked}"/> class.
|
|
/// </summary>
|
|
protected ImageBase()
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="ImageBase{TPacked}"/> class.
|
|
/// </summary>
|
|
/// <param name="width">The width of the image in pixels.</param>
|
|
/// <param name="height">The height of the image in pixels.</param>
|
|
/// <exception cref="ArgumentOutOfRangeException">
|
|
/// Thrown if either <paramref name="width"/> or <paramref name="height"/> are less than or equal to 0.
|
|
/// </exception>
|
|
protected ImageBase(int width, int height)
|
|
{
|
|
// Guard.MustBeGreaterThan(width, 0, nameof(width));
|
|
// Guard.MustBeGreaterThan(height, 0, nameof(height));
|
|
|
|
this.Width = width;
|
|
this.Height = height;
|
|
this.Pixels = new TPacked[width * height];
|
|
}
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="ImageBase{TPacked}"/> class.
|
|
/// </summary>
|
|
/// <param name="other">
|
|
/// The other <see cref="ImageBase{TPacked}"/> to create this instance from.
|
|
/// </param>
|
|
/// <exception cref="ArgumentNullException">
|
|
/// Thrown if the given <see cref="ImageBase{TPacked}"/> is null.
|
|
/// </exception>
|
|
protected ImageBase(ImageBase<TPacked> other)
|
|
{
|
|
// Guard.NotNull(other, nameof(other), "Other image cannot be null.");
|
|
|
|
this.Width = other.Width;
|
|
this.Height = other.Height;
|
|
this.Quality = other.Quality;
|
|
this.FrameDelay = other.FrameDelay;
|
|
|
|
// Copy the pixels.
|
|
this.Pixels = new TPacked[this.Width * this.Height];
|
|
Array.Copy(other.Pixels, this.Pixels, other.Pixels.Length);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the pixels as an array of the given packed pixel format.
|
|
/// </summary>
|
|
public TPacked[] Pixels { get; private set; }
|
|
|
|
/// <summary>
|
|
/// Gets the width in pixels.
|
|
/// </summary>
|
|
public int Width { get; private set; }
|
|
|
|
/// <summary>
|
|
/// Gets the height in pixels.
|
|
/// </summary>
|
|
public int Height { get; private set; }
|
|
|
|
/// <summary>
|
|
/// Gets the pixel ratio made up of the width and height.
|
|
/// </summary>
|
|
public double PixelRatio => (double)this.Width / this.Height;
|
|
|
|
/// <summary>
|
|
/// Gets the <see cref="Rectangle"/> representing the bounds of the image.
|
|
/// </summary>
|
|
// public Rectangle Bounds => new Rectangle(0, 0, this.Width, this.Height);
|
|
|
|
/// <summary>
|
|
/// Gets or sets th quality of the image. This affects the output quality of lossy image formats.
|
|
/// </summary>
|
|
public int Quality { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets the frame delay for animated images.
|
|
/// If not 0, this field specifies the number of hundredths (1/100) of a second to
|
|
/// wait before continuing with the processing of the Data Stream.
|
|
/// The clock starts ticking immediately after the graphic is rendered.
|
|
/// </summary>
|
|
public int FrameDelay { get; set; }
|
|
|
|
/// <summary>
|
|
/// Sets the pixel array of the image to the given value.
|
|
/// </summary>
|
|
/// <param name="width">The new width of the image. Must be greater than zero.</param>
|
|
/// <param name="height">The new height of the image. Must be greater than zero.</param>
|
|
/// <param name="pixels">
|
|
/// The array with colors. Must be a multiple of the width and height.
|
|
/// </param>
|
|
/// <exception cref="ArgumentOutOfRangeException">
|
|
/// Thrown if either <paramref name="width"/> or <paramref name="height"/> are less than or equal to 0.
|
|
/// </exception>
|
|
/// <exception cref="ArgumentException">
|
|
/// Thrown if the <paramref name="pixels"/> length is not equal to Width * Height.
|
|
/// </exception>
|
|
public void SetPixels(int width, int height, TPacked[] pixels)
|
|
{
|
|
if (width <= 0)
|
|
{
|
|
throw new ArgumentOutOfRangeException(nameof(width), "Width must be greater than or equals than zero.");
|
|
}
|
|
|
|
if (height <= 0)
|
|
{
|
|
throw new ArgumentOutOfRangeException(nameof(height), "Height must be greater than or equal than zero.");
|
|
}
|
|
|
|
if (pixels.Length != width * height)
|
|
{
|
|
throw new ArgumentException("Pixel array must have the length of Width * Height.");
|
|
}
|
|
|
|
this.Width = width;
|
|
this.Height = height;
|
|
this.Pixels = pixels;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sets the pixel array of the image to the given value, creating a copy of
|
|
/// the original pixels.
|
|
/// </summary>
|
|
/// <param name="width">The new width of the image. Must be greater than zero.</param>
|
|
/// <param name="height">The new height of the image. Must be greater than zero.</param>
|
|
/// <param name="pixels">
|
|
/// The array with colors. Must be a multiple of four times the width and height.
|
|
/// </param>
|
|
/// <exception cref="ArgumentOutOfRangeException">
|
|
/// Thrown if either <paramref name="width"/> or <paramref name="height"/> are less than or equal to 0.
|
|
/// </exception>
|
|
/// <exception cref="ArgumentException">
|
|
/// Thrown if the <paramref name="pixels"/> length is not equal to Width * Height.
|
|
/// </exception>
|
|
public void ClonePixels(int width, int height, TPacked[] pixels)
|
|
{
|
|
if (width <= 0)
|
|
{
|
|
throw new ArgumentOutOfRangeException(nameof(width), "Width must be greater than or equals than zero.");
|
|
}
|
|
|
|
if (height <= 0)
|
|
{
|
|
throw new ArgumentOutOfRangeException(nameof(height), "Height must be greater than or equal than zero.");
|
|
}
|
|
|
|
if (pixels.Length != width * height)
|
|
{
|
|
throw new ArgumentException("Pixel array must have the length of Width * Height.");
|
|
}
|
|
|
|
this.Width = width;
|
|
this.Height = height;
|
|
|
|
// Copy the pixels.
|
|
this.Pixels = new TPacked[pixels.Length];
|
|
Array.Copy(pixels, this.Pixels, pixels.Length);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Locks the image providing access to the pixels.
|
|
/// <remarks>
|
|
/// It is imperative that the accessor is correctly disposed off after use.
|
|
/// </remarks>
|
|
/// </summary>
|
|
/// <returns>The <see cref="IPixelAccessor"/></returns>
|
|
public abstract IPixelAccessor Lock();
|
|
}
|
|
}
|
|
|