#nullable disable #pragma warning disable CS1591 using System; using System.Collections.Generic; using System.Threading; using System.Threading.Tasks; using MediaBrowser.Model.Dlna; using MediaBrowser.Model.Drawing; using MediaBrowser.Model.Dto; using MediaBrowser.Model.Entities; using MediaBrowser.Model.MediaInfo; namespace MediaBrowser.Controller.MediaEncoding { /// /// Interface IMediaEncoder. /// public interface IMediaEncoder : ITranscoderSupport { /// /// Gets the encoder path. /// /// The encoder path. string EncoderPath { get; } /// /// Gets the version of encoder. /// /// The version of encoder. Version EncoderVersion { get; } /// /// Whether the configured Vaapi device is from AMD(radeonsi/r600 Mesa driver). /// /// true if the Vaapi device is an AMD(radeonsi/r600 Mesa driver) GPU, false otherwise. bool IsVaapiDeviceAmd { get; } /// /// Whether the configured Vaapi device is from Intel(iHD driver). /// /// true if the Vaapi device is an Intel(iHD driver) GPU, false otherwise. bool IsVaapiDeviceInteliHD { get; } /// /// Whether the configured Vaapi device is from Intel(legacy i965 driver). /// /// true if the Vaapi device is an Intel(legacy i965 driver) GPU, false otherwise. bool IsVaapiDeviceInteli965 { get; } /// /// Whether given encoder codec is supported. /// /// The encoder. /// true if XXXX, false otherwise. bool SupportsEncoder(string encoder); /// /// Whether given decoder codec is supported. /// /// The decoder. /// true if XXXX, false otherwise. bool SupportsDecoder(string decoder); /// /// Whether given hardware acceleration type is supported. /// /// The hwaccel. /// true if XXXX, false otherwise. bool SupportsHwaccel(string hwaccel); /// /// Whether given filter is supported. /// /// The filter. /// true if the filter is supported, false otherwise. bool SupportsFilter(string filter); /// /// Whether filter is supported with the given option. /// /// The option. /// true if the filter is supported, false otherwise. bool SupportsFilterWithOption(FilterOptionType option); /// /// Extracts the audio image. /// /// The path. /// Index of the image stream. /// The cancellation token. /// Task{Stream}. Task ExtractAudioImage(string path, int? imageStreamIndex, CancellationToken cancellationToken); /// /// Extracts the video image. /// /// Input file. /// Video container type. /// Media source information. /// Media stream information. /// Video 3D format. /// Time offset. /// CancellationToken to use for operation. /// Location of video image. Task ExtractVideoImage(string inputFile, string container, MediaSourceInfo mediaSource, MediaStream videoStream, Video3DFormat? threedFormat, TimeSpan? offset, CancellationToken cancellationToken); /// /// Extracts the video image. /// /// Input file. /// Video container type. /// Media source information. /// Media stream information. /// Index of the stream to extract from. /// The format of the file to write. /// CancellationToken to use for operation. /// Location of video image. Task ExtractVideoImage(string inputFile, string container, MediaSourceInfo mediaSource, MediaStream imageStream, int? imageStreamIndex, ImageFormat? targetFormat, CancellationToken cancellationToken); /// /// Gets the media info. /// /// The request. /// The cancellation token. /// Task. Task GetMediaInfo(MediaInfoRequest request, CancellationToken cancellationToken); /// /// Gets the input argument. /// /// The input file. /// The mediaSource. /// System.String. string GetInputArgument(string inputFile, MediaSourceInfo mediaSource); /// /// Gets the time parameter. /// /// The ticks. /// System.String. string GetTimeParameter(long ticks); Task ConvertImage(string inputPath, string outputPath); /// /// Escapes the subtitle filter path. /// /// The path. /// System.String. string EscapeSubtitleFilterPath(string path); /// /// Sets the path to find FFmpeg. /// void SetFFmpegPath(); /// /// Updates the encoder path. /// /// The path. /// The type of path. void UpdateEncoderPath(string path, string pathType); /// /// Gets the primary playlist of .vob files. /// /// The to the .vob files. /// The title number to start with. /// A playlist. IEnumerable GetPrimaryPlaylistVobFiles(string path, uint? titleNumber); } }