mirror of
https://github.com/Tonejs/Tone.js
synced 2025-01-25 10:05:02 +00:00
175 lines
5.8 KiB
JavaScript
175 lines
5.8 KiB
JavaScript
define(["Tone/core/Tone", "Tone/signal/TimelineSignal", "Tone/core/Transport", "Tone/signal/Signal"], function (Tone) {
|
|
|
|
/**
|
|
* @class Tone.TransportTimelineSignal extends Tone.TimelineSignal, but adds the ability to synchronize the signal to the signal to the Tone.Transport
|
|
* @extends {Tone.TimelineSignal}
|
|
*/
|
|
Tone.TransportTimelineSignal = function(){
|
|
Tone.TimelineSignal.apply(this, arguments);
|
|
|
|
/**
|
|
* The real signal output
|
|
* @type {Tone.Signal}
|
|
* @private
|
|
*/
|
|
this.output = this._outputSig = new Tone.Signal(this._initial);
|
|
|
|
/**
|
|
* Keep track of the last value. (small optimization)
|
|
* @private
|
|
* @type {Number}
|
|
*/
|
|
this._lastVal = this.value;
|
|
|
|
/**
|
|
* The event id of the tick update loop
|
|
* @private
|
|
* @type {Number}
|
|
*/
|
|
this._synced = Tone.Transport.scheduleRepeat(this._onTick.bind(this), "1i");
|
|
|
|
/**
|
|
* A bound version of the anchor value methods
|
|
* @type {Function}
|
|
* @private
|
|
*/
|
|
this._bindAnchorValue = this._anchorValue.bind(this);
|
|
Tone.Transport.on("start stop pause", this._bindAnchorValue);
|
|
|
|
this._events.memory = Infinity;
|
|
};
|
|
|
|
Tone.extend(Tone.TransportTimelineSignal, Tone.TimelineSignal);
|
|
|
|
/**
|
|
* Callback which is invoked every tick.
|
|
* @private
|
|
* @param {Number} time
|
|
* @return {Tone.TransportTimelineSignal} this
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype._onTick = function(time){
|
|
var val = this.getValueAtTime(Tone.Transport.seconds);
|
|
if (this._lastVal !== val){
|
|
this._lastVal = val;
|
|
//approximate ramp curves with linear ramps
|
|
this._outputSig.linearRampToValueAtTime(val, time);
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Anchor the value at the start and stop of the Transport
|
|
* @param {Number} time The time of the event
|
|
* @return {Tone.TransportTimelineSignal} this
|
|
* @private
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype._anchorValue = function(time){
|
|
var val = this.getValueAtTime(Tone.Transport.ticks);
|
|
this._lastVal = val;
|
|
this._outputSig.cancelScheduledValues(time);
|
|
this._outputSig.setValueAtTime(val, time);
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* Get the scheduled value at the given time. This will
|
|
* return the unconverted (raw) value.
|
|
* @param {TransportTime} time The time in seconds.
|
|
* @return {Number} The scheduled value at the given time.
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype.getValueAtTime = function(time){
|
|
time = this.toTicks(time);
|
|
return Tone.TimelineSignal.prototype.getValueAtTime.call(this, time);
|
|
};
|
|
|
|
/**
|
|
* Set the output of the signal at the given time
|
|
* @param {Number} value The value to change to at the given time
|
|
* @param {TransportTime} time The time to change the signal
|
|
* @return {Tone.TransportTimelineSignal} this
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype.setValueAtTime = function(value, time){
|
|
time = this.toTicks(time);
|
|
Tone.TimelineSignal.prototype.setValueAtTime.call(this, value, time);
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* Linear ramp to the given value from the previous scheduled point to the given value
|
|
* @param {Number} value The value to change to at the given time
|
|
* @param {TransportTime} time The time to change the signal
|
|
* @return {Tone.TransportTimelineSignal} this
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype.linearRampToValueAtTime = function(value, time){
|
|
time = this.toTicks(time);
|
|
Tone.TimelineSignal.prototype.linearRampToValueAtTime.call(this, value, time);
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* Exponential ramp to the given value from the previous scheduled point to the given value
|
|
* @param {Number} value The value to change to at the given time
|
|
* @param {TransportTime} time The time to change the signal
|
|
* @return {Tone.TransportTimelineSignal} this
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype.exponentialRampToValueAtTime = function(value, time){
|
|
time = this.toTicks(time);
|
|
Tone.TimelineSignal.prototype.exponentialRampToValueAtTime.call(this, value, time);
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* Start exponentially approaching the target value at the given time with
|
|
* a rate having the given time constant.
|
|
* @param {number} value
|
|
* @param {TransportTime} startTime
|
|
* @param {number} timeConstant
|
|
* @return {Tone.TransportTimelineSignal} this
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype.setTargetAtTime = function(value, startTime, timeConstant){
|
|
startTime = this.toTicks(startTime);
|
|
Tone.TimelineSignal.prototype.setTargetAtTime.call(this, value, startTime, timeConstant);
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* Cancels all scheduled parameter changes with times greater than or
|
|
* equal to startTime.
|
|
* @param {TransportTime} startTime
|
|
* @returns {Tone.Param} this
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype.cancelScheduledValues = function(startTime){
|
|
startTime = this.toTicks(startTime);
|
|
Tone.TimelineSignal.prototype.cancelScheduledValues.call(this, startTime);
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* Set an array of arbitrary values starting at the given time for the given duration.
|
|
* @param {Float32Array} values
|
|
* @param {Time} startTime
|
|
* @param {Time} duration
|
|
* @param {NormalRange} [scaling=1] If the values in the curve should be scaled by some value
|
|
* @returns {Tone.TimelineSignal} this
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype.setValueCurveAtTime = function (values, startTime, duration, scaling) {
|
|
startTime = this.toTicks(startTime);
|
|
duration = this.toTicks(duration);
|
|
Tone.TimelineSignal.prototype.setValueCurveAtTime.call(this, values, startTime, duration, scaling);
|
|
return this;
|
|
};
|
|
|
|
/**
|
|
* Dispose and disconnect
|
|
* @return {Tone.TransportTimelineSignal} this
|
|
*/
|
|
Tone.TransportTimelineSignal.prototype.dispose = function(){
|
|
Tone.Transport.clear(this._synced);
|
|
Tone.Transport.off("start stop pause", this._syncedCallback);
|
|
this._events.cancel(0);
|
|
Tone.TimelineSignal.prototype.dispose.call(this);
|
|
this._outputSig.dispose();
|
|
this._outputSig = null;
|
|
};
|
|
|
|
return Tone.TransportTimelineSignal;
|
|
});
|