Spectro

screenshot of Spectro
react
material-ui

Real-time audio spectrogram generator for the web

Overview:

Spectro is a real-time audio spectrogram generator for the web. It allows users to visualize sound from their microphone or audio files on their device. The generated spectrogram represents the frequencies present in sound over time, with time represented along the horizontal axis and frequency along the vertical axis. Users can customize the appearance of the spectrogram using various options such as sensitivity, contrast, zoom, frequency range, frequency scale, and color scheme. Spectro works on the latest versions of Chrome, Firefox, Safari, and other Chromium-based browsers.

Features:

  • Real-time audio spectrogram: Spectro allows users to generate a spectrogram in real-time from their microphone or audio files.
  • Customizable appearance: Users can control the sensitivity, contrast, zoom, frequency range, frequency scale, and color scheme of the spectrogram to suit their preferences.
  • Support for various audio formats: Spectro supports any audio format that is supported by the user's browser.
  • Record from microphone: Users can start generating a spectrogram by clicking the "Record from mic" button.
  • Record audio from device's audio output: Users can enable 'Stereo Mix' on Windows or use BlackHole on macOS to record audio from their device's audio output and then set it as the browser's default input device.
  • Play audio file: Users can generate a spectrogram from an audio file on their device by clicking the "Play audio file" button, which also plays the selected audio file.
  • Option to stop generating spectrogram: Users can click the "Stop" button to stop generating the spectrogram. When playing an audio file, the spectrogram will automatically stop at the end of the track.
react
React

React is a widely used JavaScript library for building user interfaces and single-page applications. It follows a component-based architecture and uses a virtual DOM to efficiently update and render UI components

material-ui
Material UI

material-ui adds classes to Tailwind CSS for all common UI components. Classes like btn, card, etc. This allows us to focus on important things instead of making basic elements for every project.

eslint
Eslint

ESLint is a linter for JavaScript that analyzes code to detect and report on potential problems and errors, as well as enforce consistent code style and best practices, helping developers to write cleaner, more maintainable code.

material-design
Material Design

Material Design is a design system developed by Google that provides a set of guidelines, components, and tools for creating visually appealing and functional user interfaces. Material Design is designed to be flexible and customizable, making it a great choice for a wide range of applications and use cases.

typescript
Typescript

TypeScript is a superset of JavaScript, providing optional static typing, classes, interfaces, and other features that help developers write more maintainable and scalable code. TypeScript's static typing system can catch errors at compile-time, making it easier to build and maintain large applications.

webpack
Webpack

Webpack is a popular open-source module bundler for JavaScript applications that bundles and optimizes the code and its dependencies for production-ready deployment. It can also be used to transform other types of assets such as CSS, images, and fonts.