ISubtitleEncoder.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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. /// <summary>
  52. /// Extracts all extractable subtitles (text and pgs).
  53. /// </summary>
  54. /// <param name="mediaSource">The mediaSource.</param>
  55. /// <param name="cancellationToken">The cancellation token.</param>
  56. /// <returns>Task.</returns>
  57. Task ExtractAllExtractableSubtitles(MediaSourceInfo mediaSource, CancellationToken cancellationToken);
  58. }
  59. }