2019-01-27 18:05:20 +00:00
|
|
|
import Tone from "../core/Tone";
|
|
|
|
import "../type/Ticks";
|
2017-09-04 20:01:57 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* @class Tone.TransportEvent is an internal class used by (Tone.Transport)[Transport]
|
|
|
|
* to schedule events. Do no invoke this class directly, it is
|
|
|
|
* handled from within Tone.Transport.
|
|
|
|
* @extends {Tone}
|
|
|
|
* @param {Object} options
|
|
|
|
*/
|
|
|
|
Tone.TransportEvent = function(Transport, options){
|
2017-09-04 20:01:57 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
options = Tone.defaultArg(options, Tone.TransportEvent.defaults);
|
|
|
|
Tone.call(this);
|
2017-09-04 20:01:57 +00:00
|
|
|
|
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* Reference to the Transport that created it
|
|
|
|
* @type {Tone.Transport}
|
2017-09-04 20:01:57 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this.Transport = Transport;
|
2017-09-04 20:01:57 +00:00
|
|
|
|
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* The unique id of the event
|
2017-09-04 20:01:57 +00:00
|
|
|
* @type {Number}
|
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this.id = Tone.TransportEvent._eventId++;
|
2017-09-04 20:01:57 +00:00
|
|
|
|
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* The time the event starts
|
|
|
|
* @type {Ticks}
|
2017-09-04 20:01:57 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this.time = Tone.Ticks(options.time);
|
2017-09-04 20:01:57 +00:00
|
|
|
|
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* The callback to invoke
|
|
|
|
* @type {Function}
|
2017-09-04 20:01:57 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this.callback = options.callback;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If the event should be removed after being created.
|
|
|
|
* @type {Boolean}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._once = options.once;
|
|
|
|
};
|
|
|
|
|
|
|
|
Tone.extend(Tone.TransportEvent);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The defaults
|
|
|
|
* @static
|
|
|
|
* @type {Object}
|
|
|
|
*/
|
|
|
|
Tone.TransportEvent.defaults = {
|
|
|
|
"once" : false,
|
|
|
|
"callback" : Tone.noOp,
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Current ID counter
|
|
|
|
* @private
|
|
|
|
* @static
|
|
|
|
* @type {Number}
|
|
|
|
*/
|
|
|
|
Tone.TransportEvent._eventId = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoke the event callback.
|
|
|
|
* @param {Time} time The AudioContext time in seconds of the event
|
|
|
|
*/
|
|
|
|
Tone.TransportEvent.prototype.invoke = function(time){
|
|
|
|
if (this.callback){
|
|
|
|
this.callback(time);
|
|
|
|
if (this._once && this.Transport){
|
|
|
|
this.Transport.clear(this.id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clean up
|
|
|
|
* @return {Tone.TransportEvent} this
|
|
|
|
*/
|
|
|
|
Tone.TransportEvent.prototype.dispose = function(){
|
|
|
|
Tone.prototype.dispose.call(this);
|
|
|
|
this.Transport = null;
|
|
|
|
this.callback = null;
|
|
|
|
this.time = null;
|
|
|
|
return this;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Tone.TransportEvent;
|
2017-09-04 20:01:57 +00:00
|
|
|
|