aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Controller/Trickplay
diff options
context:
space:
mode:
authornicknsy <20588554+nicknsy@users.noreply.github.com>2023-02-22 00:08:35 -0800
committerNick <20588554+nicknsy@users.noreply.github.com>2023-06-22 16:19:59 -0700
commitca7d1a13000ad948eebbfdeb40542312f3e37d3e (patch)
tree6ff31f7f318410c62ba3278aeac71f26e9626603 /MediaBrowser.Controller/Trickplay
parenta1eb2f6ea8cd78d527f1ae395378419f016208ab (diff)
Trickplay generation, manager, storage
Diffstat (limited to 'MediaBrowser.Controller/Trickplay')
-rw-r--r--MediaBrowser.Controller/Trickplay/ITrickplayManager.cs54
1 files changed, 54 insertions, 0 deletions
diff --git a/MediaBrowser.Controller/Trickplay/ITrickplayManager.cs b/MediaBrowser.Controller/Trickplay/ITrickplayManager.cs
new file mode 100644
index 000000000..bae458f98
--- /dev/null
+++ b/MediaBrowser.Controller/Trickplay/ITrickplayManager.cs
@@ -0,0 +1,54 @@
+using System;
+using System.Collections.Generic;
+using System.Threading;
+using System.Threading.Tasks;
+using MediaBrowser.Controller.Entities;
+using MediaBrowser.Model.Entities;
+
+namespace MediaBrowser.Controller.Trickplay
+{
+ /// <summary>
+ /// Interface ITrickplayManager.
+ /// </summary>
+ public interface ITrickplayManager
+ {
+ /// <summary>
+ /// Generate or replace trickplay data.
+ /// </summary>
+ /// <param name="video">The video.</param>
+ /// <param name="replace">Whether or not existing data should be replaced.</param>
+ /// <param name="cancellationToken">CancellationToken to use for operation.</param>
+ /// <returns>Task.</returns>
+ Task RefreshTrickplayData(Video video, bool replace, CancellationToken cancellationToken);
+
+ /// <summary>
+ /// Get available trickplay resolutions and corresponding info.
+ /// </summary>
+ /// <param name="itemId">The item.</param>
+ /// <returns>Map of width resolutions to trickplay tiles info.</returns>
+ Dictionary<int, TrickplayTilesInfo> GetTilesResolutions(Guid itemId);
+
+ /// <summary>
+ /// Saves trickplay tiles info.
+ /// </summary>
+ /// <param name="itemId">The item.</param>
+ /// <param name="tilesInfo">The trickplay tiles info.</param>
+ void SaveTilesInfo(Guid itemId, TrickplayTilesInfo tilesInfo);
+
+ /// <summary>
+ /// Gets the trickplay manifest.
+ /// </summary>
+ /// <param name="item">The item.</param>
+ /// <returns>A map of media source id to a map of tile width to tile info.</returns>
+ Dictionary<Guid, Dictionary<int, TrickplayTilesInfo>> GetTrickplayManifest(BaseItem item);
+
+ /// <summary>
+ /// Gets the path to a trickplay tiles image.
+ /// </summary>
+ /// <param name="item">The item.</param>
+ /// <param name="width">The width of a single tile.</param>
+ /// <param name="index">The tile grid's index.</param>
+ /// <returns>The absolute path.</returns>
+ string GetTrickplayTilePath(BaseItem item, int width, int index);
+ }
+}