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.
42 lines
1.6 KiB
42 lines
1.6 KiB
// Copyright (c) Six Labors and contributors.
|
|
// Licensed under the Apache License, Version 2.0.
|
|
|
|
using SixLabors.ImageSharp.PixelFormats;
|
|
using SixLabors.ImageSharp.Processing.Dithering.ErrorDiffusion;
|
|
|
|
namespace SixLabors.ImageSharp.Processing.Quantization
|
|
{
|
|
/// <summary>
|
|
/// Provides methods for for allowing quantization of images pixels with configurable dithering.
|
|
/// </summary>
|
|
/// <typeparam name="TPixel">The pixel format.</typeparam>
|
|
public interface IQuantizer<TPixel> : IQuantizer
|
|
where TPixel : struct, IPixel<TPixel>
|
|
{
|
|
/// <summary>
|
|
/// Quantize an image and return the resulting output pixels.
|
|
/// </summary>
|
|
/// <param name="image">The image to quantize.</param>
|
|
/// <param name="maxColors">The maximum number of colors to return.</param>
|
|
/// <returns>
|
|
/// A <see cref="T:QuantizedImage"/> representing a quantized version of the image pixels.
|
|
/// </returns>
|
|
QuantizedFrame<TPixel> Quantize(ImageFrame<TPixel> image, int maxColors);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Provides methods for allowing quantization of images pixels with configurable dithering.
|
|
/// </summary>
|
|
public interface IQuantizer
|
|
{
|
|
/// <summary>
|
|
/// Gets or sets a value indicating whether to apply dithering to the output image.
|
|
/// </summary>
|
|
bool Dither { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gets or sets the dithering algorithm to apply to the output image.
|
|
/// </summary>
|
|
IErrorDiffuser DitherType { get; set; }
|
|
}
|
|
}
|