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