前端录音
export class SoundRecording{
mediaRecorder: MediaRecorder | null;
stream: MediaStream | null;
chunks: any[];
endCallback: any[];
constructor() {
this.mediaRecorder = null;
this.stream = null;
this.chunks = [];
this.endCallback = [];
}
create() {
return new Promise((resolve, reject) => {
this.resetState();
navigator.mediaDevices.getUserMedia({audio: true}).then((stream) => {
this.stream = stream;
this.mediaRecorder = new MediaRecorder(stream, { audioBitsPerSecond: 128000, mimeType: "audio/webm;codecs=opus" });
resolve('');
}).catch((err) => {
reject(err);
});
});
}
start() {
return new Promise((resolve, reject) => {
this.judgeMediaRecorderIs().then((mediaRecorder: MediaRecorder) => {
mediaRecorder.start();
mediaRecorder.addEventListener('dataavailable', (e) => {
this.chunks.push(e.data);
this.endCallback.forEach((resolve) => {
resolve();
this.endCallback.shift();
});
});
resolve('');
}).catch((err) => {
reject(err);
});
});
}
stop() {
return new Promise((resolve, reject) => {
this.judgeMediaRecorderIs().then((mediaRecorder: MediaRecorder) => {
if (mediaRecorder.state === 'inactive') {
return reject({code: 0, message: '已结束'});
};
mediaRecorder.stop();
this.stream.getTracks().forEach((track) => { track.stop(); })
this.endCallback.push(resolve);
}).catch((err) => {
reject(err);
});
});
}
download() {
return new Promise((resolve, reject) => {
this.handleChunksToBolb().then((blob: Blob) => {
let url = URL.createObjectURL(blob);
let a = document.createElement('a');
a.href = url;
a.download = 'audio.wav';
a.click();
resolve(url);
}).catch((err) => {
reject(err);
});
});
}
viewRecording() {
return new Promise((resolve, reject) => {
this.handleChunksToBolb().then((blob: Blob) => {
let url = URL.createObjectURL(blob);
resolve(url);
}).catch((err) => {
reject(err);
});
});
}
toFile() {
return new Promise((resolve, reject) => {
this.handleChunksToBolb().then((blob: Blob) => {
resolve(new File([blob], 'audio.wav', { type: 'audio/wav' }));
}).catch((err) => {
reject(err);
});
});
}
handleChunksToBolb() {
return new Promise((resolve, reject) => {
this.judgeChunksIs().then((chunks: any) => {
let blob = new Blob(chunks, { type: 'audio/wav;codecs=opus' })
resolve(blob);
}).catch((err) => {
reject(err);
});
});
}
judgeChunksIs() {
return new Promise((resolve, reject) => {
let chunks = this.chunks;
if (chunks.length === 0) {
return reject({code: 0, message: '没有录制的缓冲'});
};
return resolve(chunks);
});
}
judgeMediaRecorderIs() {
return new Promise((resolve, reject) => {
let mediaRecorder = this.mediaRecorder;
if (!mediaRecorder) { return reject({code: 0, message: '请先创建一个录制对象'}); };
resolve(mediaRecorder);
});
}
setEndCallback(callback) {
this.endCallback.push(callback);
}
resetState() {
this.chunks = [];
this.mediaRecorder = null;
this.stream = null;
}
};
使用方法
let mySoundRecording = new SoundRecording();
mySoundRecording.create().then(() => {
mySoundRecording.start();
let endRecording = () => {
mySoundRecording.download();
mySoundRecording.viewRecording().then((srcObject) => {});
mySoundRecording.toFile().then((file) => {});
};
mySoundRecording.setEndCallback(endRecording);
mySoundRecording.stop().then(() => {
mySoundRecording.download();
mySoundRecording.viewRecording().then((srcObject) => {});
mySoundRecording.toFile().then((file) => {});
});
});