2018-08-27 02:29:17 +00:00
|
|
|
define(["../core/Tone", "../event/Loop", "../control/CtrlPattern"], function(Tone){
|
2015-11-04 00:15:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @class Tone.Pattern arpeggiates between the given notes
|
2015-11-18 03:52:22 +00:00
|
|
|
* in a number of patterns. See Tone.CtrlPattern for
|
|
|
|
* a full list of patterns.
|
|
|
|
* @example
|
|
|
|
* var pattern = new Tone.Pattern(function(time, note){
|
|
|
|
* //the order of the notes passed in depends on the pattern
|
|
|
|
* }, ["C2", "D4", "E5", "A6"], "upDown");
|
2015-11-04 00:15:40 +00:00
|
|
|
* @extends {Tone.Loop}
|
|
|
|
* @param {Function} callback The callback to invoke with the
|
|
|
|
* event.
|
2016-03-04 20:35:10 +00:00
|
|
|
* @param {Array} values The values to arpeggiate over.
|
2015-11-04 00:15:40 +00:00
|
|
|
*/
|
|
|
|
Tone.Pattern = function(){
|
|
|
|
|
2017-04-26 02:31:06 +00:00
|
|
|
var options = Tone.defaults(arguments, ["callback", "values", "pattern"], Tone.Pattern);
|
2015-11-04 00:15:40 +00:00
|
|
|
Tone.Loop.call(this, options);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The pattern manager
|
|
|
|
* @type {Tone.CtrlPattern}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._pattern = new Tone.CtrlPattern({
|
2016-03-04 20:35:10 +00:00
|
|
|
"values" : options.values,
|
2015-11-04 00:15:40 +00:00
|
|
|
"type" : options.pattern,
|
|
|
|
"index" : options.index
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
Tone.extend(Tone.Pattern, Tone.Loop);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The defaults
|
|
|
|
* @const
|
|
|
|
* @type {Object}
|
|
|
|
*/
|
|
|
|
Tone.Pattern.defaults = {
|
|
|
|
"pattern" : Tone.CtrlPattern.Type.Up,
|
2017-04-26 02:31:06 +00:00
|
|
|
"callback" : Tone.noOp,
|
2016-03-04 20:35:10 +00:00
|
|
|
"values" : [],
|
2015-11-04 00:15:40 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Internal function called when the notes should be called
|
|
|
|
* @param {Number} time The time the event occurs
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
Tone.Pattern.prototype._tick = function(time){
|
2016-12-18 18:43:23 +00:00
|
|
|
this.callback(time, this._pattern.value);
|
2015-11-04 00:15:40 +00:00
|
|
|
this._pattern.next();
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2016-03-04 20:35:10 +00:00
|
|
|
* The current index in the values array.
|
2015-11-04 00:15:40 +00:00
|
|
|
* @memberOf Tone.Pattern#
|
2015-11-18 03:52:22 +00:00
|
|
|
* @type {Positive}
|
2015-11-04 00:15:40 +00:00
|
|
|
* @name index
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.Pattern.prototype, "index", {
|
|
|
|
get : function(){
|
|
|
|
return this._pattern.index;
|
|
|
|
},
|
|
|
|
set : function(i){
|
|
|
|
this._pattern.index = i;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The array of events.
|
|
|
|
* @memberOf Tone.Pattern#
|
2015-11-18 03:52:22 +00:00
|
|
|
* @type {Array}
|
2016-03-04 20:35:10 +00:00
|
|
|
* @name values
|
2015-11-04 00:15:40 +00:00
|
|
|
*/
|
2016-03-04 20:35:10 +00:00
|
|
|
Object.defineProperty(Tone.Pattern.prototype, "values", {
|
2015-11-04 00:15:40 +00:00
|
|
|
get : function(){
|
|
|
|
return this._pattern.values;
|
|
|
|
},
|
|
|
|
set : function(vals){
|
|
|
|
this._pattern.values = vals;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The current value of the pattern.
|
|
|
|
* @memberOf Tone.Pattern#
|
2015-11-18 03:52:22 +00:00
|
|
|
* @type {*}
|
2015-11-04 00:15:40 +00:00
|
|
|
* @name value
|
2015-11-18 03:52:22 +00:00
|
|
|
* @readOnly
|
2015-11-04 00:15:40 +00:00
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.Pattern.prototype, "value", {
|
|
|
|
get : function(){
|
|
|
|
return this._pattern.value;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
2015-11-18 03:52:22 +00:00
|
|
|
* The pattern type. See Tone.CtrlPattern for the full list of patterns.
|
2015-11-04 00:15:40 +00:00
|
|
|
* @memberOf Tone.Pattern#
|
2015-11-18 03:52:22 +00:00
|
|
|
* @type {String}
|
2015-11-04 00:15:40 +00:00
|
|
|
* @name pattern
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.Pattern.prototype, "pattern", {
|
|
|
|
get : function(){
|
|
|
|
return this._pattern.type;
|
|
|
|
},
|
|
|
|
set : function(pattern){
|
|
|
|
this._pattern.type = pattern;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clean up
|
|
|
|
* @return {Tone.Pattern} this
|
|
|
|
*/
|
|
|
|
Tone.Pattern.prototype.dispose = function(){
|
|
|
|
Tone.Loop.prototype.dispose.call(this);
|
|
|
|
this._pattern.dispose();
|
|
|
|
this._pattern = null;
|
|
|
|
};
|
|
|
|
|
|
|
|
return Tone.Pattern;
|
2017-10-26 20:02:01 +00:00
|
|
|
});
|