Metode captureStream()
memungkinkan
pengambilan MediaStream
dari elemen <canvas>
,
<audio>
, atau <video>
.
Hal ini memungkinkan streaming video atau audio dari salah satu elemen ini direkam,
di-live stream melalui WebRTC, atau digabungkan dengan efek atau MediaStream
lainnya dalam
<canvas>
. Dengan kata lain, captureStream()
memungkinkan MediaStream
meneruskan
media bolak-balik antara elemen kanvas, audio, atau video — atau ke
RTCPeerConnection
atau MediaRecorder
.
Dalam demo berikut (tersedia dari
contoh WebRTC),
MediaStream
yang diambil dari elemen kanvas di sebelah kiri di-streaming melalui
koneksi peer WebRTC ke elemen video di sebelah kanan:
(Ada link ke contoh kanvas dan video lainnya di bawah.)
Kode captureStream()
sederhana.
Untuk <canvas>
:
var canvas = document.querySelector('canvas');
var video = document.querySelector('video');
// Optional frames per second argument.
var stream = canvas.captureStream(25);
// Set the source of the <video> element to be the stream from the <canvas>.
video.srcObject = stream;
Untuk <video>
:
var leftVideo = document.getElementById('leftVideo');
var rightVideo = document.getElementById('rightVideo');
leftVideo.onplay = function() {
// Set the source of one <video> element to be a stream from another.
var stream = leftVideo.captureStream();
rightVideo.srcObject = stream;
};
Namun, mengapa?
Metode captureStream()
memungkinkan Anda
merekam atau
melakukan live stream dari kanvas
dan elemen media:
- Merekam dan melakukan streaming gameplay dari
<canvas>
- Merekam video dari kamera, lalu menambahkan konten atau efek tambahan
- Membuat efek picture-in-picture dari beberapa video melalui
<canvas>
- Menggabungkan video dan gambar (dari file atau kamera atau keduanya) dalam
<canvas>
- Live streaming video yang diputar dari file
- Menggunakan pesan audio atau video yang direkam untuk pesan suara atau video
Pada dasarnya, captureStream()
memungkinkan JavaScript membuat dan "memasukkan
hal" ke dalam
MediaStream.
Detail lainnya
Mencoba menggunakan
captureStream()
dengan elemen media yang menerapkan perlindungan konten melalui Ekstensi Media Terenkripsi akan menampilkan pengecualian.Saat mengambil gambar dari
<canvas>
, kecepatan frame maksimum ditetapkan saatcaptureStream()
dipanggil. Misalnya,canvas.captureStream(10)
berarti output kanvas antara 0 dan 10 fps. Tidak ada yang direkam jika tidak ada yang digambar di<canvas>
, dan 10 fps direkam meskipun<canvas>
digambar pada 30 fps. Ada bug dengan diskusi lebih lanjut yang diajukan pada spesifikasicaptureStream
.Dimensi video
captureStream()
cocok dengan<canvas>
tempatnya dipanggil.
Demo
Kanvas
Video
Dukungan
- Canvas
captureStream()
: Firefox 43 atau yang lebih baru; Chrome 50 dan yang lebih baru dengan chrome://flags/#enable-experimental-web-platform-features diaktifkan, atau Chrome 52 dan yang lebih baru secara default. - Video dan audio
captureStream()
: Firefox 47; Chrome 52 dan yang lebih baru dengan chrome://flags/#enable-experimental-web-platform-features diaktifkan, atau Chrome 53 dan yang lebih baru secara default.