Когда я использую шестнадцатеричную компоновку аудиоканала в контейнере mpegts, я могу нормально получать и воспроизводить поток только в том случае, если я настрою сервер hls, чтобы разрешить обслуживание самого первого сегмента, а затем объединение последующих сегментов.
Т.е. если я исследую сегмент 1414:
[mpegts @ 0x7faf58001200] Could not find codec parameters for stream 1 (Audio: aac (LC) ([15][0][0][0] / 0x000F), 0 channels, fltp, 1464 kb/s): unspecified sample rate
Consider increasing the value for the 'analyzeduration' and 'probesize' options
Input #0, mpegts, from '1414.ts':
Duration: 00:00:02.07, start: 2834.393367, bitrate: 9079 kb/s
Program 1
Stream #0:0[0x100]: Audio: aac (LC) ([15][0][0][0] / 0x000F), 0 channels, fltp, 1430 kb/s
Stream #0:1[0x101]: Audio: aac (LC) ([15][0][0][0] / 0x000F), 0 channels, fltp, 1464 kb/s
Stream #0:2[0x102]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1920x1080 [SAR 1:1 DAR 16:9], 59.94 fps, 59.94 tbr, 90k tbn, 119.88 tbc
Stream #0:3[0x103]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1920x1080 [SAR 1:1 DAR 16:9], 60 fps, 60 tbr, 90k tbn, 120 tbc
Однако , если я исследую первый сегмент:
Input #0, mpegts, from '0.ts':
Duration: 00:00:02.02, start: 1.412033, bitrate: 11598 kb/s
Program 1
Stream #0:0[0x100]: Audio: aac (LC) ([15][0][0][0] / 0x000F), 48000 Hz, 16 channels, fltp, 1353 kb/s
Stream #0:1[0x101]: Audio: aac (LC) ([15][0][0][0] / 0x000F), 48000 Hz, 16 channels, fltp, 744 kb/s
Stream #0:2[0x102]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1920x1080 [SAR 1:1 DAR 16:9], 59.94 fps, 59.94 tbr, 90k tbn, 119.88 tbc
Stream #0:3[0x103]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1920x1080 [SAR 1:1 DAR 16:9], 60 fps, 60 tbr, 90k tbn, 120 tbc
Файл списка воспроизведения очень прост и выглядит так:
#EXTM3U
#EXT-X-VERSION:3
#EXT-X-MEDIA-SEQUENCE:0
#EXT-X-TARGETDURATION:4
#EXTINF:2.000,
0.ts
#EXTINF:2.000,
1.ts
#EXTINF:2.000,
2.ts
#EXTINF:2.000,
3.ts
#EXTINF:2.000,
etc ...
Скажем, при 8-канальном макете этого не происходит. Каждый сегмент содержит правильные заголовки. Но я предпочитаю сохранять 16 каналов, потому что мое приложение на принимающей стороне использует 16-канальные файлы, и это позволяет избежать необходимости перекодирования при загрузке.
Я использую FFmpeg для загрузки потока mpegts.
Любое понимание механики того, что здесь происходит, и что я могу сделать, чтобы добиться желаемой независимости сегментов?
Для нетрадиционных макетов собственный кодировщик AAC записывает раздел PCE в заголовок битового потока как часть AudioSpecificConfig. Однако это происходит только в начале, поэтому в последующих файлах потоки AAC отсутствуют.
Обходной путь — перейти на другую схему пакетирования для AAC в MPEG-TS.
Добавить -hls_ts_options mpegts_flags=latm
при создании пакета HLS.
hmedia1
-mpegts_flags latm
напрямую). Есть ли какие-либо непредвиденные последствия, которые могут возникнуть из-за этого? Прочитав ANSI/SCTE 193-2 2014, можно предположить, что LATM в любом случае является предпочтительной инкапсуляцией.Гьян