Skip to content

Instantly share code, notes, and snippets.

@jacksonfdam
Created May 16, 2022 09:05
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 jacksonfdam/d372ba6937c2e7c83969b7515fc735ee to your computer and use it in GitHub Desktop.
Save jacksonfdam/d372ba6937c2e7c83969b7515fc735ee to your computer and use it in GitHub Desktop.
Web RTC - Sound and Microphone Check
<main class="has-background-dark">
<div class="is-family-sans-serif has-text-white has-text-centered">
<h1 class="is-size-1 has-text-centered is-uppercase has-text-weight-bold">Sound check!</h1>
<p class="">See if your microphone and headphones are setup properly</p>
<p> For the Microphone test, a prompt will appear asking for permission to access your select output device </p>
<p>If you are not using headphones, it'll have a loop feedback</p>
<p></p>
<button class="button is-primary is-fullwidth is-large" id="micTest" type="button">Test Microphone</button>
<button class="button is-link is-light is-fullwidth is-medium" id="soundTest" type="button">Test Headphone/Speakers</button>
</div>
</main>
// Based On https://github.com/webrtc/samples/tree/gh-pages/src/content/getusermedia/audio
function handleSuccess(stream) {
if (window.stream) {
window.stream.getAudioTracks().forEach(track => track.stop());
window.stream = null;
} else {
const audio = document.createElement('audio');
audio.controls = true;
audio.autoplay = true;
window.stream = stream;
audio.srcObject = stream;
stream.oninactive = function() {
console.log('Stream ended');
};
}
}
function handleError(e){
console.log("ruin", e.message);
}
document.querySelector("#micTest").addEventListener('click', function(){
if ( window.stream ) {
this.innerText = "Test Microphone";
} else {
this.innerText = "Stop Test";
}
if (navigator.mediaDevices) {
const constraints = window.constraints = {
audio: true,
video: false
}
navigator.mediaDevices.getUserMedia(constraints).then(handleSuccess).catch(handleError)
}
});
document.querySelector('#soundTest').addEventListener('click', function(){
const audio = document.createElement('audio');
audio.controls = true;
audio.autoplay = true;
audio.src = 'https://teste-sdk-rs.s3.amazonaws.com/Purr.wav';
})
// Nothing here is related with the bare bone of the project
#micTest::before {
content: '';
background-image: url("");
background-size: contain;
display: block;
width: 20px;
height: 20px;
}
#soundTest::before {
content: '';
background-image: url("");
background-size: contain;
display: block;
width: 20px;
height: 20px;
}
main {
display: flex;
height: 100vh;
width: 100vw;
align-items: center;
justify-content: center;
div {
display: flex;
flex-direction: column;
justify-content: space-between;
min-height: 300px;
}
}
<link href="https://cdnjs.cloudflare.com/ajax/libs/bulma/0.8.1/css/bulma.min.css" rel="stylesheet" />

Web RTC - Sound and Microphone Check

An example usage of the Web RTC API for testing the output device of the client's pc.

A Pen by Rhamses on CodePen.

License.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment