Hark is a tiny browser/commonJS module that listens to an audio stream, and emits events indicating whether the user is speaking or not.
npm install hark
Without browserify download and use:
npm install hark
If you aren't using browserify, you'll want hark.bundle.js.
var hark =var getUserMedia =;
Hark uses the webaudio API to FFT (get the power of) the audio in the audio stream. If the power is above a threshold, it's determined to be speech.
var speech = ;speech;
speakingemitted when the stream appears to be speaking
stopped_speakingemitted when the audio doesn't seem to be speaking
volume_changeemitted on every poll event by the event emitter with the current volume (in decibels) and the current threshold for speech
setThreshold(threshold_in_db)change the minimum volume at which the audio will emit a
stop()will stop the polling and events will not be emitted.
interval(optional, default 100ms) how frequently the analyser polls the audio stream to check if speaking has started or stopped. This will also be the frequency of the
threshold(optional, default -50db) the volume at which
stopped\_speakingevents will be fired
play(optional, default true for audio tags, false for webrtc streams) whether the audio stream should also be piped to the speakers, or just swallowed by the analyser. Typically for audio tags you would want to hear them, but for microphone based webrtc streams you may not to avoid feedback.
Fine tuning the volume threshold is the main configuration setting for how this module will behave. The level of -50db have been chosen based on some basic experimentation on mysetup, but you may wish to change them (and should if it improves your app).
What is dB? Decibels are how sound is measured. The loudest sounds on your system will be at 0dB, and silence in webaudio is -100dB. Speech seems to be above -50dB depending on the volume and type of source. If speaking events are being fired too frequently, you would make this number higher (i.e. towards 0). If they are not firing frequently enough (you are speaking loudly but no events are firing), make the number closer to -100dB).
Clone and open example/index.html or view it online