Skip to content

Latest commit

 

History

History
78 lines (55 loc) · 2.78 KB

README.md

File metadata and controls

78 lines (55 loc) · 2.78 KB

bc-010

Netlify Status

A browser based synthesizer. 🎹 🔉

What is this?

This is an audio synthesizer to be used right in your own web browser. You can play the computer keyboard to sound the notes or click them in with the mouse. The tone of the synth can be changed by clicking and dragging the sliders in the control panel.

Screenshot:

Screenshot of synth

How to Use:

  • Open a Chrome web browser (so far, only Chrome supports all features of Web MIDI / Web Audio)
  • Go to the URL for the app/synth: https://frosty-swanson-669b64.netlify.com/
  • Click on a musical key to play the synth
    • You can also use the "musical typing" feature of the computer keyboard to play notes
  • Click and drag the sliders to adjust the tone
  • Change the waveform of the synth between the 4 shown in the control panel (sine, square, triangle, sawtooth)
  • Adjust the octave of the keyboard by toggling the plus and minus buttons in the octave section

How to install and Run: 🏃

  • git clone the repo
  • Run npm install to get all dependencies
  • cd into bc-010
  • Run npm start
  • Go to localhost:3000 in your web browser

How to type check with Flow 🔍 📋

  • cd into the root of the repo
  • Run npm install --save-dev flow-bin
    • This command installs Flow as a Dev Dependency
  • While in the root of the repo, run npm run flow
  • Any errors will be logged to the console
    • If there aren't any errors, it will display as well

Documentation 📑

How To Run Documentation Server:

  • Make sure React Styleguidist is installed. (It should have been installed as a devDependency).
  • Then in the root directory of the project, run npx styleguidist server
  • View the documenatation in your web browser at http://localhost:6060/

Setting up AutoFix on save with VSCode 👔

Having Prettier/Eslint autofix errors is very handy for development. This repo is all set up to autofix errors. If you're using VSCode, make sure these settings below are in your workspace settings (below are the json version):

{
  "editor.formatOnSave": true,
  "eslint.autoFixOnSave": true,
}

Built with:

Future Features:

  • Ability to login and save presets
  • Add MIDI keyboard recognition
  • Fully adjustable portamento