From 20c711b2484e6163802f8dfaf07322660c1a5104 Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Sun, 2 Feb 2014 11:21:40 -0500 Subject: [PATCH] vary bitrate params depending on input resolution requested --- .../Playback/BaseStreamingService.cs | 40 ++++++++++++++++--- MediaBrowser.Api/Playback/StreamRequest.cs | 12 ++++++ 2 files changed, 46 insertions(+), 6 deletions(-) diff --git a/MediaBrowser.Api/Playback/BaseStreamingService.cs b/MediaBrowser.Api/Playback/BaseStreamingService.cs index 98220e5c69..8cdfc04f60 100644 --- a/MediaBrowser.Api/Playback/BaseStreamingService.cs +++ b/MediaBrowser.Api/Playback/BaseStreamingService.cs @@ -305,27 +305,39 @@ namespace MediaBrowser.Api.Playback { var param = string.Empty; + var hasFixedResolution = state.VideoRequest.HasFixedResolution; + if (string.Equals(videoCodec, "libx264", StringComparison.OrdinalIgnoreCase)) { switch (GetQualitySetting()) { case EncodingQuality.HighSpeed: - param = "-preset ultrafast -crf 18"; + param = "-preset ultrafast"; break; case EncodingQuality.HighQuality: - param = "-preset superfast -crf 18"; + param = "-preset superfast"; break; case EncodingQuality.MaxQuality: - param = "-preset superfast -crf 18"; + param = "-preset superfast"; break; } + + if (!hasFixedResolution) + { + param += " crf18"; + } } // webm else if (string.Equals(videoCodec, "libvpx", StringComparison.OrdinalIgnoreCase)) { // http://www.webmproject.org/docs/encoder-parameters/ - param = "-speed 16 -quality good -profile:v 0 -slices 8 -crf 18"; + param = "-speed 16 -quality good -profile:v 0 -slices 8"; + + if (!hasFixedResolution) + { + param += " crf18"; + } } else if (string.Equals(videoCodec, "mpeg4", StringComparison.OrdinalIgnoreCase)) @@ -941,21 +953,37 @@ namespace MediaBrowser.Api.Playback if (bitrate.HasValue) { + var hasFixedResolution = state.VideoRequest.HasFixedResolution; + if (isHls) { return string.Format(" -b:v {0} -maxrate ({0}*.80) -bufsize {0}", bitrate.Value.ToString(UsCulture)); } - // With vpx when crf is used, b:v becomes a max rate - // https://trac.ffmpeg.org/wiki/vpxEncodingGuide if (string.Equals(videoCodec, "libvpx", StringComparison.OrdinalIgnoreCase)) { + if (hasFixedResolution) + { + return string.Format(" -minrate:v ({0}*.90) -maxrate:v ({0}*1.10) -bufsize:v {0} -b:v {0}", bitrate.Value.ToString(UsCulture)); + } + + // With vpx when crf is used, b:v becomes a max rate + // https://trac.ffmpeg.org/wiki/vpxEncodingGuide return string.Format(" -b:v {0}", bitrate.Value.ToString(UsCulture)); } + if (string.Equals(videoCodec, "msmpeg4", StringComparison.OrdinalIgnoreCase)) { return string.Format(" -b:v {0}", bitrate.Value.ToString(UsCulture)); } + + + // H264 + if (hasFixedResolution) + { + return string.Format(" -b:v {0}", bitrate.Value.ToString(UsCulture)); + } + return string.Format(" -maxrate {0} -bufsize {1}", bitrate.Value.ToString(UsCulture), (bitrate.Value * 2).ToString(UsCulture)); diff --git a/MediaBrowser.Api/Playback/StreamRequest.cs b/MediaBrowser.Api/Playback/StreamRequest.cs index b0c5220e35..78682d54a2 100644 --- a/MediaBrowser.Api/Playback/StreamRequest.cs +++ b/MediaBrowser.Api/Playback/StreamRequest.cs @@ -157,5 +157,17 @@ namespace MediaBrowser.Api.Playback /// The level. [ApiMember(Name = "Level", Description = "Optional. Specify a level for the h264 profile, e.g. 3, 3.1.", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")] public string Level { get; set; } + + /// + /// Gets a value indicating whether this instance has fixed resolution. + /// + /// true if this instance has fixed resolution; otherwise, false. + public bool HasFixedResolution + { + get + { + return Width.HasValue || Height.HasValue; + } + } } }