aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Model/Dlna/ResolutionNormalizer.cs
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2017-04-30 16:03:28 -0400
committerLuke Pulverenti <luke.pulverenti@gmail.com>2017-04-30 16:03:28 -0400
commit7ee588060da18d30dbec189285d91568007f129c (patch)
tree06d8fbf62bcfefbd50483dc9debd189be4b021be /MediaBrowser.Model/Dlna/ResolutionNormalizer.cs
parent7ef16a449ae044306227da00a83f5abe062fb893 (diff)
add IgnoreDts option
Diffstat (limited to 'MediaBrowser.Model/Dlna/ResolutionNormalizer.cs')
-rw-r--r--MediaBrowser.Model/Dlna/ResolutionNormalizer.cs35
1 files changed, 23 insertions, 12 deletions
diff --git a/MediaBrowser.Model/Dlna/ResolutionNormalizer.cs b/MediaBrowser.Model/Dlna/ResolutionNormalizer.cs
index b0760d91f..950d3680d 100644
--- a/MediaBrowser.Model/Dlna/ResolutionNormalizer.cs
+++ b/MediaBrowser.Model/Dlna/ResolutionNormalizer.cs
@@ -12,7 +12,9 @@ namespace MediaBrowser.Model.Dlna
new ResolutionConfiguration(426, 320000),
new ResolutionConfiguration(640, 400000),
new ResolutionConfiguration(720, 950000),
- new ResolutionConfiguration(1280, 2500000)
+ new ResolutionConfiguration(1280, 2500000),
+ new ResolutionConfiguration(1920, 4000000),
+ new ResolutionConfiguration(3840, 35000000)
};
public static ResolutionOptions Normalize(int? inputBitrate,
@@ -35,19 +37,15 @@ namespace MediaBrowser.Model.Dlna
}
}
- foreach (var config in Configurations)
+ var resolutionConfig = GetResolutionConfiguration(outputBitrate);
+ if (resolutionConfig != null)
{
- if (outputBitrate <= config.MaxBitrate)
- {
- var originvalValue = maxWidth;
-
- maxWidth = Math.Min(config.MaxWidth, maxWidth ?? config.MaxWidth);
- if (!originvalValue.HasValue || originvalValue.Value != maxWidth.Value)
- {
- maxHeight = null;
- }
+ var originvalValue = maxWidth;
- break;
+ maxWidth = Math.Min(resolutionConfig.MaxWidth, maxWidth ?? resolutionConfig.MaxWidth);
+ if (!originvalValue.HasValue || originvalValue.Value != maxWidth.Value)
+ {
+ maxHeight = null;
}
}
@@ -58,6 +56,19 @@ namespace MediaBrowser.Model.Dlna
};
}
+ private static ResolutionConfiguration GetResolutionConfiguration(int outputBitrate)
+ {
+ foreach (var config in Configurations)
+ {
+ if (outputBitrate <= config.MaxBitrate)
+ {
+ return config;
+ }
+ }
+
+ return null;
+ }
+
private static double GetVideoBitrateScaleFactor(string codec)
{
if (StringHelper.EqualsIgnoreCase(codec, "h265") ||