- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一整天都被这个问题困扰了。尝试从 getUserMedia 中分离源并分别可视化左 channel 和右 channel 。无论我做什么,每个可视化工具都停留在单声道状态。我使用的源是立体声(如果我在 Windows 中收听它,它显然是立体声)。复制所需的最低限度。
navigator.getUserMedia({audio: true}, analyse, function(e) {
alert('Error getting audio');
console.log(e);
});
}
function analyse(stream){
window.stream = stream;
var input = audioContext.createMediaStreamSource(stream);
splitter = audioContext.createChannelSplitter(2),
lAnalyser = audioContext.createAnalyser(),
rAnalyser = audioContext.createAnalyser();
input.connect(splitter);
splitter.connect(lAnalyser, 0, 0);
splitter.connect(rAnalyser, 1, 0);
var lArray = new Uint8Array(lAnalyser.frequencyBinCount),
rArray = new Uint8Array(rAnalyser.frequencyBinCount);
updateAnalyser()
function updateAnalyser(){
requestAnimationFrame(updateAnalyser);
lAnalyser.getByteFrequencyData(lArray);
rAnalyser.getByteFrequencyData(rArray);
}
}
即使我将左声道或右声道静音,lArray 和 rArray 也将是相同的。难道我做错了什么?我也尝试过输入->分离器->左合并/右合并->左分析器/右分析器。
http://www.smartjava.org/content/exploring-html5-web-audio-visualizing-sound是我能找到的最相似的东西,但它不使用用户输入并处理音频缓冲区。
最佳答案
根据https://code.google.com/p/chromium/issues/detail?id=387737
The behaviour is expected. In M37, we moved the audio processing from peer connection to getUserMedia, and the audio processing is turned on by default if you do no specify "echoCancellation : false" in the getUserMedia constraints, since the audio processing only support mono, we have to down sample the audio to mono before passing the data for processing.
If you want to avoid the down sampling, passing a constraint to getUserMedia, for example:var constraints = {audio: { mandatory: { echoCancellation : false, googAudioMirroring: true } }};getUserMedia(constraints, gotStream, gotStreamFailed);
将约束设置为 {audio: { permanent: { echoCancellation: false}}
会停止输入缩混。
关于javascript - 使用 AnalyserNode 和 ChannelSplitter 获取 L/R 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31697427/
我想捕捉一个小时间窗口(即 ~1 秒)的傅里叶变换。 let audioCtx = new AudioContext(); let analyser = audioCtx.createAnalyser
WebAudio的AnalyserNode有一个FFT来获取声音信号的频域数据。我不明白 FFT 的窗口函数是如何定义的。是否可以更改窗口大小甚至窗口函数(即 Hanning 或 Blackman)?
我正在尝试使用 Web Audio API 编写自相关算法。自相关仅依赖于时域中的数据,而不依赖于频域中的数据,因此我仅使用 getByteTimeDomainData()。我很难找到有关 Analy
我正在使用 Web Audio API 来显示正在播放的音频的可视化效果。我有一个 控制播放的元素,然后我通过创建 MediaElementSource 将它连接到 Web Audio API来自
代码应该流式传输任何 url 并提供音频的可视化。不幸的是,可视化工具无法正常工作。可视化依赖于来自 AnalyzerNode 的数据,它总是返回空数据。为什么这段代码中的 AnalyserNode
我想我可能对使用 AnalyserNode 有点困惑。我目前将我的 userAudio 流“输入”连接到 AnalyserNode。然后我使用 getByteFrequencyData() 填充一个
在Web Audio API中,AnalyserNode的getFloatFrequencyData()和 getByteFrequencyData()方法为我们提供FFT分析数据,其域是频率,余域是
我正在使用 Web Audio API,但有些行为我无法理解。 var audio = document.querySelector('audio'); var context = new Audio
我无法在移动设备中使用 AudioContext.createMediaElementSource 使 AnalayserNode 工作。它不适用于 iOS 上的 Safari,也不适用于 Andro
背景 我的目标是创建一个基于 JavaScript 的网络应用程序来分析和显示音频源中的频率信息,包括页面内源( 标记)和从客户端麦克风流出的信号。我正在路上:) 作为一名敏锐的萨克斯管演奏者,我的目
所以我想我明白 getFloatFrequencyData很不错。如 getFloatFrequencyData返回一个包含 1024 个值的数组,每个值代表一个频率区间/范围的音量。在采样率为 44
实现 Peak Meter 的正确方法是什么?就像 Logic Pro 中的那些使用网络音频 API AnalyserNode ? 我知道AnalyserNode.getFloatFrequencyD
我正在尝试使用 Web-Audio 的分析器节点并不断从中得到奇怪的结果。 代码: var self = this; var bufferSize = 512; var spectrum = new
这似乎是一个常见问题 - Javascript Web Audio API AnalyserNode Not Working - 但我不确定我是否在我的实现中找到了边缘案例。 我使用 createMe
我一整天都被这个问题困扰了。尝试从 getUserMedia 中分离源并分别可视化左 channel 和右 channel 。无论我做什么,每个可视化工具都停留在单声道状态。我使用的源是立体声(如果我
网络浏览器中的音频分析可以通过 AnalyserNode of Web Audio API 轻松执行。 Node.js 有类似的东西吗? 最佳答案 您可能对 https://www.npmjs.com
我是一名优秀的程序员,十分优秀!