mirror of
https://github.com/scratchfoundation/scratch-audio.git
synced 2025-01-10 06:41:56 -05:00
JSDoc comments
This commit is contained in:
parent
dcdc2c0831
commit
7483cbdb2f
7 changed files with 215 additions and 81 deletions
|
@ -1,17 +1,18 @@
|
||||||
/*
|
|
||||||
|
|
||||||
An echo effect
|
|
||||||
|
|
||||||
0 mutes the effect
|
|
||||||
Values up to 100 set the echo feedback amount,
|
|
||||||
increasing the time it takes the echo to fade away
|
|
||||||
|
|
||||||
Clamped 0-100
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tone = require('tone');
|
var Tone = require('tone');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @fileoverview
|
||||||
|
* An echo effect (aka 'delay effect' in audio terms)
|
||||||
|
* Effect value of 0 mutes the effect
|
||||||
|
* Values up to 100 set the echo feedback amount,
|
||||||
|
* increasing the time it takes the echo to fade away
|
||||||
|
* Clamped 0-100
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize and chain the effect
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
function EchoEffect () {
|
function EchoEffect () {
|
||||||
Tone.Effect.call(this);
|
Tone.Effect.call(this);
|
||||||
|
|
||||||
|
@ -24,6 +25,10 @@ function EchoEffect () {
|
||||||
|
|
||||||
Tone.extend(EchoEffect, Tone.Effect);
|
Tone.extend(EchoEffect, Tone.Effect);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the effect value
|
||||||
|
* @param {number} val - the new value to set the effect to
|
||||||
|
*/
|
||||||
EchoEffect.prototype.set = function (val) {
|
EchoEffect.prototype.set = function (val) {
|
||||||
this.value = val;
|
this.value = val;
|
||||||
|
|
||||||
|
@ -40,10 +45,20 @@ EchoEffect.prototype.set = function (val) {
|
||||||
this.delay.feedback.rampTo(feedback, 1/60);
|
this.delay.feedback.rampTo(feedback, 1/60);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the effect value
|
||||||
|
* @param {number} val - the value to change the effect by
|
||||||
|
*/
|
||||||
EchoEffect.prototype.changeBy = function (val) {
|
EchoEffect.prototype.changeBy = function (val) {
|
||||||
this.set(this.value + val);
|
this.set(this.value + val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clamp the input to a range
|
||||||
|
* @param {number} input - the input to clamp
|
||||||
|
* @param {number} min - the min value to clamp to
|
||||||
|
* @param {number} max - the max value to clamp to
|
||||||
|
*/
|
||||||
EchoEffect.prototype.clamp = function (input, min, max) {
|
EchoEffect.prototype.clamp = function (input, min, max) {
|
||||||
return Math.min(Math.max(input, min), max);
|
return Math.min(Math.max(input, min), max);
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
/*
|
|
||||||
|
|
||||||
A fuzz effect
|
|
||||||
|
|
||||||
Distortion
|
|
||||||
|
|
||||||
the value controls the wet/dry amount
|
|
||||||
|
|
||||||
Clamped 0-100
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tone = require('tone');
|
var Tone = require('tone');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @fileoverview
|
||||||
|
* An fuzz effect (aka 'distortion effect' in audio terms)
|
||||||
|
* Effect value controls the wet/dry amount:
|
||||||
|
* 0 passes through none of the effect, 100 passes through all effect
|
||||||
|
* Clamped 0-100
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize and chain the effect
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
function FuzzEffect () {
|
function FuzzEffect () {
|
||||||
Tone.Effect.call(this);
|
Tone.Effect.call(this);
|
||||||
|
|
||||||
|
@ -24,6 +24,10 @@ function FuzzEffect () {
|
||||||
|
|
||||||
Tone.extend(FuzzEffect, Tone.Effect);
|
Tone.extend(FuzzEffect, Tone.Effect);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the effect value
|
||||||
|
* @param {number} val - the new value to set the effect to
|
||||||
|
*/
|
||||||
FuzzEffect.prototype.set = function (val) {
|
FuzzEffect.prototype.set = function (val) {
|
||||||
this.value = val;
|
this.value = val;
|
||||||
|
|
||||||
|
@ -32,10 +36,19 @@ FuzzEffect.prototype.set = function (val) {
|
||||||
this.distortion.wet.value = this.value / 100;
|
this.distortion.wet.value = this.value / 100;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the effect value
|
||||||
|
* @param {number} val - the value to change the effect by
|
||||||
|
*/
|
||||||
FuzzEffect.prototype.changeBy = function (val) {
|
FuzzEffect.prototype.changeBy = function (val) {
|
||||||
this.set(this.value + val);
|
this.set(this.value + val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {number} input - the input to clamp
|
||||||
|
* @param {number} min - the min value to clamp to
|
||||||
|
* @param {number} max - the max value to clamp to
|
||||||
|
*/
|
||||||
FuzzEffect.prototype.clamp = function (input, min, max) {
|
FuzzEffect.prototype.clamp = function (input, min, max) {
|
||||||
return Math.min(Math.max(input, min), max);
|
return Math.min(Math.max(input, min), max);
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,15 +1,17 @@
|
||||||
/*
|
|
||||||
|
|
||||||
A Pan effect
|
|
||||||
|
|
||||||
-100 puts the audio on the left channel, 0 centers it, 100 puts it on the right.
|
|
||||||
|
|
||||||
Clamped -100 to 100
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tone = require('tone');
|
var Tone = require('tone');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @fileoverview
|
||||||
|
* An pan effect, which moves the sound to the left or right between the speakers
|
||||||
|
* Effect value of -100 puts the audio entirely on the left channel,
|
||||||
|
* 0 centers it, 100 puts it on the right.
|
||||||
|
* Clamped -100 to 100
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize and chain the effect
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
function PanEffect () {
|
function PanEffect () {
|
||||||
Tone.Effect.call(this);
|
Tone.Effect.call(this);
|
||||||
|
|
||||||
|
@ -22,6 +24,10 @@ function PanEffect () {
|
||||||
|
|
||||||
Tone.extend(PanEffect, Tone.Effect);
|
Tone.extend(PanEffect, Tone.Effect);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the effect value
|
||||||
|
* @param {number} val - the new value to set the effect to
|
||||||
|
*/
|
||||||
PanEffect.prototype.set = function (val) {
|
PanEffect.prototype.set = function (val) {
|
||||||
this.value = val;
|
this.value = val;
|
||||||
|
|
||||||
|
@ -30,10 +36,20 @@ PanEffect.prototype.set = function (val) {
|
||||||
this.panner.pan.value = this.value / 100;
|
this.panner.pan.value = this.value / 100;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the effect value
|
||||||
|
* @param {number} val - the value to change the effect by
|
||||||
|
*/
|
||||||
PanEffect.prototype.changeBy = function (val) {
|
PanEffect.prototype.changeBy = function (val) {
|
||||||
this.set(this.value + val);
|
this.set(this.value + val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clamp the input to a range
|
||||||
|
* @param {number} input - the input to clamp
|
||||||
|
* @param {number} min - the min value to clamp to
|
||||||
|
* @param {number} max - the max value to clamp to
|
||||||
|
*/
|
||||||
PanEffect.prototype.clamp = function (input, min, max) {
|
PanEffect.prototype.clamp = function (input, min, max) {
|
||||||
return Math.min(Math.max(input, min), max);
|
return Math.min(Math.max(input, min), max);
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,36 +1,78 @@
|
||||||
/*
|
|
||||||
|
|
||||||
A Pitch effect
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tone = require('tone');
|
var Tone = require('tone');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @fileoverview
|
||||||
|
* An pitch change effect, which changes the playback rate of the sound in order
|
||||||
|
* to change its pitch: reducing the playback rate lowers the pitch, increasing the rate
|
||||||
|
* raises the pitch. The duration of the sound is also changed.
|
||||||
|
*
|
||||||
|
* Changing the value of the pitch effect by 10 causes a change in pitch by 1 semitone
|
||||||
|
* (i.e. a musical half-step, such as the difference between C and C#)
|
||||||
|
* Changing the pitch effect by 120 changes the pitch by one octave (12 semitones)
|
||||||
|
*
|
||||||
|
* The value of this effect is not clamped (i.e. it is typically between -120 and 120,
|
||||||
|
* but can be set much higher or much lower, with weird and fun results).
|
||||||
|
* We should consider what extreme values to use for clamping it.
|
||||||
|
*
|
||||||
|
* Note that this effect functions differently from the other audio effects. It is
|
||||||
|
* not part of a chain of audio nodes. Instead, it provides a way to set the playback
|
||||||
|
* on one SoundPlayer or a group of them.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the effect
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
function PitchEffect () {
|
function PitchEffect () {
|
||||||
this.value = 0;
|
this.value = 0; // effect value
|
||||||
this.ratio = 1;
|
this.ratio = 1; // the playback rate ratio
|
||||||
|
|
||||||
this.tone = new Tone();
|
this.tone = new Tone();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the effect value
|
||||||
|
* @param {number} val - the new value to set the effect to
|
||||||
|
* @param {object} players - a dictionary of SoundPlayer objects to apply the effect to, indexed by md5
|
||||||
|
*/
|
||||||
PitchEffect.prototype.set = function (val, players) {
|
PitchEffect.prototype.set = function (val, players) {
|
||||||
this.value = val;
|
this.value = val;
|
||||||
this.ratio = this.getRatio(this.value);
|
this.ratio = this.getRatio(this.value);
|
||||||
this.updatePlayers(players);
|
this.updatePlayers(players);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the effect value
|
||||||
|
* @param {number} val - the value to change the effect by
|
||||||
|
* @param {Object} players - a dictionary of SoundPlayer objects indexed by md5
|
||||||
|
*/
|
||||||
PitchEffect.prototype.changeBy = function (val, players) {
|
PitchEffect.prototype.changeBy = function (val, players) {
|
||||||
this.set(this.value + val, players);
|
this.set(this.value + val, players);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Compute the playback ratio for an effect value.
|
||||||
|
* The playback ratio is scaled so that a change of 10 in the effect value
|
||||||
|
* gives a change of 1 semitone in the ratio.
|
||||||
|
* @param {number} val - an effect value
|
||||||
|
* @returns {number} a playback ratio
|
||||||
|
*/
|
||||||
PitchEffect.prototype.getRatio = function (val) {
|
PitchEffect.prototype.getRatio = function (val) {
|
||||||
return this.tone.intervalToFrequencyRatio(val / 10);
|
return this.tone.intervalToFrequencyRatio(val / 10);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update a sound player's playback rate using the current ratio for the effect
|
||||||
|
* @param {Object} player - a SoundPlayer object
|
||||||
|
*/
|
||||||
PitchEffect.prototype.updatePlayer = function (player) {
|
PitchEffect.prototype.updatePlayer = function (player) {
|
||||||
player.setPlaybackRate(this.ratio);
|
player.setPlaybackRate(this.ratio);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update a sound player's playback rate using the current ratio for the effect
|
||||||
|
* @param {object} players - a dictionary of SoundPlayer objects to update, indexed by md5
|
||||||
|
*/
|
||||||
PitchEffect.prototype.updatePlayers = function (players) {
|
PitchEffect.prototype.updatePlayers = function (players) {
|
||||||
if (!players) return;
|
if (!players) return;
|
||||||
|
|
||||||
|
@ -39,7 +81,5 @@ PitchEffect.prototype.updatePlayers = function (players) {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
module.exports = PitchEffect;
|
module.exports = PitchEffect;
|
||||||
|
|
||||||
|
|
|
@ -1,15 +1,17 @@
|
||||||
/*
|
|
||||||
|
|
||||||
A Reverb effect
|
|
||||||
|
|
||||||
The value controls the wet/dry amount of the effect
|
|
||||||
|
|
||||||
Clamped 0 to 100
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tone = require('tone');
|
var Tone = require('tone');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @fileoverview
|
||||||
|
* A reverb effect, simulating reverberation in a room
|
||||||
|
* Effect value controls the wet/dry amount:
|
||||||
|
* 0 passes through none of the effect, 100 passes through all effect
|
||||||
|
* Clamped 0 to 100
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize and chain the effect
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
function ReverbEffect () {
|
function ReverbEffect () {
|
||||||
Tone.Effect.call(this);
|
Tone.Effect.call(this);
|
||||||
|
|
||||||
|
@ -22,6 +24,10 @@ function ReverbEffect () {
|
||||||
|
|
||||||
Tone.extend(ReverbEffect, Tone.Effect);
|
Tone.extend(ReverbEffect, Tone.Effect);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the effect value
|
||||||
|
* @param {number} val - the new value to set the effect to
|
||||||
|
*/
|
||||||
ReverbEffect.prototype.set = function (val) {
|
ReverbEffect.prototype.set = function (val) {
|
||||||
this.value = val;
|
this.value = val;
|
||||||
|
|
||||||
|
@ -30,10 +36,20 @@ ReverbEffect.prototype.set = function (val) {
|
||||||
this.reverb.wet.value = this.value / 100;
|
this.reverb.wet.value = this.value / 100;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the effect value
|
||||||
|
* @param {number} val - the value to change the effect by
|
||||||
|
*/
|
||||||
ReverbEffect.prototype.changeBy = function (val) {
|
ReverbEffect.prototype.changeBy = function (val) {
|
||||||
this.set(this.value + val);
|
this.set(this.value + val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clamp the input to a range
|
||||||
|
* @param {number} input - the input to clamp
|
||||||
|
* @param {number} min - the min value to clamp to
|
||||||
|
* @param {number} max - the max value to clamp to
|
||||||
|
*/
|
||||||
ReverbEffect.prototype.clamp = function (input, min, max) {
|
ReverbEffect.prototype.clamp = function (input, min, max) {
|
||||||
return Math.min(Math.max(input, min), max);
|
return Math.min(Math.max(input, min), max);
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,20 +1,22 @@
|
||||||
/*
|
|
||||||
|
|
||||||
A robot-voice effect
|
|
||||||
|
|
||||||
A feedback comb filter with a short delay time creates a low-pitched buzzing
|
|
||||||
The effect value controls the length of this delay time, changing the pitch
|
|
||||||
|
|
||||||
0 mutes the effect
|
|
||||||
|
|
||||||
Other values changes the pitch of the effect, in units of 10 steps per semitone
|
|
||||||
|
|
||||||
Not clamped
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tone = require('tone');
|
var Tone = require('tone');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @fileoverview
|
||||||
|
* A "robotic" effect that adds a low-pitched buzzing to the sound, reminiscent of the
|
||||||
|
* voice of the daleks from Dr. Who.
|
||||||
|
* In audio terms it is a feedback comb filter with a short delay time.
|
||||||
|
* The effect value controls the length of this delay time, changing the pitch of the buzz
|
||||||
|
* A value of 0 mutes the effect.
|
||||||
|
* Other values change the pitch of the effect, in units of 10 steps per semitone.
|
||||||
|
* The effect value is not clamped (but probably should be).
|
||||||
|
* Exterminate.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize and chain the effect
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
function RoboticEffect () {
|
function RoboticEffect () {
|
||||||
Tone.Effect.call(this);
|
Tone.Effect.call(this);
|
||||||
|
|
||||||
|
@ -28,6 +30,10 @@ function RoboticEffect () {
|
||||||
|
|
||||||
Tone.extend(RoboticEffect, Tone.Effect);
|
Tone.extend(RoboticEffect, Tone.Effect);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the effect value
|
||||||
|
* @param {number} val - the new value to set the effect to
|
||||||
|
*/
|
||||||
RoboticEffect.prototype.set = function (val) {
|
RoboticEffect.prototype.set = function (val) {
|
||||||
this.value = val;
|
this.value = val;
|
||||||
|
|
||||||
|
@ -43,13 +49,22 @@ RoboticEffect.prototype.set = function (val) {
|
||||||
this.feedbackCombFilter.delayTime.rampTo(time, 1/60);
|
this.feedbackCombFilter.delayTime.rampTo(time, 1/60);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the effect value
|
||||||
|
* @param {number} val - the value to change the effect by
|
||||||
|
*/
|
||||||
RoboticEffect.prototype.changeBy = function (val) {
|
RoboticEffect.prototype.changeBy = function (val) {
|
||||||
this.set(this.value + val);
|
this.set(this.value + val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Compute the delay time for an effect value.
|
||||||
|
* Convert the effect value to a musical note (in units of 10 per semitone),
|
||||||
|
* and return the period (single cycle duration) of the frequency of that note.
|
||||||
|
* @param {number} val - the effect value
|
||||||
|
* @returns {number} a delay time in seconds
|
||||||
|
*/
|
||||||
RoboticEffect.prototype._delayTimeForValue = function (val) {
|
RoboticEffect.prototype._delayTimeForValue = function (val) {
|
||||||
// convert effect setting range, typically 0-100 but can be outside that,
|
|
||||||
// to a musical note, and return the period of the frequency of that note
|
|
||||||
var midiNote = ((val - 100) / 10) + 36;
|
var midiNote = ((val - 100) / 10) + 36;
|
||||||
var freq = Tone.Frequency(midiNote, 'midi').eval();
|
var freq = Tone.Frequency(midiNote, 'midi').eval();
|
||||||
return 1 / freq;
|
return 1 / freq;
|
||||||
|
|
|
@ -1,16 +1,21 @@
|
||||||
/*
|
|
||||||
|
|
||||||
A wobble effect
|
|
||||||
|
|
||||||
A low frequency oscillator (LFO) controls a gain node
|
|
||||||
This creates an effect like tremolo
|
|
||||||
|
|
||||||
Clamped 0 to 100
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tone = require('tone');
|
var Tone = require('tone');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @fileoverview
|
||||||
|
* A wobble effect. In audio terms, it sounds like tremolo.
|
||||||
|
* It is implemented using a low frequency oscillator (LFO) controlling
|
||||||
|
* a gain node, which causes the loudness of the signal passing through
|
||||||
|
* to increase and decrease rapidly.
|
||||||
|
* Effect value controls the wet/dry amount:
|
||||||
|
* 0 passes through none of the effect, 100 passes through all effect
|
||||||
|
* Effect value also controls the frequency of the LFO.
|
||||||
|
* Clamped 0 to 100
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize and chain the effect
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
function WobbleEffect () {
|
function WobbleEffect () {
|
||||||
Tone.Effect.call(this);
|
Tone.Effect.call(this);
|
||||||
|
|
||||||
|
@ -25,6 +30,10 @@ function WobbleEffect () {
|
||||||
|
|
||||||
Tone.extend(WobbleEffect, Tone.Effect);
|
Tone.extend(WobbleEffect, Tone.Effect);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the effect value
|
||||||
|
* @param {number} val - the new value to set the effect to
|
||||||
|
*/
|
||||||
WobbleEffect.prototype.set = function (val) {
|
WobbleEffect.prototype.set = function (val) {
|
||||||
this.value = val;
|
this.value = val;
|
||||||
|
|
||||||
|
@ -35,10 +44,20 @@ WobbleEffect.prototype.set = function (val) {
|
||||||
this.wobbleLFO.frequency.rampTo(this.value / 10, 1/60);
|
this.wobbleLFO.frequency.rampTo(this.value / 10, 1/60);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Change the effect value
|
||||||
|
* @param {number} val - the value to change the effect by
|
||||||
|
*/
|
||||||
WobbleEffect.prototype.changeBy = function (val) {
|
WobbleEffect.prototype.changeBy = function (val) {
|
||||||
this.set(this.value + val);
|
this.set(this.value + val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clamp the input to a range
|
||||||
|
* @param {number} input - the input to clamp
|
||||||
|
* @param {number} min - the min value to clamp to
|
||||||
|
* @param {number} max - the max value to clamp to
|
||||||
|
*/
|
||||||
WobbleEffect.prototype.clamp = function (input, min, max) {
|
WobbleEffect.prototype.clamp = function (input, min, max) {
|
||||||
return Math.min(Math.max(input, min), max);
|
return Math.min(Math.max(input, min), max);
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue