This is an old revision of the document!
jsfxr: synthesizing sounds in the browser
Sfxr, programmed by Tomas Pettersson, and ported to JavaScript by Eric Fredricksen. Forked and improved by Chris McCormick
First point: make sure that you select 44k and 16 bit in the column on the right for maximum sound quality (unless you are deliberately going for the old-school vibe).
The concept is to pass the output of a basic oscillator through an envelope and a few effects to generate a sound.
Parameters and functions provided in jsfxr:
- Base waveform
- Envelope
- Frequency
- Vibrato
- Arpeggiation (second pitch)
- Duty cycle
- Retrigger
- Flanger
- Low-pass filter
- High-pass filter
- serialize/deserialize (get settings as text, load settings from text)
- Buttons (mutate, random, etc.)
Generator column (on the left)
The random button randomizes all of the parameter settings, likely creating a totally new sound.
This column contains buttons for presets, which load parameter settings for sounds that correspond to the labels. After loading them, you can adjust the parameters to customize the sound.
The mutate button slightly changes all of the parameter settings, creating a variation of the previous settings.
base waveform
The base waveform at the top of the interface describes what initial oscillator will be used. This decides the original characteristic of the sound.
- square
- sawtooth
- sine
- noise
Envelope
We've discussed envelope here. This envelope control doesn't have a “release” parameter, but it has an extra “sustain punch” parameter.
Frequency
There are four frequency parameters:
- start frequency
- min freq. cutoff
- slide
- delta slide
vibrato
Vibrato has two parameters:
- depth
- speed
arpeggiation
Arpeggiation has two parameters:
- frequency mult
- change speed
duty cycle
Duty cycle has two parameters:
- duty cycle as a percentage
- sweep as a percentage per second
Retrigger
Retrigger has only one parameter:
- rate
flanger
Flanger has two parameters:
- offset
- sweetp
low-pass filter
The low-pass filter has three parameters:
- cutoff frequency
- cutoff sweep
- resonance
high-pass filter
The high-pass filter has two parameters:
- cutoff frequency
- cutoff sweep