Tone.js/Tone/source/Source.js
2014-12-19 16:27:50 -05:00

97 lines
No EOL
1.9 KiB
JavaScript

define(["Tone/core/Tone", "Tone/core/Transport", "Tone/core/Master"], function(Tone){
"use strict";
/**
* @class Base class for sources.
* Sources have start/stop/pause and
* the ability to be synced to the
* start/stop/pause of Tone.Transport.
*
* @constructor
* @extends {Tone}
*/
Tone.Source = function(){
//unlike most ToneNodes, Sources only have an output and no input
Tone.call(this, 0, 1);
/**
* @type {Tone.Source.State}
*/
this.state = Tone.Source.State.STOPPED;
};
Tone.extend(Tone.Source);
/**
* @abstract
* @param {Tone.Time} time
*/
Tone.Source.prototype.start = function(){};
/**
* @abstract
* @param {Tone.Time} time
*/
Tone.Source.prototype.stop = function(){};
/**
* @abstract
* @param {Tone.Time} time
*/
Tone.Source.prototype.pause = function(time){
//if there is no pause, just stop it
this.stop(time);
};
/**
* sync the source to the Transport
*
* @param {Tone.Time} [delay=0] delay time before starting the source
*/
Tone.Source.prototype.sync = function(delay){
Tone.Transport.syncSource(this, delay);
};
/**
* unsync the source to the Transport
*/
Tone.Source.prototype.unsync = function(){
Tone.Transport.unsyncSource(this);
};
/**
* gets the setVolume method from {@link Tone.Master}
* @method
*/
Tone.Source.prototype.setVolume = Tone.Master.setVolume;
/**
* set the parameters at once
* @param {Object} params
*/
Tone.Source.prototype.set = function(params){
if (!this.isUndef(params.volume)) this.setVolume(params.volume);
};
/**
* clean up
*/
Tone.Source.prototype.dispose = function(){
Tone.prototype.dispose.call(this);
this.state = null;
};
/**
* @enum {string}
*/
Tone.Source.State = {
STARTED : "started",
PAUSED : "paused",
STOPPED : "stopped",
SYNCED : "synced"
};
return Tone.Source;
});