[Daniel] stumbled on an interesting paper (which we featured before) on Doppler gesture sensing using only a computer’s speaker and microphone. Unfortunately the paper didn’t include source code so [Daniel] created his own implementation of Doppler gesture sensing in JavaScript that works right in the browser.
[Daniel]’s JavaScript library generates a sine wave at 20 kHz that’s played through the computer’s speakers. The frequency is high enough that it’s pretty much inaudible. While the tone is being played through the speakers, the computer’s microphone is used to sample the audio and calculate the frequency spectrum of the signal. As you move your hand closer to the computer while the tone is playing, the frequency of the received signal shifts higher; as you move your hand away, it shifts lower. [Daniel]’s script looks for this frequency shift and uses it to trigger events.
[Daniel] has some awesome examples included on his website where you can test out the functionality for yourself. He has a hands-free scrolling example, spectrum plot, and even a virtual theremin. Since his code is bundled up into an easy-to-use library, it should be fairly easy to integrate into any webpage. The only real limitation to the library is that it only works in Chrome right now (Firefox doesn’t support disabling echo cancellation).
Sweet. Reminds me a lot of the Doppler audio demo that ran on the NeXT cube to show off its DSP, in 1989 or so. It used lower frequency and would show people walking around the room. It was just a demo though, IIRC, not a UI method.
Very smart. Works like a charm!
Wow, I tried the page scrolling demo and although it’s a bit jumpy, it actually works really well. Very impressive!
Hmm, since you can enable your camera in-browser, what about making the gestures controlled via hand gestures w/out mic.
Never mind, it probably needs to be processed on a server (latency issues) or is going to eat up a lot of resources.
No, it doesn’t need to be processed on a server: http://trackingjs.com/
Really neat!
However from the summary: “He has a hands-free scrolling example”
Umm, isn’t he using his hands to do the scrolling? :-P
I suppose he could use his face, but that would just look silly.
https://www.youtube.com/watch?v=kkNxbyp6thM
lol I didn’t catch that when I read it. good find :)
Hmm so now my browser can tell if I’m sitting in front of the screen.. It just needs to wait till I go for a coffee and it’ll be up to all sorts. /me adjusts tinfoil hat.
Oh yeah, that’s a lot more convenient than using a mouse.
Wow, right under my nose and I never saw it. Thanks for this Ethan.
Careful with this, opened it up on an old dell and smoked the internal speakers
Wow, very nice demo project. Really educational. Thanks for sharing
My dog did not enjoy this.
Must be April 1st because I just spent 10 minutes waving my had in front of the laptop like a crazy person to no effect.
Hope cam was not secretly activated and footage uploaded to youtube.
Your browser requires you to allow the camera/microphone to be turned on. So unless you clicked to allow the camera, it won’t have been turned on. Although I personally have a piece of tape over my camera just in case.
I tested the demo and it works fine. Did you scroll down the page to actually activate the demo? Did you allow the page to use your microphone? Did you turn up your speakers?
Using two discrete tones on left and right speakers while using two microphones on seperate channels arrayed perpendicular to the center line of the speakers would allow for some 3D gesture mapping.