Mam dwie nazwy filmów v11.webm i v12.webm.Jak dołączyć dwa pliki wideo do bufora źródłowego za pomocą interfejsu API źródła?
Czego chcę, żeby te dwa filmy działały bezproblemowo bez żadnych luk.
Podążam za podejściem do źródła danych w api mediów, do którego dołączam dane do bufora źródłowego.
Mam na myśli demo podane link
Mam zmodyfikowany tego przykładem i usunięto część wyrwy wideo, a także próbował dołączyć dane do pliku bufora źródłowego mądry.
Mój kod wygląda następująco:
<script>
var video = document.querySelector('video');
window.MediaSource = window.MediaSource || window.WebKitMediaSource;
if (!!!window.MediaSource) {
alert('MediaSource API is not available');
}
var mediaSource = new MediaSource();
video.src = window.URL.createObjectURL(mediaSource);
mediaSource.addEventListener('webkitsourceopen', function(e) {
var sourceBuffer = mediaSource.addSourceBuffer('video/webm; codecs="vorbis,vp8"');
for(i=1;i<=2;i++)
{
(function(i){
GET('v1'+i+'.webm', function(uInt8Array) {
var file = new Blob([uInt8Array], {type: 'video/webm'});
var reader = new FileReader();
reader.onload = function(e) {
sourceBuffer.append(new Uint8Array(e.target.result));
};
reader.readAsArrayBuffer(file);
});
})(i);
}
}, false);
mediaSource.addEventListener('webkitsourceended', function(e) {
logger.log('mediaSource readyState: ' + this.readyState);
}, false);
function GET(url, callback) {
// alert(url);
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true);
xhr.responseType = 'arraybuffer';
xhr.send();
xhr.onload = function(e) {
if (xhr.status != 200) {
alert("Unexpected status code " + xhr.status + " for " + url);
return false;
}
callback(new Uint8Array(xhr.response));
};
}
</script>
Teraz kod nie działa zgodnie z oczekiwaniami.
Istnieje niespójne mieszanie danych pliku v11.webm i v12.webm.
Nie działa płynnie.
Czy kiedykolwiek byłeś w stanie to wymyślić? MediaSource Spec twierdzi, że jest to możliwe dzięki Offsetom Timestamp (https://dvcs.w3.org/hg/html-media/raw-file/6d127e69c9f8/media-source/media-source.html#source-buffer- timestamp-offsets), ale nie byłem w stanie dokładnie ustalić, jak ustawić takie przesunięcie. –