Skip to content

High-resolution real-time spectrum analyzer and music player using Web Audio and Canvas APIs.

License

Notifications You must be signed in to change notification settings

wjlee-barco/audioMotion.js

 
 

Repository files navigation

header

GitHub release GitHub Release Date

♪♫ See your music with audioMotion! ♪♫

audioMotion.js is a high-resolution real-time audio spectrum analyzer and full-featured music player written in JavaScript.

The spectrum analyzer module is also available as a standalone project and a zero-dependency npm package you can use in your own JavaScript projects!

Features

  • High-resolution (retina / HiDPI ready) real-time audio spectrum analyzer
  • Fullscreen support at up to 60 frames per second
  • Logarithmic frequency scale with customizable range
  • Visualize discrete frequencies, or octave bands based on the equal tempered scale
  • Several color gradients with optional vintage LED effect
  • Customizable Web Audio API parameters (FFT size, sensitivity and time-smoothing)
  • HTML5 audio player for MP3, AAC (M4A), OGG and FLAC files (codec support may vary depending on browser and operating system)
  • Visual file explorer and play queue with drag-and-drop functionality
  • Support for M3U playlists (m3u and m3u8 file extensions)
  • Visualize audio from your microphone (or "stereo mix", if your soundcard supports it)
  • Lightweight custom file server — also works on standard web servers with minimal configuration
  • Client runs on any modern browser (tested with Firefox, Chrome and Safari)

Online demo

➡️ https://hvianna.github.io/audioMotion.js/public/

The demo allows you to play audio files from your PC, load songs and streams from a remote URL and use the microphone input. The file explorer is not available in the demo, since there are no media files hosted on that server.

Quick start

Download the latest version from the releases page. Portable binaries are available for Windows, Linux and macOS.

Launch audioMotion and you'll be asked for the path to your music folder. Only files under that folder will be accessible to the player.

You can also use the command line argument -m to set the music folder when launching audioMotion:

audioMotion -m c:\users\john\music

This will start the server and should also launch the client in your browser.

The complete command line options are:

-m <path> : path to music directory
-p <port> : change server listening port (default is 8000)
-s        : start server only (do not launch client)
-e        : allow external connections (by default, only localhost)

Documentation

For complete documentation, see the docs folder.

Screenshots

Discrete frequencies mode. User interface showing the file explorer and play queue. screenshot1

1/12th-octave bands mode with LED effect and on-screen song information. User interface showing the settings panel. screenshot2

Full screen view: 1/6th-octave bands mode, 30Hz-16KHz, "Outrun" gradient, with complete on-screen information. screenshot3

Full screen view: Discrete frequencies mode, 20Hz-22KHz, frequency scale on, "Prism" gradient. screenshot4

Credits and acknowledgments

audioMotion was largely inspired by Soniq Viewer for iOS, by Yuji Koike.

JavaScript libraries

Some of audioMotion's great features are provided by these awesome open-source libraries:

Graphic resources

References

These online references were invaluable for the development and improvement of audioMotion:

License

audioMotion.js copyright (c) 2018-2019 Henrique Avila Vianna
Licensed under the GNU Affero General Public License, version 3 or later.

About

High-resolution real-time spectrum analyzer and music player using Web Audio and Canvas APIs.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • HTML 43.0%
  • JavaScript 36.3%
  • CSS 20.7%