2017-12-29 17:02:40 +00:00
|
|
|
define(["Tone/core/Tone", "Tone/shim/AudioContext"], function(Tone){
|
|
|
|
|
|
|
|
if (Tone.supported){
|
|
|
|
|
|
|
|
//fixes safari only bug which is still present in 11
|
|
|
|
var ua = navigator.userAgent.toLowerCase();
|
|
|
|
var isSafari = ua.indexOf("safari") !== -1 && ua.indexOf("chrome") === -1;
|
|
|
|
if (isSafari){
|
|
|
|
|
|
|
|
var WaveShaperNode = function(context){
|
|
|
|
|
|
|
|
this._internalNode = this.input = this.output = context._native_createWaveShaper();
|
|
|
|
|
|
|
|
this._curve = null;
|
|
|
|
|
|
|
|
for (var prop in this._internalNode){
|
2017-12-29 17:20:51 +00:00
|
|
|
this._defineProperty(this._internalNode, prop);
|
2017-12-29 17:02:40 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Object.defineProperty(WaveShaperNode.prototype, "curve", {
|
|
|
|
get : function(){
|
|
|
|
return this._curve;
|
|
|
|
},
|
|
|
|
set : function(curve){
|
|
|
|
this._curve = curve;
|
|
|
|
var array = new Float32Array(curve.length+1);
|
|
|
|
array.set(curve, 1);
|
|
|
|
array[0] = curve[0];
|
|
|
|
this._internalNode.curve = array;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2017-12-29 17:20:51 +00:00
|
|
|
WaveShaperNode.prototype._defineProperty = function(context, prop){
|
|
|
|
if (Tone.isUndef(this[prop])){
|
|
|
|
Object.defineProperty(this, prop, {
|
2017-12-29 17:02:40 +00:00
|
|
|
get : function(){
|
|
|
|
if (typeof context[prop] === "function"){
|
|
|
|
return context[prop].bind(context);
|
|
|
|
} else {
|
|
|
|
return context[prop];
|
|
|
|
}
|
|
|
|
},
|
|
|
|
set : function(val){
|
|
|
|
context[prop] = val;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2017-12-29 17:26:51 +00:00
|
|
|
};
|
2017-12-29 17:02:40 +00:00
|
|
|
|
|
|
|
AudioContext.prototype._native_createWaveShaper = AudioContext.prototype.createWaveShaper;
|
|
|
|
AudioContext.prototype.createWaveShaper = function(){
|
|
|
|
return new WaveShaperNode(this);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|