// -------------------------------------------------------------------------------------------------------------------- // // This file is part of the HandBrake source code - It may be used under the terms of the GNU General Public License. // // // Audio Encoder Converter // // -------------------------------------------------------------------------------------------------------------------- namespace HandBrakeWPF.Converters.Audio { using System; using System.Collections.Generic; using System.Globalization; using System.Linq; using System.Windows; using System.Windows.Data; using HandBrake.ApplicationServices.Interop; using HandBrake.ApplicationServices.Utilities; using HandBrakeWPF.Utilities; using AudioEncoder = HandBrakeWPF.Services.Encode.Model.Models.AudioEncoder; using EncodeTask = HandBrakeWPF.Services.Encode.Model.EncodeTask; using OutputFormat = HandBrakeWPF.Services.Encode.Model.Models.OutputFormat; /// /// Audio Encoder Converter /// public class AudioEncoderConverter : IMultiValueConverter { /// /// Gets a list of audio encoders OR returns the string name of an encoder depending on the input. /// /// /// The values. /// /// /// The target type. /// /// /// The parameter. /// /// /// The culture. /// /// /// IEnumberable AudioEncoder or String encoder name. /// public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture) { // TODO -> Be smarter and only show the available Passthru options. if (values.Count() == 2) { List encoders = EnumHelper.GetEnumList().ToList(); EncodeTask task = values[1] as EncodeTask; if (!HandBrakeEncoderHelpers.AudioEncoders.Any(a => a.ShortName.Contains("fdk"))) { encoders.Remove(AudioEncoder.fdkaac); encoders.Remove(AudioEncoder.fdkheaac); } if (task != null && task.OutputFormat != OutputFormat.Mkv) { encoders.Remove(AudioEncoder.Vorbis); encoders.Remove(AudioEncoder.ffflac); encoders.Remove(AudioEncoder.ffflac24); encoders.Remove(AudioEncoder.FlacPassthru); encoders.Remove(AudioEncoder.Opus); } if (parameter != null && parameter.ToString() == "True") { encoders.Remove(AudioEncoder.DtsHDPassthrough); encoders.Remove(AudioEncoder.DtsPassthrough); encoders.Remove(AudioEncoder.EAc3Passthrough); encoders.Remove(AudioEncoder.AacPassthru); encoders.Remove(AudioEncoder.Ac3Passthrough); encoders.Remove(AudioEncoder.Mp3Passthru); encoders.Remove(AudioEncoder.Passthrough); encoders.Remove(AudioEncoder.TrueHDPassthrough); encoders.Remove(AudioEncoder.FlacPassthru); } return EnumHelper.GetEnumDisplayValuesSubset(encoders); } if (values.Any() && values.First() != DependencyProperty.UnsetValue) { return EnumHelper.GetDisplay((AudioEncoder)values[0]); } return EnumHelper.GetDisplay(AudioEncoder.ffaac); } /// /// Convert from a string name, to enum value. /// /// /// The value. /// /// /// The target types. /// /// /// The parameter. /// /// /// The culture. /// /// /// Returns the audio encoder enum item. /// public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture) { string name = value as string; if (!string.IsNullOrEmpty(name)) { return new object[] { EnumHelper.GetValue(name) }; } return null; } } }