ISubtitleEncoder.cs 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. #nullable disable
  2. #pragma warning disable CS1591
  3. using System.IO;
  4. using System.Threading;
  5. using System.Threading.Tasks;
  6. using MediaBrowser.Controller.Entities;
  7. using MediaBrowser.Model.Dto;
  8. using MediaBrowser.Model.Entities;
  9. namespace MediaBrowser.Controller.MediaEncoding
  10. {
  11. public interface ISubtitleEncoder
  12. {
  13. /// <summary>
  14. /// Gets the subtitles.
  15. /// </summary>
  16. /// <param name="item">Item to use.</param>
  17. /// <param name="mediaSourceId">Media source.</param>
  18. /// <param name="subtitleStreamIndex">Subtitle stream to use.</param>
  19. /// <param name="outputFormat">Output format to use.</param>
  20. /// <param name="startTimeTicks">Start time.</param>
  21. /// <param name="endTimeTicks">End time.</param>
  22. /// <param name="preserveOriginalTimestamps">Option to preserve original timestamps.</param>
  23. /// <param name="cancellationToken">The cancellation token for the operation.</param>
  24. /// <returns>Task{Stream}.</returns>
  25. Task<Stream> GetSubtitles(
  26. BaseItem item,
  27. string mediaSourceId,
  28. int subtitleStreamIndex,
  29. string outputFormat,
  30. long startTimeTicks,
  31. long endTimeTicks,
  32. bool preserveOriginalTimestamps,
  33. CancellationToken cancellationToken);
  34. /// <summary>
  35. /// Gets the subtitle language encoding parameter.
  36. /// </summary>
  37. /// <param name="subtitleStream">The subtitle stream.</param>
  38. /// <param name="language">The language.</param>
  39. /// <param name="mediaSource">The media source.</param>
  40. /// <param name="cancellationToken">The cancellation token.</param>
  41. /// <returns>System.String.</returns>
  42. Task<string> GetSubtitleFileCharacterSet(MediaStream subtitleStream, string language, MediaSourceInfo mediaSource, CancellationToken cancellationToken);
  43. /// <summary>
  44. /// Gets the path to a subtitle file.
  45. /// </summary>
  46. /// <param name="subtitleStream">The subtitle stream.</param>
  47. /// <param name="mediaSource">The media source.</param>
  48. /// <param name="cancellationToken">The cancellation token.</param>
  49. /// <returns>System.String.</returns>
  50. Task<string> GetSubtitleFilePath(MediaStream subtitleStream, MediaSourceInfo mediaSource, CancellationToken cancellationToken);
  51. }
  52. }