| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 | #pragma warning disable CS1591using System;using System.Collections.Generic;using MediaBrowser.Model.Drawing;namespace MediaBrowser.Controller.Drawing{    public interface IImageEncoder    {        /// <summary>        /// Gets the supported input formats.        /// </summary>        /// <value>The supported input formats.</value>        IReadOnlyCollection<string> SupportedInputFormats { get; }        /// <summary>        /// Gets the supported output formats.        /// </summary>        /// <value>The supported output formats.</value>        IReadOnlyCollection<ImageFormat> SupportedOutputFormats { get; }        /// <summary>        /// Gets the display name for the encoder.        /// </summary>        /// <value>The display name.</value>        string Name { get; }        /// <summary>        /// Gets a value indicating whether [supports image collage creation].        /// </summary>        /// <value><c>true</c> if [supports image collage creation]; otherwise, <c>false</c>.</value>        bool SupportsImageCollageCreation { get; }        /// <summary>        /// Gets a value indicating whether [supports image encoding].        /// </summary>        /// <value><c>true</c> if [supports image encoding]; otherwise, <c>false</c>.</value>        bool SupportsImageEncoding { get; }        /// <summary>        /// Get the dimensions of an image from the filesystem.        /// </summary>        /// <param name="path">The filepath of the image.</param>        /// <returns>The image dimensions.</returns>        ImageDimensions GetImageSize(string path);        /// <summary>        /// Gets the blurhash of an image.        /// </summary>        /// <param name="xComp">Amount of X components of DCT to take.</param>        /// <param name="yComp">Amount of Y components of DCT to take.</param>        /// <param name="path">The filepath of the image.</param>        /// <returns>The blurhash.</returns>        string GetImageBlurHash(int xComp, int yComp, string path);        /// <summary>        /// Encode an image.        /// </summary>        /// <param name="inputPath">Input path of image.</param>        /// <param name="dateModified">Date modified.</param>        /// <param name="outputPath">Output path of image.</param>        /// <param name="autoOrient">Auto-orient image.</param>        /// <param name="orientation">Desired orientation of image.</param>        /// <param name="quality">Quality of encoded image.</param>        /// <param name="options">Image processing options.</param>        /// <param name="outputFormat">Image format of output.</param>        /// <returns>Path of encoded image.</returns>        string EncodeImage(string inputPath, DateTime dateModified, string outputPath, bool autoOrient, ImageOrientation? orientation, int quality, ImageProcessingOptions options, ImageFormat outputFormat);        /// <summary>        /// Create an image collage.        /// </summary>        /// <param name="options">The options to use when creating the collage.</param>        /// <param name="libraryName">Optional. </param>        void CreateImageCollage(ImageCollageOptions options, string? libraryName);    }}
 |