gpt4 book ai didi

javascript - 如何在 Javascript 中将音频缓冲区转换为 MP3?

转载 作者:行者123 更新时间:2023-12-02 22:22:05 39 4
gpt4 key购买 nike

我在 ReactJS 中使用 MediaRecorder 来录制来自麦克风的音频并存储到 MIME 类型为“audio/mp3”的 blob 中。我想将此 blob 转换为 MP3 并将其上传到 S3 存储桶中。

我可以通过使用 audioContext、decodeAudioData 和 audioBufferToWav 函数将其转换为 WAV,但是 WAV 的大小非常大。由于 MP3 文件的大小相对非常小,所以我希望它将我的 blob 转换为 MP3。有什么帮助吗?

我用于录制和转换为 wav 的代码:

getUserMedia({ audio: true })
.then(stream => {
this.stream = stream;
const mimeType = 'audio/mp3';
this.mediaRecorder = new MediaRecorder(stream);
this.mediaRecorder.start();
const audioChunks = [];
this.mediaRecorder.addEventListener('dataavailable', event => {
audioChunks.push(event.data);
});

this.mediaRecorder.addEventListener('stop', () => {
const audioBlob = new Blob(audioChunks, {
type: mimeType});

});
}).catch(error => { });

将上面创建的 blob 转换为 WAV:
const reader = new window.FileReader();
reader.readAsDataURL(audioBlob);
reader.onloadend = () => {
let base64 = reader.result + '';
base64 = base64.split(',')[1];
const ab = new ArrayBuffer(base64.length);
const buff = new Buffer.from(base64, 'base64');
const view = new Uint8Array(ab);
for (let i = 0; i < buff.length; ++i) {
view[i] = buff[i];
}
const context = new AudioContext();
context.decodeAudioData(ab, (buffer) => {
const wavFile = toWav(buffer);
}

我正在存储 wavFile进入 S3。我想要MP3,请帮忙?

最佳答案

我没有使用 ReactJS MediaRecorder,也没有完全遵循您的具体示例中发生的事情,但我有一个将 AudioBuffer 转换为 mp3 的解决方案,即波形。
第一个函数基于russellgood.com/how-to-convert-audiobuffer-to-audio-file .第二个是基于lamejs .
首先,将AudioBuffer转换为wave blob

function audioBufferToWav(aBuffer) {
let numOfChan = aBuffer.numberOfChannels,
btwLength = aBuffer.length * numOfChan * 2 + 44,
btwArrBuff = new ArrayBuffer(btwLength),
btwView = new DataView(btwArrBuff),
btwChnls = [],
btwIndex,
btwSample,
btwOffset = 0,
btwPos = 0;
setUint32(0x46464952); // "RIFF"
setUint32(btwLength - 8); // file length - 8
setUint32(0x45564157); // "WAVE"
setUint32(0x20746d66); // "fmt " chunk
setUint32(16); // length = 16
setUint16(1); // PCM (uncompressed)
setUint16(numOfChan);
setUint32(aBuffer.sampleRate);
setUint32(aBuffer.sampleRate * 2 * numOfChan); // avg. bytes/sec
setUint16(numOfChan * 2); // block-align
setUint16(16); // 16-bit
setUint32(0x61746164); // "data" - chunk
setUint32(btwLength - btwPos - 4); // chunk length

for (btwIndex = 0; btwIndex < aBuffer.numberOfChannels; btwIndex++)
btwChnls.push(aBuffer.getChannelData(btwIndex));

while (btwPos < btwLength) {
for (btwIndex = 0; btwIndex < numOfChan; btwIndex++) {
// interleave btwChnls
btwSample = Math.max(-1, Math.min(1, btwChnls[btwIndex][btwOffset])); // clamp
btwSample = (0.5 + btwSample < 0 ? btwSample * 32768 : btwSample * 32767) | 0; // scale to 16-bit signed int
btwView.setInt16(btwPos, btwSample, true); // write 16-bit sample
btwPos += 2;
}
btwOffset++; // next source sample
}

let wavHdr = lamejs.WavHeader.readHeader(new DataView(btwArrBuff));
let wavSamples = new Int16Array(btwArrBuff, wavHdr.dataOffset, wavHdr.dataLen / 2);

wavToMp3(wavHdr.channels, wavHdr.sampleRate, wavSamples);

function setUint16(data) {
btwView.setUint16(btwPos, data, true);
btwPos += 2;
}

function setUint32(data) {
btwView.setUint32(btwPos, data, true);
btwPos += 4;
}
}
二、将wave转换成mp3
function wavToMp3(channels, sampleRate, samples) {
var buffer = [];
var mp3enc = new lamejs.Mp3Encoder(channels, sampleRate, 128);
var remaining = samples.length;
var samplesPerFrame = 1152;
for (var i = 0; remaining >= samplesPerFrame; i += samplesPerFrame) {
var mono = samples.subarray(i, i + samplesPerFrame);
var mp3buf = mp3enc.encodeBuffer(mono);
if (mp3buf.length > 0) {
buffer.push(new Int8Array(mp3buf));
}
remaining -= samplesPerFrame;
}
var d = mp3enc.flush();
if(d.length > 0){
buffer.push(new Int8Array(d));
}

var mp3Blob = new Blob(buffer, {type: 'audio/mp3'});
var bUrl = window.URL.createObjectURL(mp3Blob);

// send the download link to the console
console.log('mp3 download:', bUrl);

}
希望这可以帮助!

关于javascript - 如何在 Javascript 中将音频缓冲区转换为 MP3?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61264581/

39 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com