我正在使用HTML5 SpeechSynthesis API编写一个简单的拼写测试应用程序。我希望我的应用程序说出来的文字如下:“拼写单词是Cat。猫追着狗。”
从第一句到第二句,API往往没有太多停顿。我想知道是否有办法在两个句子之间插入一点暂停。我意识到我可以创建2个单独的话语并使用pause()调用。但是,如果我可以简单地插入语法提示,那么代码将更简单,更简单。
通常在英语口语中,人们往往会在段落间停留一段时间。所以我在文本中插入了换行符,但没有明显的影响。
我也试过使用省略号。
有没有办法做到这一点,还是我把一切都分成了单独的话语?
答案 0 :(得分:2)
只需插入
即可<silence msec="5000" />
在文本中等待5秒(Source)。
免责声明:此代码仅适用于适当的用户代理。
// code taken from https://richjenks.com/dev/speechsynthesis/
var utterance = new SpeechSynthesisUtterance(),
speak = document.getElementById("speak"),
text = document.getElementById("text");
// Delay links and events because speechSynthesis is funny
speechSynthesis.getVoices();
setTimeout(function () {
// Add event listeners
var voiceLinks = document.querySelectorAll(".voice");
for (var i = 0; i < voiceLinks.length; i++) {
voiceLinks[i].addEventListener("click", function (event) {
utterance.voice = speechSynthesis.getVoices()[this.dataset.voice];
});
}
}, 100);
// Say text when button is clicked
speak.addEventListener("click", function (event) {
utterance.text = text.value;
speechSynthesis.speak(utterance);
});
<textarea id="text" rows="5" cols="50">Hi <silence msec="2000" /> Flash!</textarea>
<br>
<button id="speak">Speak</button>
答案 1 :(得分:1)
我发现使用逗号插入合成暂停非常有用(作为其他操作)。这里有一些摘录:
var speech = new SpeechSynthesisUtterance(),
$content = document.querySelector('main').cloneNode(true),
$space = $content.querySelectorAll('pre'),
$pause_before = $content.querySelectorAll('h2, h3, h4, h5, h6, p, li, dt, blockquote, pre, figure, footer'),
$skip = $content.querySelectorAll('aside, .dont_read');
// Don’t read
$skip.forEach(function( $el ){
$el.innerHTML = '';
});
// spacing out content
$space.forEach(function($el){
$el.innerHTML = ' ' + $el.innerHTML.replace(/[\r\n\t]/g, ' ') + ' ';
});
// Synthetic Pauses
$pause_before.forEach(function( $el ){
$el.innerHTML = ' , ' + $el.innerHTML;
});
speech.text = $content.textContent;
关键是首先克隆内容节点,以便您可以在内存中使用它而不是操纵实际内容。它似乎对我很好,我可以在JavaScript代码中控制它,而不必修改页面源。
答案 2 :(得分:1)
使用感叹号“!”由于某种原因增加了很好的延迟。
您可以将它们与句点链接在一起以延长暂停时间。
"Example text! . ! . ! . !"
答案 3 :(得分:0)
使用逗号(或自定义分隔符)分隔文本,并使用超时添加自己的空间。
这是一个简单的示例,作为概念验证。扩展它,您可以自定义文本以包括有关暂停时间的提示。
function speakMessage(message, PAUSE_MS = 500) {
try {
const messageParts = message.split(',')
let currentIndex = 0
const speak = (textToSpeak) => {
const msg = new SpeechSynthesisUtterance();
const voices = window.speechSynthesis.getVoices();
msg.voice = voices[0];
msg.volume = 1; // 0 to 1
msg.rate = 1; // 0.1 to 10
msg.pitch = .1; // 0 to 2
msg.text = textToSpeak;
msg.lang = 'en-US';
msg.onend = function() {
currentIndex++;
if (currentIndex < messageParts.length) {
setTimeout(() => {
speak(messageParts[currentIndex])
}, PAUSE_MS)
}
};
speechSynthesis.speak(msg);
}
speak(messageParts[0])
} catch (e) {
console.error(e)
}
}
function run(pause) {
speakMessage('Testing 1,2,3', pause)
}
<button onclick='run(0)'>Speak No Pause</button>
<button onclick='run(500)'>Speak Pause</button>
<button onclick='run(1000)'>Speak Pause Longer</button>