// --------------------------------------------------------------------------------------------------------------------
//
// This file is part of the HandBrake source code - It may be used under the terms of the GNU General Public License.
//
//
// Defines the Converters type.
//
// --------------------------------------------------------------------------------------------------------------------
namespace HandBrake.Interop
{
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Runtime.InteropServices;
using HandBrake.Interop.HbLib;
using HandBrake.Interop.Model.Encoding;
using HandBrake.Interop.SourceData;
using HandBrake.Interop.Model;
///
/// Converters for various encoding values.
///
public static class Converters
{
///
/// Video Frame Rates
///
private static readonly Dictionary VideoRates;
///
/// Initializes static members of the Converters class.
///
static Converters()
{
HandBrakeUtils.EnsureGlobalInit();
VideoRates = new Dictionary();
foreach (var framerate in Encoders.VideoFramerates)
{
VideoRates.Add(double.Parse(framerate.Name, CultureInfo.InvariantCulture), framerate.Rate);
}
}
///
/// Convert Framerate to Video Rates
///
///
/// The framerate.
///
///
/// The vrate if a valid framerate is passed in.
///
///
/// Thrown when framerate is invalid.
///
public static int FramerateToVrate(double framerate)
{
if (!VideoRates.ContainsKey(framerate))
{
throw new ArgumentException("Framerate not recognized.", "framerate");
}
return VideoRates[framerate];
}
///
/// Gets the native code for the given encoder.
///
/// The audio encoder to convert.
/// The native code for the encoder.
public static uint AudioEncoderToNative(AudioEncoder encoder)
{
switch (encoder)
{
case AudioEncoder.Passthrough:
return NativeConstants.HB_ACODEC_AUTO_PASS;
case AudioEncoder.Ac3Passthrough:
return NativeConstants.HB_ACODEC_AC3_PASS;
case AudioEncoder.Ac3:
return NativeConstants.HB_ACODEC_AC3;
case AudioEncoder.ffaac:
return NativeConstants.HB_ACODEC_FFAAC;
case AudioEncoder.fdkaac:
return NativeConstants.HB_ACODEC_FDK_AAC;
case AudioEncoder.fdkheaac:
return NativeConstants.HB_ACODEC_FDK_HAAC;
case AudioEncoder.AacPassthru:
return NativeConstants.HB_ACODEC_AAC_PASS;
case AudioEncoder.Lame:
return NativeConstants.HB_ACODEC_LAME;
case AudioEncoder.Mp3Passthru:
return NativeConstants.HB_ACODEC_MP3_PASS;
case AudioEncoder.DtsPassthrough:
return NativeConstants.HB_ACODEC_DCA_PASS;
case AudioEncoder.DtsHDPassthrough:
return NativeConstants.HB_ACODEC_DCA_HD_PASS;
case AudioEncoder.Vorbis:
return NativeConstants.HB_ACODEC_VORBIS;
case AudioEncoder.ffflac:
return NativeConstants.HB_ACODEC_FFFLAC;
}
return 0;
}
///
/// Convert Native HB Internal Audio int to a AudioCodec model.
///
///
/// The codec.
///
///
/// An AudioCodec object.
///
public static AudioCodec NativeToAudioCodec(uint codec)
{
switch (codec)
{
case NativeConstants.HB_ACODEC_AC3:
return AudioCodec.Ac3;
case NativeConstants.HB_ACODEC_DCA:
return AudioCodec.Dts;
case NativeConstants.HB_ACODEC_DCA_HD:
return AudioCodec.DtsHD;
case NativeConstants.HB_ACODEC_LAME:
case NativeConstants.HB_ACODEC_MP3:
return AudioCodec.Mp3;
case NativeConstants.HB_ACODEC_FAAC:
case NativeConstants.HB_ACODEC_FFAAC:
case NativeConstants.HB_ACODEC_CA_AAC:
case NativeConstants.HB_ACODEC_CA_HAAC:
case NativeConstants.HB_ACODEC_FDK_HAAC: // TODO Check this is correct
case NativeConstants.HB_ACODEC_FDK_AAC: // TODO Check this is correct
return AudioCodec.Aac;
case NativeConstants.HB_ACODEC_FFFLAC:
return AudioCodec.Flac;
default:
return AudioCodec.Other;
}
}
///
/// Converts a native HB encoder structure to an Encoder model.
///
/// The structure to convert.
/// The converted model.
public static HBVideoEncoder NativeToVideoEncoder(hb_encoder_s encoder)
{
var result = new HBVideoEncoder
{
Id = encoder.codec,
ShortName = encoder.short_name,
DisplayName = encoder.name,
CompatibleContainers = Container.None
};
if ((encoder.muxers & NativeConstants.HB_MUX_MKV) > 0)
{
result.CompatibleContainers = result.CompatibleContainers | Container.Mkv;
}
if ((encoder.muxers & NativeConstants.HB_MUX_MP4) > 0)
{
result.CompatibleContainers = result.CompatibleContainers | Container.Mp4;
}
return result;
}
///
/// Converts a native HB encoder structure to an Encoder model.
///
/// The structure to convert.
/// The converted model.
public static HBAudioEncoder NativeToAudioEncoder(hb_encoder_s encoder)
{
var result = new HBAudioEncoder
{
Id = encoder.codec,
ShortName = encoder.short_name,
DisplayName = encoder.name,
CompatibleContainers = Container.None
};
if ((encoder.muxers & NativeConstants.HB_MUX_MKV) > 0)
{
result.CompatibleContainers = result.CompatibleContainers | Container.Mkv;
}
if ((encoder.muxers & NativeConstants.HB_MUX_MP4) > 0)
{
result.CompatibleContainers = result.CompatibleContainers | Container.Mp4;
}
result.QualityLimits = Encoders.GetAudioQualityLimits(encoder.codec);
result.DefaultQuality = HBFunctions.hb_audio_quality_get_default((uint)encoder.codec);
result.CompressionLimits = Encoders.GetAudioCompressionLimits(encoder.codec);
result.DefaultCompression = HBFunctions.hb_audio_compression_get_default((uint)encoder.codec);
return result;
}
///
/// Converts a native HB rate structure to an HBRate object.
///
/// The structure to convert.
/// The converted rate object.
public static HBRate NativeToRate(hb_rate_s rate)
{
return new HBRate
{
Name = rate.name,
Rate = rate.rate
};
}
///
/// Converts a native HB mixdown structure to a Mixdown model.
///
/// The structure to convert.
/// The converted model.
public static HBMixdown NativeToMixdown(hb_mixdown_s mixdown)
{
return new HBMixdown
{
Id = mixdown.amixdown,
ShortName = mixdown.short_name,
DisplayName = mixdown.name
};
}
///
/// Converts a native language structure to a Language object.
///
/// The structure to convert.
/// The converted structure.
public static Language NativeToLanguage(iso639_lang_t language)
{
string englishName = InteropUtilities.ReadUtf8Ptr(language.eng_name);
string nativeName = InteropUtilities.ReadUtf8Ptr(language.native_name);
return new Language
{
Code = language.iso639_2,
EnglishName = englishName,
NativeName = nativeName
};
}
///
/// Converts the PTS amount to a TimeSpan. There may be some accuracy loss here.
///
/// The PTS to convert.
/// The timespan for it.
public static TimeSpan PtsToTimeSpan(ulong pts)
{
return TimeSpan.FromTicks((long)((pts * 10000000) / 90000));
}
///
/// Converts the PTS amount to seconds.
///
/// The PTS to convert.
/// The corresponding number of seconds.
public static double PtsToSeconds(ulong pts)
{
return (double)pts / 90000;
}
}
}