Bucket Brigade Singing |
November 3rd, 2020 |
audio, bucket_brigade, singing, tech |
gsc268k1lu78lbvfbhphdr0cs4@group.calendar.google.com
. If
you run into any problems, please file
a bug.
Unfortunately it currently only works in the Blink-based browsers: Chrome, new Edge, Brave, Opera, etc. It depends on two new browser features that other browser engines are working on adding but haven't added yet.
When you first visit the page it will as permission to use your microphone:
If there is currently an event scheduled, it will tell you. Everything is honor system right now; please don't mess up anyone else's events.
It will ask some clarifying questions, and encourage you to use wired headphones. Wireless has inconsistent latency, and the system is dependent on latency staying absolutely constant, while when you don't use headphones feedback (though not the squealy kind) can be a problem.
It asks you for your name; this is honor system as well. No accounts yet:
It also asks you to choose your input device. Typically starting with the default is a good approach, and then only coming back here if there's a problem.
In order to perfectly line up everybody's voice with everyone else, it needs to know how much time there is from (a) when it asks the browser to send audio out to your speakers or headphones until (b) when it receives audio back in from your microphone. The time from (a) to (b) depends on your audio hardware, your computer, and isn't even always consistent if you refresh the page. Worse, we can't just ask the browser how long this latency is, all we can do is measure it. We send a series of beeps out the speaker/headphones and time how long it takes until they come back in the microphone.
There's also the problem that not everyone has a setup where their computer will detect them as singing at the same volume. Some people have a microphone right up by their face, other people have one several feet away. In a video call it typically sets your volume automatically, but if we use that algorithm, built into the browser, it will do things like slowly turn your volume down as you hold a long loud note. Instead, we ask everyone to sing a little bit so we can set a level for them.
Once you're fully calibrated, you can see who else is on the system and choose to lead a song or sing along. There's also a rudimentary chat system so you can coordinate with others.
Glenn, Taymon, and I have worked hard on this, and feedback is most welcome! It's also open source, if you'd like to look at the code.
Comment via: facebook, hacker news