2019-01-27 18:05:20 +00:00
|
|
|
import Tone from "../core/Tone";
|
|
|
|
import "../component/CrossFade";
|
2019-05-23 18:00:49 +00:00
|
|
|
import "./Merge";
|
|
|
|
import "./Split";
|
2019-01-27 18:05:20 +00:00
|
|
|
import "../signal/Signal";
|
|
|
|
import "../signal/AudioToGain";
|
|
|
|
import "../signal/Zero";
|
|
|
|
import "../core/AudioNode";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class Tone.Panner is an equal power Left/Right Panner and does not
|
|
|
|
* support 3D. Panner uses the StereoPannerNode when available.
|
|
|
|
*
|
|
|
|
* @constructor
|
|
|
|
* @extends {Tone.AudioNode}
|
|
|
|
* @param {NormalRange} [initialPan=0] The initail panner value (center).
|
|
|
|
* @example
|
|
|
|
* //pan the input signal hard right.
|
|
|
|
* var panner = new Tone.Panner(1);
|
|
|
|
*/
|
2019-05-23 18:00:49 +00:00
|
|
|
Tone.Panner = function() {
|
2019-01-27 18:05:20 +00:00
|
|
|
|
2019-04-04 19:10:03 +00:00
|
|
|
var options = Tone.defaults(arguments, ["pan"], Tone.Panner);
|
2019-01-27 18:05:20 +00:00
|
|
|
Tone.AudioNode.call(this);
|
2014-06-21 17:06:27 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* the panner node
|
|
|
|
* @type {StereoPannerNode}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._panner = this.input = this.output = this.context.createStereoPanner();
|
2014-04-05 22:05:42 +00:00
|
|
|
|
2014-06-21 17:06:27 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* The pan control. -1 = hard left, 1 = hard right.
|
|
|
|
* @type {AudioRange}
|
|
|
|
* @signal
|
|
|
|
*/
|
|
|
|
this.pan = this._panner.pan;
|
|
|
|
|
|
|
|
//initial value
|
2019-04-04 19:10:03 +00:00
|
|
|
this.pan.value = options.pan;
|
2019-01-27 18:05:20 +00:00
|
|
|
this._readOnly("pan");
|
|
|
|
};
|
|
|
|
|
|
|
|
Tone.extend(Tone.Panner, Tone.AudioNode);
|
|
|
|
|
2019-04-04 19:10:03 +00:00
|
|
|
/**
|
|
|
|
* Defaults
|
|
|
|
* @type {Object}
|
|
|
|
* @const
|
|
|
|
* @static
|
|
|
|
*/
|
|
|
|
Tone.Panner.defaults = {
|
2019-05-23 18:00:49 +00:00
|
|
|
"pan" : 0,
|
2019-04-04 19:10:03 +00:00
|
|
|
};
|
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* Clean up.
|
|
|
|
* @returns {Tone.Panner} this
|
|
|
|
*/
|
2019-05-23 18:00:49 +00:00
|
|
|
Tone.Panner.prototype.dispose = function() {
|
2019-01-27 18:05:20 +00:00
|
|
|
Tone.AudioNode.prototype.dispose.call(this);
|
|
|
|
this._writable("pan");
|
|
|
|
this._panner.disconnect();
|
|
|
|
this._panner = null;
|
|
|
|
this.pan = null;
|
|
|
|
return this;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Tone.Panner;
|
|
|
|
|