MPEG-DASH和碎片mp4

时间:2013-08-12 01:30:42

标签: ffmpeg html5-video mp4 mpeg-dash

我对碎片化mp4的理解是它是一个单独的文件,但在内部它被构造为碎片。有人可以向我解释如何在DASH的.mpd文件中解决这些片段吗?我见过的.mpd文件似乎用不同的url来处理各个段,但我想,片段化的mp4必须通过字节偏移来解决到同一个url。然后浏览器如何知道哪些时间对应于哪个字节范围?

5 个答案:

答案 0 :(得分:5)

这是MPEG DASH主要配置文件的example mpd。这个mpd描述的mp4文件是一个碎片mp4。如你所见:

<SegmentURL media="bunny_15s_200kbit/bunny_200kbit_dashNonSeg.mp4" mediaRange="868-347185"/>
<SegmentURL media="bunny_15s_200kbit/bunny_200kbit_dashNonSeg.mp4" mediaRange="347186-664464"/>

<SegmentURL>元素处,片段可以被寻址到同一个网址,您可以在@mediaRange属性中找到字节偏移。

答案 1 :(得分:3)

.mpd文件有一个列表,其字节范围如上所示。要访问段,您需要解析每行的mediarange属性,并使用带有setRequestHeader的XHR请求它来指定字节范围。使用此方法,不需要服务器组件。这是我一直在使用的一些代码:

  var xhr = new XMLHttpRequest();

  // Range is in format of 1234-34567
  // url is the .mp4 file path 
  if (range || url) { // make sure we've got content in our params
    xhr.open('GET', url);
    xhr.setRequestHeader("Range", "bytes=" + range); 
    xhr.send();
    xhr.responseType = 'arraybuffer';
    try {
      // watch the ready state
      xhr.addEventListener("readystatechange", function () {
        if (xhr.readyState == 4) { //wait for video to load
          // add response to buffer
          try {   
            // videoSource is a sourceBuffer on your mediaSource object.             
            videoSource.appendBuffer(new Uint8Array(xhr.response));
            videoSource.onreadystatechange = function () {
              if (videoSource.readyState == videoSource.done) {
                videoElement.play();
              }
            };
          } catch (e) {
            //  fail quietly  
          }
        }
      }, false);

答案 2 :(得分:0)

服务器有一个清单,可以通过扫描文件来创建moof框。 moof + mdat =一个片段。当发出片段请求时,将在清单中查找文件偏移量并返回正确的框。

答案 3 :(得分:0)

据我所知...在DASH'onDemand'配置文件的情况下,DASH打包器的工作是创建* .mpd(清单)并指定哪个字节范围映射到一个段(可能是一些片段)。然后,客户端加载* .mpd并对清单中的范围发出http字节范围请求。我认为DASH'live'配置文件更像是流畅的流媒体,因为每个段都有一个url。

如果你需要找出mp4容器中片段的位置,我相信这些信息在片段'sidx'框中。

答案 4 :(得分:0)

现在ffmpeg似乎有support for HLS directly as well