有没有可能使用Javascript Web Speech API来编写Javascript代码来生成音频文件(wav、ogg或mp3),并在给定的文本中使用语音?我是说,我想这样做:
window.speechSynthesis.speak(new SpeechSynthesisUtterance("0 1 2 3"))但我希望它产生的声音不是输出到扬声器,而是输出到文件中。
发布于 2017-09-27 22:44:02
仅使用Web Speech API是不可能实现此要求的,请参阅Re: MediaStream, ArrayBuffer, Blob audio result from speak() for recording?,How to implement option to return Blob, ArrayBuffer, or AudioBuffer from window.speechSynthesis.speak() call
尽管可能需要使用库,例如espeak或meSpeak,但请参阅How to create or convert text to audio at chromium browser?。
fetch("https://gist.githubusercontent.com/guest271314/f48ee0658bc9b948766c67126ba9104c/raw/958dd72d317a6087df6b7297d4fee91173e0844d/mespeak.js")
.then(response => response.text())
.then(text => {
const script = document.createElement("script");
script.textContent = text;
document.body.appendChild(script);
return Promise.all([
new Promise(resolve => {
meSpeak.loadConfig("https://gist.githubusercontent.com/guest271314/8421b50dfa0e5e7e5012da132567776a/raw/501fece4fd1fbb4e73f3f0dc133b64be86dae068/mespeak_config.json", resolve)
}),
new Promise(resolve => {
meSpeak.loadVoice("https://gist.githubusercontent.com/guest271314/fa0650d0e0159ac96b21beaf60766bcc/raw/82414d646a7a7ef11bb04ddffe4091f78ef121d3/en.json", resolve)
})
])
})
.then(() => {
// takes approximately 14 seconds to get here
console.log(meSpeak.isConfigLoaded());
console.log(meSpeak.speak("what it do my ninja", {
amplitude: 100,
pitch: 5,
speed: 150,
wordgap: 1,
variant: "m7",
rawdata: "mime"
}));
})
.catch(err => console.log(err));
根据系统硬件How to capture generated audio from window.speechSynthesis.speak() call?的不同,还可以解决使用MediaRecorder的问题。
https://stackoverflow.com/questions/38727696
复制相似问题