From f7487708e5676a823330693f010d84c4bf7ebe21 Mon Sep 17 00:00:00 2001 From: Charles Ewert Date: Sun, 20 Oct 2024 18:31:35 -0400 Subject: [PATCH 1/2] transcode audio to keep multichannel support --- source/api/Items.bs | 37 ++++++++++++++++++++++++++++++++++++- 1 file changed, 36 insertions(+), 1 deletion(-) diff --git a/source/api/Items.bs b/source/api/Items.bs index 65ed564b9..05262bece 100644 --- a/source/api/Items.bs +++ b/source/api/Items.bs @@ -45,7 +45,7 @@ function ItemPostPlaybackInfo(id as string, mediaSourceId = "" as string, audioT if selectedAudioStream <> invalid params.AudioStreamIndex = audioTrackIndex - ' force the server to transcode AAC profiles we don't support to MP3 instead of the usual AAC + ' force the server to transcode AAC profiles we don't support to MP3 instead of the usual AAC. ' TODO: Remove this after server adds support for transcoding AAC from one profile to another if selectedAudioStream.Codec <> invalid and LCase(selectedAudioStream.Codec) = "aac" if selectedAudioStream.Profile <> invalid and LCase(selectedAudioStream.Profile) = "main" or LCase(selectedAudioStream.Profile) = "he-aac" @@ -64,6 +64,26 @@ function ItemPostPlaybackInfo(id as string, mediaSourceId = "" as string, audioT end for end if end if + + preferredAudioCodec = GetPreferredAudioCodec() + if preferredAudioCodec <> "aac" + ' device supports multi-channel audio output + + ' is this a multi-channel audio stream? + if selectedAudioStream.Channels <> invalid and selectedAudioStream.Channels > 2 + ' tell the server to transcode this file to the preferred multi channel audio codec instead of the default AAC for stereo + for each rule in deviceProfile.TranscodingProfiles + if rule.Container = "ts" or rule.Container = "mp4" + if rule.AudioCodec = "aac" + rule.AudioCodec = preferredAudioCodec + else + rule.AudioCodec = preferredAudioCodec + "," + rule.AudioCodec + end if + end if + end for + end if + + end if end if end if @@ -538,3 +558,18 @@ function TVEpisodeShuffleList(show_id as string) return data end function + +' Returns the users preferred audio codec in string format +' Defaults to AAC for stereo and AC3 for surround sound +' with a user setting to use DTS for surround sound +function GetPreferredAudioCodec() as string + deviceInfo = CreateObject("roDeviceInfo") + preferredAudioCodec = "aac" ' AAC for stereo + if deviceInfo.GetAudioOutputChannel() <> "Stereo" + preferredAudioCodec = "ac3" ' Dolby Digital for surround sound + if m.global.session.user.settings["playback.forceDTS"] + preferredAudioCodec = "dts" ' DTS for surround sound when asked + end if + end if + return preferredAudioCodec +end function From c0f0a184b0465bbd14f6736aca83c703eace04a5 Mon Sep 17 00:00:00 2001 From: Charles Ewert Date: Sun, 20 Oct 2024 19:10:17 -0400 Subject: [PATCH 2/2] always transcode multichannel aac if surround sound is detected --- source/api/Items.bs | 13 +++++++++++++ source/utils/deviceCapabilities.bs | 2 +- 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/source/api/Items.bs b/source/api/Items.bs index 05262bece..786512639 100644 --- a/source/api/Items.bs +++ b/source/api/Items.bs @@ -81,6 +81,19 @@ function ItemPostPlaybackInfo(id as string, mediaSourceId = "" as string, audioT end if end if end for + + ' don't direct play multi-channel AAC + if selectedAudioStream.Codec <> invalid and LCase(selectedAudioStream.Codec) = "aac" + for each rule in deviceProfile.DirectPlayProfiles + if rule.audioCodec <> invalid + if rule.AudioCodec = "aac" + rule.AudioCodec = "" + else if rule.AudioCodec.Left(4) = "aac," + rule.AudioCodec = mid(rule.AudioCodec, 5) + end if + end if + end for + end if end if end if diff --git a/source/utils/deviceCapabilities.bs b/source/utils/deviceCapabilities.bs index 384838972..44065db66 100644 --- a/source/utils/deviceCapabilities.bs +++ b/source/utils/deviceCapabilities.bs @@ -87,7 +87,7 @@ function GetDirectPlayProfiles() as object } ' all possible codecs (besides those restricted by user settings) videoCodecs = ["h264", "mpeg4 avc", "vp8", "vp9", "h263", "mpeg1"] - audioCodecs = ["mp3", "mp2", "pcm", "lpcm", "wav", "ac3", "ac4", "aiff", "wma", "flac", "alac", "aac", "opus", "dts", "wmapro", "vorbis", "eac3", "mpg123"] + audioCodecs = ["aac", "mp3", "mp2", "pcm", "lpcm", "wav", "ac3", "ac4", "aiff", "wma", "flac", "alac", "opus", "dts", "wmapro", "vorbis", "eac3", "mpg123"] ' check if hevc is disabled if globalUserSettings["playback.compatibility.disablehevc"] = false