1

长话短说:为什么 HLS 不能一个接一个地播放普通的 MP4 文件?为什么需要将媒体文件分割成 .ts 段?

细节:

我们将 MP4 文件分割成迷你 MP4 片段(不是 TS),每个片段大约 30 秒进行测试。它永远不会在任何 HLS 播放器中播放,只是加载所有段文件然后什么都没有发生。

示例 MP4 片段信息:

Format                      : MPEG-4
Format profile              : Base Media
Codec ID                    : isom
File size                   : 1.44 MiB
Duration                    : 32s 950ms
Overall bit rate            : 366 Kbps
Writing application         : Lavf56.25.101

Video
ID                          : 1
Format                      : AVC
Format/Info                 : Advanced Video Codec
Format profile              : High@L4.1
Format settings, CABAC      : Yes
Format settings, ReFrames   : 6 frames
Codec ID                    : avc1
Codec ID/Info               : Advanced Video Coding
Duration                    : 32s 950ms
Bit rate                    : 230 Kbps
Width                       : 426 pixels
Height                      : 240 pixels
Display aspect ratio        : 16:9
Original display aspect rat : 16:9
Frame rate mode             : Constant
Frame rate                  : 23.976 fps
Color space                 : YUV
Chroma subsampling          : 4:2:0
Bit depth                   : 8 bits
Scan type                   : Progressive
Bits/(Pixel*Frame)          : 0.094
Stream size                 : 925 KiB (63%)
Writing library             : x264 core 142 r2495 6a301b6

Audio
ID                          : 2
Format                      : AAC
Format/Info                 : Advanced Audio Codec
Format profile              : LC
Codec ID                    : 40
Duration                    : 32s 896ms
Bit rate mode               : Constant
Bit rate                    : 129 Kbps
Channel(s)                  : 2 channels
Channel(s)_Original         : 6 channels
Channel positions           : Front: L C R, Side: L R, LFE
Sampling rate               : 48.0 KHz
Compression mode            : Lossy
Stream size                 : 517 KiB (35%)

M3U8 大师:

#EXTM3U
#EXT-X-VERSION:7
#EXT-X-INDEPENDENT-SEGMENTS

#EXT-X-STREAM-INF:RESOLUTION=426x240,BANDWIDTH=370000,CODECS="avc1.640015,mp4a.40.2"
240p.m3u8

#EXT-X-STREAM-INF:RESOLUTION=640x360,BANDWIDTH=580000,CODECS="avc1.640015,mp4a.40.2"
360p.m3u8

#EXT-X-STREAM-INF:RESOLUTION=896x504,BANDWIDTH=900000,CODECS="avc1.640015,mp4a.40.2"
480p.m3u8

#EXT-X-STREAM-INF:RESOLUTION=1280x720,BANDWIDTH=1500000,CODECS="avc1.640015,mp4a.40.2"
720p.m3u8

240p.m3u8

#EXTM3U
#EXT-X-VERSION:7
#EXT-X-MEDIA-SEQUENCE:0
#EXT-X-PLAYLIST-TYPE:VOD
#EXT-X-TARGETDURATION:34

#EXTINF:33.033033,
240p000.mp4
#EXTINF:33.533534,
240p001.mp4
#EXTINF:24.941608,
240p002.mp4
#EXTINF:28.611945,
240p003.mp4
#EXT-X-ENDLIST

使用 HLS.js 进行测试时,会出现以下错误:

解析错误:找不到与内容匹配的解复用器,无法恢复,上次媒体错误恢复失败...

Bitmovin Player:加载所有变体的所有片段并且从不播放其中任何一个。停下来。

在 Windows 上的 Chrome 和 Firefox、Mac、Android 和 iPad 浏览器上的 Safari 上测试。永远不会对它们中的任何一个起作用。我们做错什么了吗?!

4

3 回答 3

2

虽然传输流段是自初始化的,但 fMP4 段通常/通常不是这种情况。因此,您需要将初始化段添加到清单文件中,这是初始化解码器所需的。这可以使用 #EXT-X-MAP:URI 标签来完成,如本博文图片和以下示例所示:

#EXTM3U
#EXT-X-TARGETDURATION:4
#EXT-X-VERSION:7
#EXT-X-MEDIA-SEQUENCE:1
#EXT-X-PLAYLIST-TYPE:VOD
#EXT-X-INDEPENDENT-SEGMENTS
#EXT-X-MAP:URI="init.mp4"

#EXTINF:4.0
segment_0.m4s
#EXTINF:4.0
segment_1.m4s
...
#EXT-X-ENDLIST

我不确定 HLS.js,但这至少适用于 Bitmovin Player。如果不是,我建议使用 Bitmovin 的支持。

Apple 还提供了一个带有 fMP4 HLS 的测试页面(需要在浏览器中提供本机 HLS 支持,例如在 Safari 中),Bitmovin 有一个带有 fMP4 HLS 的演示页面可用

于 2016-12-07T08:57:13.313 回答
0

FFMPEG 现在已经支持为 HLS 生成片段 MP4。看看https://trac.ffmpeg.org/ticket/5699

于 2017-07-18T21:25:23.470 回答
0

为什么 HLS 不能一个接一个地播放普通的 MP4 文件?为什么需要将媒体文件分割成 .ts 段?

MP4 文件有一个您并不真正想要或不需要的完整容器。理论上,每个片段都可以包含自己数量的音频和视频轨道,每个轨道都有自己的格式、帧速率、采样率等。您不需要所有这些,还需要将视频片段干净地粘贴在一起。因此,您首先需要一些东西来干净地编码段。

于 2016-08-20T07:03:00.220 回答