【问题标题】:Speech Synthesis won't pause in google chrome at first load after browser launch语音合成在浏览器启动后首次加载时不会在谷歌浏览器中暂停
【发布时间】:2019-04-05 16:01:24
【问题描述】:

完全杀死浏览器,重新打开浏览器并使用 SpeechSynthesis.speak(string) 启动文本转语音;

speechSynthesis.pause();在您刷新页面之前无法使用。

同样可以看到, https://developer.microsoft.com/en-us/microsoft-edge/testdrive/demos/speechsynthesis/

这发生在 Mac 和 Windows,chrome 70 上。

有人知道解决方法吗?

【问题讨论】:

  • 嗨 - 这里似乎没有问题?如果这是 Chrome 的错误报告,您需要向 Google 报告,而不是在 Stack Overflow 上发布。
  • 不确定这是 Chrome 错误还是语音表达问题。

标签: javascript google-chrome text-to-speech speech-synthesis


【解决方案1】:

有人知道解决方法吗?

如果你先说一个空文本,它会在第一次加载时暂停。

let btnSpeak = document.getElementById("btnSpeak");
let spoken = false;
speechSynthesis.cancel();
function speak() {
    btnSpeak.disabled = true;
    let msg = new SpeechSynthesisUtterance();
    if (!spoken) {
        let mt = new SpeechSynthesisUtterance();
        mt.text = " ";
        window.speechSynthesis.speak(mt);
        spoken = true;
    }
    msg.text = "Use a long sentence to give time to hit pause";
    msg.voice = voices[0];
    msg.lang = voices[0].lang;
    msg.onend = function(event) {
        btnSpeak.disabled = false;
    };
    window.speechSynthesis.speak(msg);
}

【讨论】:

猜你喜欢
  • 2012-01-21
  • 2011-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-01-29
相关资源
最近更新 更多