Your Web News in One Place

Help Webnuz

Referal links:

Sign up for GreenGeeks web hosting
October 21, 2021 03:00 pm GMT

Lets create a screen recorder with JS

OBS studio is cool but lets create our very own screen recorder using JavaScript.
And guess what? Its not limited to just recording the browser screen. Yes, you've read that right. Although JavaScript runs on browser, we can use JS to record not only the active tab but any tab or entire screen. So lets get started.
First thing we'd need is a HTML file, in that we will have a record button and a video element where we can play the recorded video.

<!DOCTYPE html><html>  <head>    <title>Parcel Sandbox</title>    <meta charset="UTF-8" />  </head>  <body>    <video class="video" width="600px" controls></video>    <button class="record-btn">record</button>    <script src="./index.js"></script>  </body></html>

And we'd also need a JS file so lets create the index.js also

let btn = document.querySelector(".record-btn");btn.addEventListener("click", function () {  console.log("hello");});

So now if we open it the browser and click on the button we should see hello in console.

Alright now instead of console.log lets get the stream of users display

let btn = document.querySelector(".record-btn");btn.addEventListener("click", async function () {  let stream = await navigator.mediaDevices.getDisplayMedia({    video: true  });});

So now if you click on the button you'll see this popup.
screen record popup

Now you might think we are done select a window or screen and click share and it should start recording. But its a bit more complicated than that. We have to record the video our self. We are going to use MediaRecorder to record our video.

let btn = document.querySelector(".record-btn")btn.addEventListener("click", async function () {  let stream = await navigator.mediaDevices.getDisplayMedia({    video: true  })  //needed for better browser support  const mime = MediaRecorder.isTypeSupported("video/webm; codecs=vp9")              ? "video/webm; codecs=vp9"              : "video/webm"    let mediaRecorder = new MediaRecorder(stream, {        mimeType: mime    })    //we have to start the recorder manually    mediaRecorder.start()})

So as our screen get recorded mediaRecorder will give us data in chunks we need to store those data in a variable.

let btn = document.querySelector(".record-btn")btn.addEventListener("click", async function () {  let stream = await navigator.mediaDevices.getDisplayMedia({    video: true  })  //needed for better browser support  const mime = MediaRecorder.isTypeSupported("video/webm; codecs=vp9")              ? "video/webm; codecs=vp9"              : "video/webm"    let mediaRecorder = new MediaRecorder(stream, {        mimeType: mime    })    let chunks = []    mediaRecorder.addEventListener('dataavailable', function(e) {        chunks.push(e.data)    })    //we have to start the recorder manually    mediaRecorder.start()})

And now when we click on the stop sharing button we want the recorded video to be played in our video element so lets do that.

let btn = document.querySelector(".record-btn")btn.addEventListener("click", async function () {  let stream = await navigator.mediaDevices.getDisplayMedia({    video: true  })  //needed for better browser support  const mime = MediaRecorder.isTypeSupported("video/webm; codecs=vp9")              ? "video/webm; codecs=vp9"              : "video/webm"    let mediaRecorder = new MediaRecorder(stream, {        mimeType: mime    })    let chunks = []    mediaRecorder.addEventListener('dataavailable', function(e) {        chunks.push(e.data)    })    mediaRecorder.addEventListener('stop', function(){      let blob = new Blob(chunks, {          type: chunks[0].type      })      let video = document.querySelector(".video")      video.src = URL.createObjectURL(blob)  })    //we have to start the recorder manually    mediaRecorder.start()})

Now as a finishing touch lets automatically download the recorded video.

let btn = document.querySelector(".record-btn")btn.addEventListener("click", async function () {  let stream = await navigator.mediaDevices.getDisplayMedia({    video: true  })  //needed for better browser support  const mime = MediaRecorder.isTypeSupported("video/webm; codecs=vp9")              ? "video/webm; codecs=vp9"              : "video/webm"    let mediaRecorder = new MediaRecorder(stream, {        mimeType: mime    })    let chunks = []    mediaRecorder.addEventListener('dataavailable', function(e) {        chunks.push(e.data)    })    mediaRecorder.addEventListener('stop', function(){      let blob = new Blob(chunks, {          type: chunks[0].type      })      let url = URL.createObjectURL(blob)      let video = document.querySelector("video")      video.src = url      let a = document.createElement('a')      a.href = url      a.download = 'video.webm'      a.click()  })    //we have to start the recorder manually    mediaRecorder.start()})

And there now we have a fully functional screen recorder app.

Make sure to read my other articles.

.ltag__user__id__728097 .follow-action-button { background-color: #000000 !important; color: #ffffff !important; border-color: #000000 !important; }
0shuvo0 image

Original Link: https://dev.to/0shuvo0/lets-create-a-screen-recorder-with-js-3leb

Share this article:    Share on Facebook
View Full Article

Dev To

An online community for sharing and discovering great ideas, having debates, and making friends

More About this Source Visit Dev To