我正在通过电线接收一个交错的16位PCM样本。每个样本都有签名
我把它读作Int16bit数组,让我们调用这个all_data。因此每个数组条目都是一个16位的样本。
因为它是交错的,所以我将它提取成2个通道,R-L-R-L,最后得到2个(16位)数组,大小是ALL_DATA数组的一半。
之后,我查看每个示例,并将其规范化为Float32Array,因为这是web audio API所使用的。
var NormalizedSample=(sample>0)?样本/32768:样本/-32768;
这样做对吗。
我听到了扭曲的声音。你能看出是怎么回事。所以从字面上看,如果你听的是古典吉他,听起来就像是有失真的电吉他。
为了参数起见,我把示例代码放了下来,但这段代码处理
单声道,使示例更简单,所以我们也不必交错
var startTime = 0;
var fileReader = new FileReader();
fileReader.onload = function (e) {
var data = new DataView(e.target.result);
var audio = new Int16Array(data.byteLength / Int16Array.BYTES_PER_ELEMENT);
var len = audio.length;
for (var jj = 0; jj < len; ++jj) {
audio[jj] = data.getInt16(jj * Int16Array.BYTES_PER_ELEMENT, true);
}
var right = new Float32Array(audio.length);
var channleCounter = 0;
for (var i = 0; i < audio.length; ) {
var normalizedRight = (audio[i] > 0) ? audio[i] / 32768 : audio[i] / -32768;
i = i + 1;
right[channleCounter] = normalizedRight;
channleCounter++;
}
var source = audioContext.createBufferSource();
var audioBuffer = audioContext.createBuffer(1, right.length, 44100);
audioBuffer.getChannelData(0).set(right);
source.buffer = audioBuffer;
source.connect(audioContext.destination);
source.noteOn(startTime);
startTime += audioBuffer.duration;
};
任何可能导致声音失真的建议都将有所帮助。我写了pcm数据之前,我把它在服务器端发送到一个文件是好的,声音是完美的。
而不是说
var normalizedSample= (sample > 0) ? sample / 32768 : sample / -32768;
试试看
var normalizedSample= sample / 32768;
当前编写的计算将以类似于全波整流器的方式反转波形的负部分(样本始终为正数)。