Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cwilso/metronome
Web Audio metronome example to show scheduling.
https://github.com/cwilso/metronome
Last synced: about 24 hours ago
JSON representation
Web Audio metronome example to show scheduling.
- Host: GitHub
- URL: https://github.com/cwilso/metronome
- Owner: cwilso
- License: mit
- Created: 2012-12-27T00:58:16.000Z (about 12 years ago)
- Default Branch: main
- Last Pushed: 2022-10-07T16:56:40.000Z (over 2 years ago)
- Last Synced: 2025-01-03T21:11:30.598Z (8 days ago)
- Language: JavaScript
- Homepage: https://cwilso.github.io/metronome/
- Size: 22.5 KB
- Stars: 587
- Watchers: 24
- Forks: 194
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-webaudio - Web Audio Metronome - metronome app that uses the Web Audio scheduler and setTimeout scheduler (Packages / Apps)
README
# Web Audio Metronome
This application shows how to use a collaboration between a setTimeout scheduler and the Web Audio scheduler to properly implement rock-solid timing for audio applications.
I added some code to this demo after writing the article on web audio scheduling that now resides at https://web.dev/audio-scheduling/.
This code was added because Chrome (and other browsers) made a power-saving change to throttle JS timers at one point, so if the page was not visible (e.g. a tab that you tabbed away from), it would only have setTimeout timers delivered once a second. Timers in worker threads were not throttled, so I set up a worker thread to ping the main thread (which does the audio scheduling).
Since that time, I believe the code I wrote is actually no longer necessary, because based on ANOTHER change audible audio should prevent the throttling, so for this application setTimeout on the main thread would work just fine. (Jake Archibald wrote an article in early 2021 outlining the current state of affairs at https://developer.chrome.com/blog/timer-throttling-in-chrome-88/.) I have not yet tested this assumption or removed the code yet, however.
Check it out, feel free to submit issues or requests, fork, submit pull requests, etc.
The live app is at https://cwilso.github.io/metronome/.
-Chris