Доступ к камере и микрофону пользователя возможен на веб-платформе с помощью API Media Capture и Streams . Метод getUserMedia()
предлагает пользователю получить доступ к камере и/или микрофону для захвата в виде медиапотока. Затем этот поток можно записать с помощью API MediaRecorder или поделиться с другими по сети. Запись можно сохранить в локальный файл с помощью метода showOpenFilePicker()
.
В примере ниже показано, как можно записать звук с микрофона пользователя в формате WebM и сохранить запись в файловой системе пользователя.
let stream;
let recorder;
startMicrophoneButton.addEventListener("click", async () => {
// Prompt the user to use their microphone.
stream = await navigator.mediaDevices.getUserMedia({ audio: true });
recorder = new MediaRecorder(stream);
});
stopMicrophoneButton.addEventListener("click", () => {
// Stop the stream.
stream.getTracks().forEach(track => track.stop());
});
startRecordButton.addEventListener("click", async () => {
// For the sake of more legible code, this sample only uses the
// `showSaveFilePicker()` method. In production, you need to
// cater for browsers that don't support this method, as
// outlined in https://web.dev/patterns/files/save-a-file/.
// Prompt the user to choose where to save the recording file.
const suggestedName = "microphone-recording.webm";
const handle = await window.showSaveFilePicker({ suggestedName });
const writable = await handle.createWritable();
// Start recording.
recorder.start();
recorder.addEventListener("dataavailable", async (event) => {
// Write chunks to the file.
await writable.write(event.data);
if (recorder.state === "inactive") {
// Close the file when the recording stops.
await writable.close();
}
});
});
stopRecordButton.addEventListener("click", () => {
// Stop the recording.
recorder.stop();
});
Поддержка браузера
MediaDevices.getUserMedia()
МедиаРекордер API
API доступа к файловой системе showSaveFilePicker()
дальнейшее чтение
- Спецификация захвата и потоков мультимедиа W3C
- Спецификация записи W3C MediaStream
- Спецификация доступа к файловой системе WICG