Então eu tenho esta entrada:
Stream #0:0(eng): Video: hevc (Main 10), yuv420p10le(tv, bt2020nc/bt2020/smpte2084), 3840x2160, SAR 1:1 DAR 16:9, 25 fps, 25 tbr, 1k tbn, 25 tbc (default)
Stream #0:1(eng): Audio: dts (DTS-HD MA), 48000 Hz, 5.1(side), s32p (24 bit) (default)
Stream #0:2(rus): Audio: dts (DTS-HD MA), 48000 Hz, 5.1(side), s32p (24 bit)
Stream #0:3(ger): Audio: dts (DTS-HD MA), 48000 Hz, 5.1(side), s32p (24 bit)
Stream #0:4(ita): Audio: ac3, 48000 Hz, stereo, fltp, 192 kb/s
Stream #0:5(eng): Subtitle: subrip
Stream #0:6(ita): Subtitle: subrip (default)
Stream #0:7(eng): Subtitle: dvd_subtitle, 1920x1080
Stream #0:8(ita): Subtitle: subrip
E eu quero essa saída:
Stream #0:0(eng): Video: hevc (Main 10), yuv420p10le(tv, bt2020nc/bt2020/smpte2084), 3840x2160, SAR 1:1 DAR 16:9, 25 fps, 25 tbr, 1k tbn, 25 tbc (default)
Stream #0:1(eng): Audio: aac (default)
Stream #0:2(eng): Audio: dts (DTS-HD MA), 48000 Hz, 5.1(side), s32p (24 bit)
Stream #0:3(rus): Audio: dts (DTS-HD MA), 48000 Hz, 5.1(side), s32p (24 bit)
Stream #0:4(ger): Audio: dts (DTS-HD MA), 48000 Hz, 5.1(side), s32p (24 bit)
Stream #0:5(ita): Audio: ac3, 48000 Hz, stereo, fltp, 192 kb/s
Stream #0:6(eng): Subtitle: subrip (default)
Stream #0:7(ita): Subtitle: subrip
Stream #0:8(eng): Subtitle: dvd_subtitle, 1920x1080
Stream #0:9(ita): Subtitle: subrip
Portanto, basicamente converta o fluxo de áudio 1 para AAC (mesma qualidade, apenas AAC em vez de DTS, idealmente renomeando o título e mantenha-o como padrão) e insira como fluxo 1 na saída. Além disso, preserve todos os fluxos existentes simplesmente copiando-os um índice adiante.
Até agora eu fiz este comando:
sudo ffmpeg -i 'input.mkv' -map 0:0 -c:v copy -map 0:1 -c:1:a aac -ac 6 -ab 320k -map 0:1 -map 0:2 -map 0:3 -map 0:4 -map 0:5 -map 0:6 -map 0:7 -map 0:8 -c:s copy 'output.mkv'
Mas o resultado não é o que eu espero:
Stream mapping:
Stream #0:0 -> #0:0 (copy)
Stream #0:1 -> #0:1 (dts (dca) -> aac (native))
Stream #0:1 -> #0:2 (dts (dca) -> vorbis (libvorbis))
Stream #0:2 -> #0:3 (dts (dca) -> vorbis (libvorbis))
Stream #0:3 -> #0:4 (dts (dca) -> vorbis (libvorbis))
Stream #0:4 -> #0:5 (ac3 (native) -> vorbis (libvorbis))
Stream #0:5 -> #0:6 (copy)
Stream #0:6 -> #0:7 (copy)
Stream #0:7 -> #0:8 (copy)
Stream #0:8 -> #0:9 (copy)
Então, o que estou perdendo para que o fluxo de áudio que eu quero copiar não seja convertido?
Gravy seria também reatribuir sub padrão para eng:)