为什么我在移动铬浏览器中的MediaStream录制API中获得斑点长度为0?

发布于 2025-02-12 05:36:36 字数 1492 浏览 0 评论 0原文

我正在下一个JS中构建一个简单的录音机,该录音机将在录制结束后将音频斑点发送到服务器。

import { useEffect, useState } from "react";
const useRecorder = () => {
  const [audioURL, setAudioURL] = useState();
  const [isRecording, setIsRecording] = useState(false);
  const [recorder, setRecorder] = useState(null);
  useEffect(() => {
    // Lazily obtain recorder first time we're recording.
    if (recorder === null) {
      if (isRecording) {
        requestRecorder().then(setRecorder, console.error);
      }
      return;
    }
    // Manage recorder state.
    if (isRecording) {
      recorder?.start();
    } else {
      recorder?.stop();
    }
    // Obtain the audio when ready.
    const handleData = (e) => {
      setAudioURL({
        data: URL.createObjectURL(e.data),
        type: e,
        name: e.name,
      });
    };
    recorder.addEventListener("dataavailable", handleData);
    return () => recorder.removeEventListener("dataavailable", handleData);
  }, [recorder, isRecording]);
  const startRecording = () => {
    setIsRecording(true);
  };
  const stopRecording = () => {
    setIsRecording(false);
  };

  return [audioURL, isRecording, startRecording, stopRecording];
};
async function requestRecorder() {
  const stream = await navigator.mediaDevices.getUserMedia({ audio: true });
  return new MediaRecorder(stream, { type: "audio/x-mpeg-3" });
}
export default useRecorder;

我正在使用上面的钩子开始,停止并生成斑点。一切都在桌面版本中起作用,但是在移动镀铬浏览器中,斑点的长度为0。还有其他方法可以解决它吗?

I am building a simple audio recorder in next js which will send audio blob to server after the recording ends.

import { useEffect, useState } from "react";
const useRecorder = () => {
  const [audioURL, setAudioURL] = useState();
  const [isRecording, setIsRecording] = useState(false);
  const [recorder, setRecorder] = useState(null);
  useEffect(() => {
    // Lazily obtain recorder first time we're recording.
    if (recorder === null) {
      if (isRecording) {
        requestRecorder().then(setRecorder, console.error);
      }
      return;
    }
    // Manage recorder state.
    if (isRecording) {
      recorder?.start();
    } else {
      recorder?.stop();
    }
    // Obtain the audio when ready.
    const handleData = (e) => {
      setAudioURL({
        data: URL.createObjectURL(e.data),
        type: e,
        name: e.name,
      });
    };
    recorder.addEventListener("dataavailable", handleData);
    return () => recorder.removeEventListener("dataavailable", handleData);
  }, [recorder, isRecording]);
  const startRecording = () => {
    setIsRecording(true);
  };
  const stopRecording = () => {
    setIsRecording(false);
  };

  return [audioURL, isRecording, startRecording, stopRecording];
};
async function requestRecorder() {
  const stream = await navigator.mediaDevices.getUserMedia({ audio: true });
  return new MediaRecorder(stream, { type: "audio/x-mpeg-3" });
}
export default useRecorder;

I am using the above hook to start, stop and generating the blob. Everything is working in desktop version but in mobile chrome browser the length of the blob is 0. Is there any other way to solve it?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文