我有一个程序,它连接到实时 MPEG-TS 流并将其提供给 ffmpeg,然后将其转换为 MPEG-DASH。
输入 TS 有三个音频 PID。(确切的音频 PID 将根据节目 ID 和流源而不同,因此无法硬编码到命令行中)。例如:
0x67 Spanish Dubbed Audio "spa/Main Audio"
0x68 Original Audio "qaa/Main Audio"
0x69 Descriptive Audio for visually impaired
在网络浏览器中使用 的播放器dash.js
有一个菜单可供选择要选择的音轨。
但是,根据连接到 MPEG-TS 流的时间,ffmpeg 会以不同的、看似随机的顺序枚举音频。似乎音轨在输出中按升序“输入流”索引分配。例如:
Output Stream mapping:
Stream #0:18 (mpeg2video) -> scale (graph 0)
scale (graph 0) -> Stream #0:0 (libx264)
Stream #0:9 -> #0:1 (mp2 (native) -> aac (native))
Stream #0:13 -> #0:2 (mp2 (native) -> aac (native))
Stream #0:17 -> #0:3 (mp2 (native) -> aac (native))
扫描输入后分配spa/spa/qaa:
Stream #0:9[0x67](spa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, stereo, fltp, 192 kb/s
Stream #0:13[0x69](spa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, mono, fltp, 96 kb/s (visual impaired) (descriptions)
Stream #0:17[0x68](qaa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, stereo, fltp, 128 kb/s
多运行几次,输入检测总是不同的:
Stream #0:8[0x69](spa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, mono, fltp, 96 kb/s (visual impaired) (descriptions)
Stream #0:15[0x68](qaa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, stereo, fltp, 128 kb/s
Stream #0:17[0x67](spa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, stereo, fltp, 192 kb/s
Stream #0:10[0x68](qaa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, stereo, fltp, 128 kb/s
Stream #0:17[0x67](spa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, stereo, fltp, 192 kb/s
Stream #0:22[0x69](spa): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, mono, fltp, 96 kb/s (visual impaired) (descriptions)
如何ffmpeg
创建输入到输出的一致映射?理想情况下,通过增量 PID 编号。
編輯
我认为这与我的问题并不真正相关,但对于那些感兴趣的人,这里有一个命令行... ffmpeg
从管道读取。我的程序接收提要并将其写入管道。
ffmpeg -re -f mpegts -i pipe:10 -ignore_unknown \
-map 0:p:510 -map -0:s -map -0:d \
-filter_complex [p:510:v]scale=640:-1 -r 25 -force_key_frames expr:gte(t,n_forced*1) \
-c:v libx264 -b:v 1M -x264-params scenecut=0 -threads 2 \
-c:a aac -b:a 64k -ac 2 \
-f dash -dash_segment_type mp4 -movflags +delay_moov \
-seg_duration 2.000000 -frag_type duration -frag_duration 0.200000 \
-index_correction 1 -target_latency 5 -window_size 10 -extra_window_size 5 \
-remove_at_exit 1 -streaming 1 -ldash 1 -use_template 1 -use_timeline 0 \
-write_prft 1 -avioflags direct -fflags +nobuffer+flush_packets \
-format_options movflags=+cmaf -utc_timing_url \
/web/be/time.php /var/ott/session_9733/master.mpd'
答案1
MPEG-TS 是一种传输流,即流动的流,因此流顺序由解复用器遇到 PES 数据包的顺序设置。这是无法更改的。
你可以做的是,-map 0:p:510
用-map 0:p:510:v -map 0:p:510:a:m:language:qaa -map 0:p:510:a:m:language:spa
我没有可以使用的 MPTS 源,所以目前无法验证语法。
答案2
从 Gyan 的回答来看,ffmpeg
枚举他们看到的流。因此,使用 MPTS(多节目传输流),无法轻松选择流和强制执行流的特定排序(基于 PID 号)
因此程序必须首先独立扫描 TS 以构建视频和音频 PID 列表。然后循环使用这些 PID 来构建命令ffmpeg
行。
这是构造的命令行:
ffmpeg -re -loglevel verbose \
-f mpegts -i inputFile.ts -ignore_unknown \
-map 0:v:i:101 \
-map 0:a:i:103 -metadata:s:a:0 title='Main' \
-map 0:a:i:104 -metadata:s:a:1 title='Main' \
-map 0:a:i:105 -metadata:s:a:2 title='Visual impaired commentary' \
-map -0:s -map -0:d \
-filter_complex [p:510:v]scale=640:-1 \
-r 25 -force_key_frames expr:gte\(t,n_forced*1\) \
-c:v libx264 -b:v 1M -x264-params scenecut=0 \
-threads 2 -c:a aac -b:a 64k -ac 2 \
-f dash -dash_segment_type mp4 -movflags +delay_moov -seg_duration 2.000000 \
-frag_type duration -frag_duration 0.200000 -index_correction 1 \
-target_latency 5 -window_size 10 -extra_window_size 5 -remove_at_exit 1 \
-streaming 1 -ldash 1 -use_template 1 -use_timeline 0 -write_prft 1 \
-avioflags direct -fflags +nobuffer+flush_packets -format_options movflags=+cmaf \
-utc_timing_url /time.php \
/tmp/master.mpd