| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 | using MediaBrowser.Common.IO;using MediaBrowser.Controller.Channels;using MediaBrowser.Controller.Configuration;using MediaBrowser.Controller.Library;using MediaBrowser.Controller.LiveTv;using MediaBrowser.Controller.MediaEncoding;using MediaBrowser.Controller.Session;using MediaBrowser.Model.IO;using MediaBrowser.Model.Logging;using System;using System.Collections.Generic;namespace MediaBrowser.MediaEncoding.Encoder{    public class AudioEncoder : BaseEncoder    {        public AudioEncoder(MediaEncoder mediaEncoder, ILogger logger, IServerConfigurationManager configurationManager, IFileSystem fileSystem, ILiveTvManager liveTvManager, IIsoManager isoManager, ILibraryManager libraryManager, IChannelManager channelManager, ISessionManager sessionManager, ISubtitleEncoder subtitleEncoder, IMediaSourceManager mediaSourceManager) : base(mediaEncoder, logger, configurationManager, fileSystem, liveTvManager, isoManager, libraryManager, channelManager, sessionManager, subtitleEncoder, mediaSourceManager)        {        }        protected override string GetCommandLineArguments(EncodingJob job)        {            var audioTranscodeParams = new List<string>();            var bitrate = job.OutputAudioBitrate;            if (bitrate.HasValue)            {                audioTranscodeParams.Add("-ab " + bitrate.Value.ToString(UsCulture));            }            if (job.OutputAudioChannels.HasValue)            {                audioTranscodeParams.Add("-ac " + job.OutputAudioChannels.Value.ToString(UsCulture));            }            if (job.OutputAudioSampleRate.HasValue)            {                audioTranscodeParams.Add("-ar " + job.OutputAudioSampleRate.Value.ToString(UsCulture));            }            var threads = GetNumberOfThreads(job, false);            var inputModifier = GetInputModifier(job);            return string.Format("{0} {1} -threads {2}{3} {4} -id3v2_version 3 -write_id3v1 1 -y \"{5}\"",                inputModifier,                GetInputArgument(job),                threads,                " -vn",                string.Join(" ", audioTranscodeParams.ToArray()),                job.OutputFilePath).Trim();        }        protected override string GetOutputFileExtension(EncodingJob state)        {            var ext = base.GetOutputFileExtension(state);            if (!string.IsNullOrEmpty(ext))            {                return ext;            }            var audioCodec = state.Options.AudioCodec;            if (string.Equals("aac", audioCodec, StringComparison.OrdinalIgnoreCase))            {                return ".aac";            }            if (string.Equals("mp3", audioCodec, StringComparison.OrdinalIgnoreCase))            {                return ".mp3";            }            if (string.Equals("vorbis", audioCodec, StringComparison.OrdinalIgnoreCase))            {                return ".ogg";            }            if (string.Equals("wma", audioCodec, StringComparison.OrdinalIgnoreCase))            {                return ".wma";            }            return null;        }        protected override bool IsVideoEncoder        {            get { return false; }        }    }}
 |