Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
jsfxr [2023/12/04 07:30] – renick | jsfxr [2024/08/04 21:38] (current) – renick | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== jsfxr: synthesizing sounds in the browser ====== | ====== jsfxr: synthesizing sounds in the browser ====== | ||
- | https:// | + | Access this browser-based synthesizer here: https:// |
- | Sfxr, programmed by [[http:// | + | Sfxr was programmed by [[http:// |
- | 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). | + | <color #ed1c24>First point: make sure that you select 44k and 16 bit in the column on the right for maximum sound quality</ |
- | Second point: this synthesizer doesn' | + | <color #ed1c24>Second point: this synthesizer doesn' |
The concept is to pass the output of a basic oscillator through an envelope and a few effects to generate a sound. Every time you change a parameter, the sound will be played so that you can audition it. | The concept is to pass the output of a basic oscillator through an envelope and a few effects to generate a sound. Every time you change a parameter, the sound will be played so that you can audition it. | ||
Line 36: | Line 36: | ||
This section of the interface allows you to really customize the sound and control the parameters of synthesis. | This section of the interface allows you to really customize the sound and control the parameters of synthesis. | ||
+ | |||
+ | ===== serialize/ | ||
+ | |||
+ | Use these to get the settings as text. Once they are there, you can modify them. This is good if you want to put in a specific value. Then you can load settings from text using the deserialize button. One way to use this is to make a sound, serialize it, and send it to your friend. Then your friend can paste it in and deserialize it to get the same sound as you. In this way, you can work on the same sound or variations together with a friend remotely. | ||
===== base waveform ===== | ===== base waveform ===== | ||
Line 41: | Line 45: | ||
The base waveform at the top of the interface describes what initial oscillator will be used. This decides the original characteristic of the sound. | 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 | + | - square |
- | - sawtooth | + | - sawtooth |
- | - sine | + | - sine https:// |
- | - noise | + | - noise https:// |
===== Envelope ===== | ===== Envelope ===== | ||
- | We've discussed envelope here. This envelope control doesn' | + | [[envelopes|We've discussed envelope here]]. This envelope control doesn' |
===== Frequency ===== | ===== Frequency ===== | ||
Line 60: | Line 64: | ||
===== vibrato ===== | ===== vibrato ===== | ||
- | Vibrato has two parameters: | + | Vibrato is a kind of wobble to the frequency. https:// |
+ | |||
+ | Vibrato has two parameters, and you'll need to raise both to hear this effect: | ||
- depth | - depth | ||
- speed | - speed | ||
===== arpeggiation ===== | ===== arpeggiation ===== | ||
+ | |||
+ | Arpeggiation repeats the sound at a new frequency, delayed in time. Most musical arpeggiators will repeat many times, but this one only adds one repeat. | ||
Arpeggiation has two parameters: | Arpeggiation has two parameters: | ||
Line 72: | Line 80: | ||
===== duty cycle ===== | ===== duty cycle ===== | ||
- | [[https:// | + | [[https:// |
- duty cycle as a percentage; you may feel that the higher the percentage, the " | - duty cycle as a percentage; you may feel that the higher the percentage, the " | ||
- sweep as a percentage per second; the same seems to be true here: the higher the percentage, the fatter the sound. the lower the percentage, the more high-end details emerge. | - sweep as a percentage per second; the same seems to be true here: the higher the percentage, the fatter the sound. the lower the percentage, the more high-end details emerge. | ||
Line 91: | Line 99: | ||
===== low-pass filter ===== | ===== low-pass filter ===== | ||
- | The low-pass filter, discussed over here, has three parameters: | + | A low-pass filter cuts high frequencies. |
- cutoff frequency: sounds below this frequency are preserved; sounds above it are reduced | - cutoff frequency: sounds below this frequency are preserved; sounds above it are reduced | ||
- cutoff sweep: creates an envelope on the cutoff frequency, reducing it over time. The time specified is how long it takes the cutoff frequency to fall to its minimum value. Keep in mind the amplitude envelope; long values here may not be audible if the amplitude envelope is short. | - cutoff sweep: creates an envelope on the cutoff frequency, reducing it over time. The time specified is how long it takes the cutoff frequency to fall to its minimum value. Keep in mind the amplitude envelope; long values here may not be audible if the amplitude envelope is short. | ||
Line 98: | Line 106: | ||
===== high-pass filter ===== | ===== high-pass filter ===== | ||
- | The high-pass filter has two parameters: | + | A high-pass filter cuts low frequencies. |
- cutoff frequency: sounds above this frequency are preserved; sounds below it are reduced | - cutoff frequency: sounds above this frequency are preserved; sounds below it are reduced | ||
- cutoff sweep: creates an envelope on the cutoff frequency, reducing it over time. The time specified is how long it takes the cutoff frequency to fall to its minimum value. Keep in mind the amplitude envelope; long values here may not be audible if the amplitude envelope is short. | - cutoff sweep: creates an envelope on the cutoff frequency, reducing it over time. The time specified is how long it takes the cutoff frequency to fall to its minimum value. Keep in mind the amplitude envelope; long values here may not be audible if the amplitude envelope is short. | ||