diff --git a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatVideoDynamicRangeTypeFixture.cs b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatVideoDynamicRangeTypeFixture.cs index 3c37d0f34..aed6d0fc1 100644 --- a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatVideoDynamicRangeTypeFixture.cs +++ b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatVideoDynamicRangeTypeFixture.cs @@ -15,6 +15,7 @@ public class FormatVideoDynamicRangeTypeFixture : TestBase [TestCase(HdrFormat.Hdr10Plus, "HDR10Plus")] [TestCase(HdrFormat.DolbyVision, "DV")] [TestCase(HdrFormat.DolbyVisionHdr10, "DV HDR10")] + [TestCase(HdrFormat.DolbyVisionHdr10Plus, "DV HDR10Plus")] [TestCase(HdrFormat.DolbyVisionHlg, "DV HLG")] [TestCase(HdrFormat.DolbyVisionSdr, "DV SDR")] public void should_format_video_dynamic_range_type(HdrFormat format, string expectedVideoDynamicRangeType) diff --git a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/VideoFileInfoReaderFixture.cs b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/VideoFileInfoReaderFixture.cs index 40d9ea99c..c48f3a63d 100644 --- a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/VideoFileInfoReaderFixture.cs +++ b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/VideoFileInfoReaderFixture.cs @@ -116,6 +116,8 @@ public void get_info_unicode() [TestCase(10, "bt2020", "smpte2084", "FFMpegCore.HdrDynamicMetadataSpmte2094", null, HdrFormat.Hdr10Plus)] [TestCase(10, "bt2020", "smpte2084", "FFMpegCore.DoviConfigurationRecordSideData", null, HdrFormat.DolbyVision)] [TestCase(10, "bt2020", "smpte2084", "FFMpegCore.DoviConfigurationRecordSideData", 1, HdrFormat.DolbyVisionHdr10)] + [TestCase(10, "bt2020", "smpte2084", "FFMpegCore.DoviConfigurationRecordSideData,FFMpegCore.HdrDynamicMetadataSpmte2094", 1, HdrFormat.DolbyVisionHdr10Plus)] + [TestCase(10, "bt2020", "smpte2084", "FFMpegCore.DoviConfigurationRecordSideData,FFMpegCore.HdrDynamicMetadataSpmte2094", 6, HdrFormat.DolbyVisionHdr10Plus)] [TestCase(10, "bt2020", "smpte2084", "FFMpegCore.DoviConfigurationRecordSideData", 2, HdrFormat.DolbyVisionSdr)] [TestCase(10, "bt2020", "smpte2084", "FFMpegCore.DoviConfigurationRecordSideData", 4, HdrFormat.DolbyVisionHlg)] public void should_detect_hdr_correctly(int bitDepth, string colourPrimaries, string transferFunction, string sideDataTypes, int? doviConfigId, HdrFormat expected) diff --git a/src/NzbDrone.Core/MediaFiles/MediaInfo/HdrFormat.cs b/src/NzbDrone.Core/MediaFiles/MediaInfo/HdrFormat.cs index ffe98300a..219c10804 100644 --- a/src/NzbDrone.Core/MediaFiles/MediaInfo/HdrFormat.cs +++ b/src/NzbDrone.Core/MediaFiles/MediaInfo/HdrFormat.cs @@ -11,6 +11,7 @@ public enum HdrFormat DolbyVision, DolbyVisionHdr10, DolbyVisionSdr, - DolbyVisionHlg + DolbyVisionHlg, + DolbyVisionHdr10Plus } } diff --git a/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoFormatter.cs b/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoFormatter.cs index e5d8093fb..154d25b7b 100644 --- a/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoFormatter.cs +++ b/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoFormatter.cs @@ -321,6 +321,8 @@ public static string FormatVideoDynamicRangeType(MediaInfoModel mediaInfo) return "DV"; case HdrFormat.DolbyVisionHdr10: return "DV HDR10"; + case HdrFormat.DolbyVisionHdr10Plus: + return "DV HDR10Plus"; case HdrFormat.DolbyVisionHlg: return "DV HLG"; case HdrFormat.DolbyVisionSdr: diff --git a/src/NzbDrone.Core/MediaFiles/MediaInfo/VideoFileInfoReader.cs b/src/NzbDrone.Core/MediaFiles/MediaInfo/VideoFileInfoReader.cs index fadb6f8bb..c7cb4ba48 100644 --- a/src/NzbDrone.Core/MediaFiles/MediaInfo/VideoFileInfoReader.cs +++ b/src/NzbDrone.Core/MediaFiles/MediaInfo/VideoFileInfoReader.cs @@ -188,12 +188,14 @@ public static HdrFormat GetHdrFormat(int bitDepth, string colorPrimaries, string if (TryGetSideData(sideData, out var dovi)) { + var hasHdr10Plus = TryGetSideData(sideData, out _); + return dovi.DvBlSignalCompatibilityId switch { - 1 => HdrFormat.DolbyVisionHdr10, + 1 => hasHdr10Plus ? HdrFormat.DolbyVisionHdr10Plus : HdrFormat.DolbyVisionHdr10, 2 => HdrFormat.DolbyVisionSdr, 4 => HdrFormat.DolbyVisionHlg, - 6 => HdrFormat.DolbyVisionHdr10, + 6 => hasHdr10Plus ? HdrFormat.DolbyVisionHdr10Plus : HdrFormat.DolbyVisionHdr10, _ => HdrFormat.DolbyVision }; }