2017-08-15 17 views
0

私はうまく動作するビデオ(webm)キャプチャスクリプトを持っています。それはビデオを記録し、それをダウンロードとして提供します。コードの関連部分は次のとおりです。ビデオストリームからデータURLを取得しますか?

stopBtn.addEventListener('click', function() { 
    recorder.ondataavailable = e => { 
     ul.style.display = 'block'; 
     var a = document.createElement('a'), 
      li = document.createElement('li'); 
     a.download = ['video_', (new Date() + '').slice(4, 28), '.'+vid_format].join(''); 
     a.textContent = a.download; 
     a.href = URL.createObjectURL(stream); //<-- deprecated usage? 
     li.appendChild(a); 
     ul.appendChild(li); 
    }; 
    recorder.stop(); 
    startBtn.removeAttribute('disabled'); 
    stopBtn.disabled = true; 
}, false); 

これは私の言うとおりです。しかし、コンソールは、メディアストリームをURL.createObjectURLに渡すことは推奨されていないと言い、代わりにHTMLMediaElement srcObjectを使用する必要があります。

だから私はそれを変更:

a.href = URL.createObjectURL(video.srcObject); 

...とすべてがまだ動作しますが、私は同じ警告が表示されます。

この廃止予定のない方法でURLまたはBLOBデータを取得する方法を知っている人はいますか?

私はまた、ビデオ要素からsrccurrentSrcのプロパティを読み込もうとしましたが、ストリームが関係するところで空に戻ります。

+1

ストリームをダウンロードしようとしていますか?これを行う一般的な方法は、MediaRecorderでblobを作成し、blob(URL.createObjectURLが含まれ、ストリームではなくblobを含む)をダウンロードすることです。 –

+0

基本的には、録画したビデオをサーバーに保存したいだけです。ヒントをお寄せいただきありがとうございます - これを行う方法や何を読むべきかを教えていただけますか?コードスニペットはエースです。 – Utkanos

+0

このコードは本当に機能しましたか? Weirdird ... – Kaiido

答えて

3

私はあなたのコードでも動作しなかったことは本当に驚いて...

streamが本当にMediaStreamある場合はダウンロードを中止したときに、ブラウザでも(したがって、それはダウンロードしなければならないどのようなサイズではない知っているべきではありませんそれはストリームです)。

MediaRecorder#ondataavailableは、記録されたMediaStreamのチャンクで満たされたdataプロパティのイベントを公開します。このイベントでは、これらのチャンクを配列に格納してから、これらのBlobチャンクの連結を、通常はMediaRecorder#onstopイベントにダウンロードしなければなりません。

const stream = getCanvasStream(); // we'll use a canvas stream so that it works in stacksnippet 
 
const chunks = []; // this will store our Blobs chunks 
 
const recorder = new MediaRecorder(stream); 
 
recorder.ondataavailable = e => chunks.push(e.data); // a new chunk Blob is given in this event 
 
recorder.onstop = exportVid; // only when the recorder stops, we do export the whole; 
 
setTimeout(() => recorder.stop(), 5000); // will stop in 5s 
 
recorder.start(1000); // all chunks will be 1s 
 

 
function exportVid() { 
 
    var blob = new Blob(chunks); // here we concatenate all our chunks in a single Blob 
 
    var url = URL.createObjectURL(blob); // we creat a blobURL from this Blob 
 
    var a = document.createElement('a'); 
 
    a.href = url; 
 
    a.innerHTML = 'download'; 
 
    a.download = 'myfile.webm'; 
 
    document.body.appendChild(a); 
 
    stream.getTracks().forEach(t => t.stop()); // never bad to close the stream when not needed anymore 
 
} 
 

 

 
function getCanvasStream() { 
 
    const canvas = document.createElement('canvas'); 
 
    const ctx = canvas.getContext('2d'); 
 
    ctx.fillStyle = 'red'; 
 
    // a simple animation to be recorded 
 
    let x = 0; 
 
    const anim = t => { 
 
    x = (x + 2) % 300; 
 
    ctx.clearRect(0, 0, 300, 150); 
 
    ctx.fillRect(x, 0, 10, 10); 
 
    requestAnimationFrame(anim); 
 
    } 
 
    anim(); 
 
    document.body.appendChild(canvas); 
 
    return canvas.captureStream(30); 
 
}

URL.createObjectURL(MediaStream)<video>要素のために使用しました。しかしこれはまた、BlobURLが現在の文書よりも長い存続期間を持つことができるため、ブラウザーが物理的な装置へのアクセスを閉じることを困難にしていました。
MediaStreamを使用してcreateObjectURLを呼び出すことは推奨されていません。代わりにMediaElement.srcObject = MediaStreamを使用する必要があります。

+0

ありがとうございます。あなたの最後の段落で表現された考え方を理解しています。私は自分自身で質問しました。この推奨(非推奨)メソッドを使用してデータURLを導出する方法を具体的に求めていました。チャンクとブロブのメソッドは、私が必要としたものです。 – Utkanos

関連する問題