Ver Fonte

Options

nicknsy há 2 anos atrás
pai
commit
6c649a7e72

+ 5 - 1
MediaBrowser.MediaEncoding/Encoder/MediaEncoder.cs

@@ -853,10 +853,14 @@ namespace MediaBrowser.MediaEncoding.Encoder
             {
                 filterParam = "-vf \"" + fps + "\"";
             }
-            else
+            else if (filterParam.IndexOf("\"", StringComparison.Ordinal) != -1)
             {
                 filterParam = filterParam.Insert(filterParam.IndexOf("\"", StringComparison.Ordinal) + 1, fps + ",");
             }
+            else
+            {
+                filterParam += fps + ",";
+            }
 
             var targetDirectory = Path.Combine(_configurationManager.ApplicationPaths.TempDirectory, Guid.NewGuid().ToString("N"));
             Directory.CreateDirectory(targetDirectory);

+ 61 - 0
MediaBrowser.Model/Configuration/TrickplayOptions.cs

@@ -0,0 +1,61 @@
+using System.Collections.Generic;
+using System.Diagnostics;
+
+namespace MediaBrowser.Model.Configuration
+{
+    /// <summary>
+    /// Class TrickplayOptions.
+    /// </summary>
+    public class TrickplayOptions
+    {
+        /// <summary>
+        /// Gets or sets a value indicating whether or not to use HW acceleration.
+        /// </summary>
+        public bool EnableHwAcceleration { get; set; } = false;
+
+        /// <summary>
+        /// Gets or sets the behavior used by trickplay provider on library scan/update.
+        /// </summary>
+        public TrickplayScanBehavior ScanBehavior { get; set; } = TrickplayScanBehavior.NonBlocking;
+
+        /// <summary>
+        /// Gets or sets the process priority for the ffmpeg process.
+        /// </summary>
+        public ProcessPriorityClass ProcessPriority { get; set; } = ProcessPriorityClass.BelowNormal;
+
+        /// <summary>
+        /// Gets or sets the interval, in ms, between each new trickplay image.
+        /// </summary>
+        public int Interval { get; set; } = 10000;
+
+        /// <summary>
+        /// Gets or sets the target width resolutions, in px, to generates preview images for.
+        /// </summary>
+        public HashSet<int> WidthResolutions { get; set; } = new HashSet<int> { 320 };
+
+        /// <summary>
+        /// Gets or sets number of tile images to allow in X dimension.
+        /// </summary>
+        public int TileWidth { get; set; } = 10;
+
+        /// <summary>
+        /// Gets or sets number of tile images to allow in Y dimension.
+        /// </summary>
+        public int TileHeight { get; set; } = 10;
+
+        /// <summary>
+        /// Gets or sets the ffmpeg output quality level.
+        /// </summary>
+        public int Qscale { get; set; } = 10;
+
+        /// <summary>
+        /// Gets or sets the jpeg quality to use for image tiles.
+        /// </summary>
+        public int JpegQuality { get; set; } = 90;
+
+        /// <summary>
+        /// Gets or sets the number of threads to be used by ffmpeg.
+        /// </summary>
+        public int ProcessThreads { get; set; } = 0;
+    }
+}

+ 18 - 0
MediaBrowser.Model/Configuration/TrickplayScanBehavior.cs

@@ -0,0 +1,18 @@
+namespace MediaBrowser.Model.Configuration
+{
+    /// <summary>
+    /// Enum TrickplayScanBehavior.
+    /// </summary>
+    public enum TrickplayScanBehavior
+    {
+        /// <summary>
+        /// Starts generation, only return once complete.
+        /// </summary>
+        Blocking,
+
+        /// <summary>
+        /// Start generation, return immediately.
+        /// </summary>
+        NonBlocking
+    }
+}