@vikasietum_tecknology/record-rtc
Version:
record-rtc is a library based on recordrtc library. In this forked version of the original library we have optimized the memory management. The video recording is stored in IndexDB in chunks.
99 lines (76 loc) • 2.78 kB
HTML
<style>
html, body {
margin: 0;
padding: 0;
}
</style>
<title>destroy | RecordRTC</title>
<h1>destroy | RecordRTC</h1>
<br>
<button id="btn-start-recording">Start Recording</button>
<button id="btn-stop-recording" disabled>Stop Recording</button>
<button id="btn-destroy-recording" disabled>Destroy</button>
<hr>
<video controls autoplay playsinline></video>
<script src="/RecordRTC.js"></script>
<script>
var video = document.querySelector('video');
function captureCamera(callback) {
navigator.mediaDevices.getUserMedia({ audio: true, video: true }).then(function(camera) {
callback(camera);
}).catch(function(error) {
alert('Unable to capture your camera. Please check console logs.');
console.error(error);
});
}
function stopRecordingCallback() {
video.src = video.srcObject = null;
var blob = new File(blobs, 'video.webm', {
type: 'video/webm'
});
video.src = URL.createObjectURL(blob);
document.getElementById('btn-destroy-recording').click();
}
var recorder; // globally accessible
var h1 = document.querySelector('h1');
var blobs = [];
document.getElementById('btn-start-recording').onclick = function() {
this.disabled = true;
captureCamera(function(camera) {
video.srcObject = camera;
recorder = RecordRTC(camera, {
recorderType: MediaStreamRecorder,
mimeType: 'video/webm',
timeSlice: 1000, // pass this parameter
// getNativeBlob: true,
ondataavailable: function(blob) {
blobs.push(blob);
var size = 0;
blobs.forEach(function(b) {
size += b.size;
});
h1.innerHTML = 'Total blobs: ' + blobs.length + ' (Total size: ' + bytesToSize(size) + ')';
}
});
recorder.startRecording();
// release camera on stopRecording
recorder.camera = camera;
document.getElementById('btn-stop-recording').disabled = false;
document.getElementById('btn-destroy-recording').disabled = false;
});
};
document.getElementById('btn-stop-recording').onclick = function() {
this.disabled = true;
recorder.stopRecording(stopRecordingCallback);
};
document.getElementById('btn-destroy-recording').onclick = function() {
this.disabled = true;
recorder.destroy();
recorder.camera.stop();
recorder = null;
document.getElementById('btn-stop-recording').disabled = true;
document.getElementById('btn-start-recording').disabled = false;
};
</script>
<footer style="margin-top: 20px;"><small id="send-message"></small></footer>
<script src="https://www.webrtc-experiment.com/common.js"></script>