From: sr55 Date: Mon, 10 Apr 2017 15:37:23 +0000 (+0100) Subject: WinGui: Audio Defaults: If the mixdown is not supported, get the best default mixdo... X-Git-Tag: 1.1.0~603 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=10e88ed33ce9a397e92aed8d03631bed3014f8b9;p=handbrake WinGui: Audio Defaults: If the mixdown is not supported, get the best default mixdown for the source track / encoder. #661 --- diff --git a/win/CS/HandBrakeWPF/Services/Encode/Model/Models/AudioTrack.cs b/win/CS/HandBrakeWPF/Services/Encode/Model/Models/AudioTrack.cs index 6dede959d..5d0333311 100644 --- a/win/CS/HandBrakeWPF/Services/Encode/Model/Models/AudioTrack.cs +++ b/win/CS/HandBrakeWPF/Services/Encode/Model/Models/AudioTrack.cs @@ -123,6 +123,17 @@ namespace HandBrakeWPF.Services.Encode.Model.Models this.encoder = chosenEncoder; this.gain = track.Gain; this.mixDown = track.MixDown != null ? track.MixDown.ShortName : "dpl2"; + + // If the mixdown isn't supported, downgrade it. + if (!HandBrakeEncoderHelpers.MixdownIsSupported(track.MixDown, encoderInfo, sourceTrack.ChannelLayout)) + { + HBMixdown changedMixdown = HandBrakeEncoderHelpers.GetDefaultMixdown(encoderInfo, (ulong)sourceTrack.ChannelLayout); + if (changedMixdown != null) + { + this.mixDown = changedMixdown.ShortName; + } + } + this.sampleRate = track.SampleRate; this.encoderRateType = track.EncoderRateType; this.quality = track.Quality;