Javascript本地语言文本转语音

时间:2014-05-29 12:21:22

标签: javascript jquery html5 text-to-speech google-text-to-speech

我正在为学校做一个项目,我们将教孩子们第一次进行计算。 不幸的是,这些孩子无法阅读,因此任务将以母语与他们交谈,在本例中为荷兰语。

我一直在四处寻找,大多数文本到语音的javascript库都为英语提供了很好的支持,但对其他任何语言都没有。 HTML5 speechSynthesis也不支持Dutch:

Speech synthesis voices currently supported in Chrome 35

在进一步的研究中,我发现了一篇文章,您可以使用谷歌翻译语音将任何文本生成语音。

您将此作为基本网址: http://translate.google.com/translate_tts

在我的案例荷兰语

中附上您想要的语言

http://translate.google.com/translate_tts?tl=nl

并附上你的文字:

"This is a test" translated to Dutch

您希望这可以使用更长的文本,但它不会。

Text to speech which is not working

还有其他解决方案吗?谷歌语音很好地说荷兰语,所以我希望链接以某种方式工作。

1 个答案:

答案 0 :(得分:3)

免责声明:Google可能不允许这样做。未经Google许可,请勿使用此功能。

可以使用谷歌的文本语音与任何大小的文本。它需要稍微调整一下。

这是脚本:

function textToSpeech(text, language) {
    if(text === undefined || text === null || text.length === 0)
        return

    var vid = document.createElement("video")
    var textParts = []

    text.split(" ").forEach(function(word) {
        var textPartsIndex = textParts.length - 1
        var currentStr = textParts[textPartsIndex]
        if(currentStr !== undefined && currentStr.length + word.length < 100)
            textParts[textPartsIndex] += " " + word
        else
            textParts.push(word)
    })

    function play(txt) {
        vid.src = "http://translate.google.com/translate_tts?tl=" + language + "&q=" + txt
        vid.load()
        vid.play()
    }

    var partIndex = 0
    play(textParts[partIndex])

    vid.addEventListener("ended", function() {
        var part = textParts[++partIndex]
        if(part !== undefined)
            play(part)
        else
            vid.removeEventListener("ended")
    })
}

在使用之前,您必须关闭所有Chrome浏览器实例,然后在Windows计算机上打开“运行”(WIN + R)并输入“chrome --no-referrers”,而不是“

在你的页面上,你现在可以写(我不懂荷兰语,所以它只是我找到的一些示例文本)

textToSpeech("Ik ga ervan uit dat de mens een groot vermogen bezit om externe informatie op te slorpen ,\" legt professor Georges uit . Hij kan zelfs 5 tot 6 maal méér informatie verwerken dan het debiet van het gesproken woord , 120 woorden per minuut . Teamgeest is voor mij geen ijdel woord . In de tweede plaats komen puur betekenisloze verhaspelingen niet in aanmerking , want die zijn niet ontstaan door verwarring met een ander woord .", "nl")

如果您的应用程序仅在本地运行,即未托管,则不必使用--no-referrers命令运行chrome。

停用推荐人的原因是,如果有推荐人标题,Google会取消您的请求。

不需要的IFRAME版本 - 没有推荐人

http://jsfiddle.net/9tTeg/

<body>
<script>
textToSpeech("Ik ga ervan uit dat de mens een groot vermogen bezit om externe informatie op te slorpen ,\" legt professor Georges uit . Hij kan zelfs 5 tot 6 maal méér informatie verwerken dan het debiet van het gesproken woord , 120 woorden per minuut . Teamgeest is voor mij geen ijdel woord . In de tweede plaats komen puur betekenisloze verhaspelingen niet in aanmerking , want die zijn niet ontstaan door verwarring met een ander woord .", "nl")

function textToSpeech(text, language) {
    if(text === undefined || text === null || text.length === 0)
        return

    var vid = document.createElement("iframe")
    document.body.appendChild(vid)
    var textParts = []

    text.split(" ").forEach(function(word) {
        var textPartsIndex = textParts.length - 1
        var currentStr = textParts[textPartsIndex]
        if(currentStr !== undefined && currentStr.length + word.length < 100)
            textParts[textPartsIndex] += " " + word
        else
            textParts.push(word)
    })

    function play(txt) {
        vid.src = "http://translate.google.com/translate_tts?tl=" + language + "&q=" + txt
    }

    var partIndex = 0
    play(textParts[partIndex])

    var intervalId = setInterval(function() {
        var part = textParts[++partIndex]
        if(part !== undefined)
            play(part)
        else
            clearInterval(intervalId)       
    }, 9000)
}
</script>
</body>

改进:不使用单词分隔字符串,而是使用点和逗号,因此暂停更自然。每个部分当前每个播放9秒,但如果单词按点和逗号分组,您可以通过查看部分的长度来计算每个部分的时间,因为9秒可能太多了