Skip to content

Instantly share code, notes, and snippets.

@fakenickels
Created November 13, 2021 18:16
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save fakenickels/41fd6d161402519e8660daae33f759a1 to your computer and use it in GitHub Desktop.
Save fakenickels/41fd6d161402519e8660daae33f759a1 to your computer and use it in GitHub Desktop.
<html>
<body>
<style>
#canvas {
border: 1px solid black;
background-color: white;
}
</style>
<script src="https://cdnjs.cloudflare.com/ajax/libs/RecordRTC/5.5.6/RecordRTC.js"></script>
<p>Paste your SVG base64 or source here</p>
<p>
<textarea rows="30" id="svg" cols="100"></textarea>
</p>
<p>
<button id="record" type="button">Record</button>
<button id="stop" disabled=true type="button">Stop recording</button>
</p>
<p>Preview:</p>
<p>
<canvas width="1012" height="506" id="canvas"></canvas>
</p>
<image
id="input"
style="opacity: 0"
src=""
/>
<script type="text/javascript">
var textarea = document.getElementById('svg');
var img = document.getElementById('input');
textarea.addEventListener('change', () => {
img.src = "data:image/svg+xml;base64," + textarea.value;
})
</script>
<script type="text/javascript">
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
var img = document.getElementById("input");
var data = [],
stream = canvas.captureStream(),
recorder = new MediaRecorder(stream, { mimeType: "video/webm" });
var height;
var width;
recorder.ondataavailable = function (event) {
if (event.data && event.data.size) {
data.push(event.data);
}
};
img.onload = () => {
width = canvas.width = img.width;
height = canvas.height = img.height;
}
function download() {
var blob = new Blob(data, {
type: "video/webm",
});
var url = URL.createObjectURL(blob);
var a = document.createElement("a");
document.body.appendChild(a);
a.style = "display: none";
a.href = url;
a.download = "test.webm";
a.click();
window.URL.revokeObjectURL(url);
}
var isRecording = false;
var timerId;
function loop() {
if (isRecording) {
// fills the background with white
recorder.requestData();
ctx.clearRect(0, 0, canvas.width, canvas.height);
ctx.fillStyle = "white";
ctx.fillRect(0, 0, height, width);
ctx.drawImage(img, 0, 0);
}
requestAnimationFrame(loop);
}
// fills the background with white
ctx.fillStyle = "white";
ctx.fillRect(0, 0, height, width);
ctx.drawImage(img, 0, 0);
loop()
var recordButton = document.getElementById("record");
var stopButton = document.getElementById("stop");
recordButton.addEventListener("click", function () {
isRecording = true;
recordButton.setAttribute("disabled", "disabled");
stopButton.removeAttribute("disabled");
recorder.start();
});
stopButton.addEventListener("click", function () {
isRecording = false;
recorder.stop();
download();
recordButton.removeAttribute("disabled");
stopButton.setAttribute("disabled", "disabled");
});
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment