HTML   发布时间:2022-04-14  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Web Audio API WaveShaperNode大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
你如何在网络音频api中使用waveshapernode?特别是曲线Float32Array属性?
@H_674_3@解决方法
请随意查看示例 here.

详细地说,我用这个函数创建了一个wavehaper曲线:

WAAMorningStar.prototype.createWSCurve = function (amount,n_samples) {

if ((amount >= 0) && (amount < 1)) {

    ND.dist = amount;

    var k = 2 * ND.dist / (1 - ND.dist);

    for (var i = 0; i < n_samples; i+=1) {
        // LINEAR INTERPOLATION: x := (c - a) * (z - y) / (b - a) + y
        // a = 0,b = 2048,z = 1,y = -1,c = i
        var x = (i - 0) * (1 - (-1)) / (n_samples - 0) + (-1);
        this.wsCurve[i] = (1 + k) * x / (1+ k * Math.abs(X));
    }

}

然后在wavehaper节点中“加载”它,如下所示:

this.createWSCurve(ND.dist,this.nSamples);
this.sigmaDistortNode = this.context.createWaveShaper();
this.sigmaDistortNode.curve = this.wsCurve;

每当我需要更改失真参数时,我会重新创建wavehaper曲线:

WAAMorningStar.prototype.setDistortion = function (distvalue) {
    var distCorrect = distValue;
    if (distValue < -1) {
        distCorrect = -1;
    }
    if (distValue >= 1) {
        distCorrect = 0.985;
    }
    this.createWSCurve (distCorrect,this.nSamples);
}

(我使用distCorrect来使失真听起来更好,从价值上看是值得的).
您可以找到我用来创建wavehaper曲线here的算法

大佬总结

以上是大佬教程为你收集整理的Web Audio API WaveShaperNode全部内容,希望文章能够帮你解决Web Audio API WaveShaperNode所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:apiaudioweb