我一直在寻找使用Web音频API创建音频均衡器: http://webaudio.github.io/web-audio-api/

我发现了许多关于创建可视化工具的线索,但这当然不是我想要做的.我只是希望能够使用频率滑块改变声音.我发现biquadFilter应该做的工作,但我不能得到一个好的结果.当我改变任何频率值时,声音会一致地改变,但它只会降低声音的质量,同时它应该改变频率.

我先加载一个声音:

Audio.prototype.init = function(callback){
    var $this = this;
    this.gainScale = d3.scale.linear().domain([0,1]).range([-40,40]);
    this.context = new AudioContext();
    this.loadSounds(function(){
        $this.loadSound(0);
        $this.play();
        callback.call();
    });
};

一切运作良好,声音在准备好时播放.

我有10个频率滑块[32,64,125,250,500,1000,2000,4000,8000,16000].
对于每个滑块,我创建一个过滤器,然后将其连接到源,如下所述:Creating a 10-Band Equalizer Using Web Audio API:

Audio.prototype.createFilter = function(index,frequency){
    if(this.filters == undefined) this.filters = [];
    var filter = this.context.createBiquadFilter();
    filter = this.context.createBiquadFilter();
    filter.type = 2;
    filter.frequency.value = frequency;
    // Connect source to filter,filter to destination.
    this.source.connect(filter);
    filter.connect(this.context.destination);
    this.filters[index] = filter;
};

最后,当我更改滑块的值时,我更新了过滤器:

Audio.prototype.updatefilter = function(index,newVal){
    this.filters[index].frequency.gain = this.gainScale(newVal);
};

注意:我的this.gainScale函数将[0,1]中的值作为输入,并返回[-40,40]中的值,以便为每个频率设置-40到40之间的增益.

非常感谢任何帮助!

解决方法

这里有很多东西.

1)您不应并行使用带通滤波器来实现均衡器.在其他问题中,双二阶滤波会改变信号不同部分的相位,因此不同的频段最终会处于不同的阶段,并且当它重新组合时,你的声音可能会产生一些非常糟糕的影响.

2)您想要的方法是在底端有一个低架式过滤器,在顶端有一个高架式过滤器,在中间有任意数量的峰值过滤器.这些应该串联连接(即输入信号连接到一个滤波器,连接到另一个滤波器,连接到另一个滤波器等,只有最终滤波器应连接到audiocontext.destination .Q值应该是调谐(见下文),滤波器上的增益决定了增强/削减.(对于平坦响应,所有滤波器增益应设置为零.)

3)filter.type是一个枚举类型,您应该将其设置为字符串,而不是数字. “lowshelf”,“highshelf”和“峰值”是你在这里寻找的.

您可以在我的DJ应用程序中看到一个简单的三波段均衡器示例 – https://github.com/cwilso/wubwubwub/blob/MixTrack/js/tracks.js#L189-L207设置它.要将其修改为多波段均衡器,您需要调整每个滤波器的Q值,以使波段不重叠(如果它们重叠则不错,但如果调整它们,您的波段会更精确) .您可以使用http://googlechrome.github.io/web-audio-samples/samples/audio/frequency-response.html检查给定Q和滤波器类型的频率响应.

javascript – Web音频API均衡器的更多相关文章

  1. ubuntu – 是否有负载均衡器允许您重新使用套接字连接?

    我有一个服务,服务器上传20kbxml文件到我的服务器.没有会话,它是一个单一的POST请求,就是这样.每个单独的请求都根据xml文件的内容进行身份验证.在负载测试期间,我将不得不进行与套接字相关的调整,服务器耗尽其套接字池.无论如何,我想知道当我将负载均衡器带入两个Web服务器之间的循环请求时,可能会发生什么变化.负载均衡器可以重新使用套接字吗?如果是这样,那么就有很大的调整范围.

  2. Windows – IIS日志文件和负载均衡器?

    我们将ASP.NET应用程序托管在两个位于硬件负载平衡器后面的Web服务器上.当我查看IIS日志时,IIS日志中的c-ip值始终是负载均衡器的IP地址.我注意到在http标头中,有一个X-Forwarded-For标头似乎有请求的IP地址.我可以做些什么来使IIS在日志中记录此标头值吗?

  3. windows-server-2008 – 负载均衡器或服务器上的SSL证书

    我有一个负载均衡器在两个服务器之间分配流量,面向公众的URL都是https前缀.我想生成一个通配符ssl证书,但我不确定将它放在负载均衡器或两个服务器中是否更好?有什么好处和差异.谢谢一种非常常见的做法是在负载均衡器中放置/配置证书,而不是在后端服务器中.为什么?

  4. php – Apache 2.4没有关闭连接

    提前致谢!

  5. windows – 负载均衡器出现故障时会发生什么?

    假设我使用的是亚马逊的EC2负载均衡器.我把它连接到两个实例.如果负载均衡器出现故障会怎样?两个实例现在都无法正常工作吗?通常,负载均衡器聚集在一起形成高可用性对.如果一个负载均衡器发生故障,则辅助设备会接收故障并变为活动状态.他们之间有一个监视状态的心跳链接.如果所有负载平衡器都出现故障,则下游服务器将脱机,直到问题得到解决,或者您手动绕过它们.

  6. Centos6下haproxy+keepalived构建高可用web集群

    1)实验拓扑信息说明:a、在客户端使用www.wanwan.com,将由负载均衡器提交给vip1所对应的集群进行处理b、在客户端使用img.wanwan.com,将由负载均衡器提交给vip1所对应的集群进行处理c、10.10.10.129和10.10.10.130两台负载均衡器,其中某一台出现故障均不影响整个系统运行2)haproxy的安装与启动脚本配置参考我的上一篇博客:http://www.j

  7. javascript – 如何为音频播放器创建均衡器

    有很多音乐播放器,甚至是HTML5音频播放器,但是如何添加均衡器呢?

  8. javascript – Web音频API均衡器

    我一直在寻找使用Web音频API创建音频均衡器:http://webaudio.github.io/web-audio-api/我发现了许多关于创建可视化工具的线索,但这当然不是我想要做的.我只是希望能够使用频率滑块改变声音.我发现biquadFilter应该做的工作,但我不能得到一个好的结果.当我改变任何频率值时,声音会一致地改变,但它只会降低声音的质量,同时它应该改变频率.我先加载一个声音:一

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部