播放ReadableStream格式二进制流音频

播放ReadableStream格式二进制流音频

接口返回中,body为ReadableStream格式的二进制流

<!DOCTYPE html>
<html>
  <head>
    <title>实时语音生成与播放</title>
  </head>
  <body>
    <h1>输入文本生成语音</h1>
    <textarea id="text-input" rows="4" cols="50"></textarea><br />
    <button onclick="generateAndPlayAudio()">生成并播放语音</button>
    <audio id="audio" controls></audio>
    <script>
      async function generateAndPlayAudio() {
        const text = document.getElementById("text-input").value;
        fetch("http://xxx.xx.xx.xxx:5000/generate_speech", {
          method: "POST",
          headers: {
            "Content-Type": "application/json",
          },
          body: JSON.stringify({ text: text, port: 9880 }),
        })
          .then((response) => {
            console.log("response", response);
            if (response.ok) {
              const reader = response.body.getReader();
              let chunks = [];
              let totalLength = 0;
              const read = () => {
                return reader.read().then(({ done, value }) => {
                  if (done) {
                    return new Blob(chunks, { type: "audio/wav" });
                  }
                  chunks.push(value);
                  totalLength += value.length;
                  return read();
                });
              };
              return read();
            }
          })
          .then((audioBlob) => {
            const audioUrl = URL.createObjectURL(audioBlob);
            console.log("Audio URL:", audioUrl);
            const audioPlayer = document.getElementById("audio");
            audioPlayer.src = audioUrl;
            audioPlayer.play().catch((error) => {
              console.error("Error playing audio:", error);
            });
          });
      }
    </script>
  </body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值