Security News
Weekly Downloads Now Available in npm Package Search Results
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.
npm install speak-tts
Speech synthesis (tts) for the browser with (optional) language detection. Based on browser SpeechSynthesis API, it improves it by handling some quirks and bugs of IOS/android devices and some chrome versions. Also split sentences into several speeches to make it sound more natural and provides additional callback functions. Work in Chrome, opera and Safari (including ios8 and ios9 devices). Tested successfully on Ipad and Android. See browser support here : http://caniuse.com/#feat=speech-synthesis
Here is a demo: Here
Import the component :
import Speech from 'speak-tts' // es6
// var Speech = require('speak-tts') //if you use es5
Start the component :
Speech.init()
You can pass the following properties at init time:
lang
will be used// Example with full conf
Speech.init({
'onVoicesLoaded': (data) => {console.log('voices', data.voices)},
'lang': 'en-US', // specify en-US language (no detection applied)
'volume': 0.5,
'rate': 0.8,
'pitch': 0.8,
'voice': 'Samantha'
})
Check browser support :
if(Speech.browserSupport()) {
console.log("speech synthesis supported")
}
Read a text :
Speech.speak({
text: 'Hello, how are you today ?',
onError: (e) => {console.log('sorry an error occurred.', e)}, // optionnal error callback
onEnd: () => {console.log('your text has successfully been spoken.')} // optionnal onEnd callback
})
Set language (note that the language must be supported by the client browser) :
Speech.setLanguage('en-US') // set language to US English
Speech.setLanguage(null) // activate language auto-detection
Set the voice (note that the voice must be supported by the client browser) :
Speech.setVoice('Fiona') // set voice to 'Fiona'
Stop talking:
Speech.stop()
ar-SA
cs-CZ
da-DK
de-DE
el-GR
en
en-AU
en-GB
en-IE
en-IN
en-US
en-ZA
es-AR
es-ES
es-MX
es-US
fi-FI
fr-CA
fr-FR
he-IL
hi-IN
hu-HU
id-ID
it-IT
ja-JP
ko-KR
nb-NO
nl-BE
nl-NL
pl-PL
pt-BR
pt-PT
ro-RO
ru-RU
sk-SK
sv-SE
th-TH
tr-TR
zh-CN
zh-HK
zh-TW
Alex
Alice
Alva
Amelie
Anna
Carmit
Damayanti
Daniel
Diego
Ellen
Fiona
Fred
Ioana
Joana
Jorge
Juan
Kanya
Karen
Kyoko
Laura
Lekha
Luca
Luciana
Maged
Mariska
Mei-Jia
Melina
Milena
Moira
Monica
Nora
Paulina
Samantha
Sara
Satu
Sin-ji
Tessa
Thomas
Ting-Ting
Veena
Victoria
Xander
Yelda
Yuna
Yuri
Zosia
Zuzana
Google Deutsch
Google US English
Google UK English Female
Google UK English Male
Google español
Google español de Estados Unidos
Google français
Google हिन्दी
Google Bahasa Indonesia
Google italiano
Google 日本語
Google 한국의
Google Nederlands
Google polski
Google português do Brasil
Google русский
Google 普通话(中国大陆)
Google 粤語(香港)
Google 國語(臺灣)
import Speech from 'speak-tts'
const _addVoicesList = (voices) => {
const list = window.document.createElement('div')
let html = '<h2>Available Voices</h2><select id="languages"><option value="">autodetect language</option>'
voices.forEach((voice) => {
html += `<option value="${voice.lang}" data-name="${voice.name}">${voice.name} (${voice.lang})</option>`
})
list.innerHTML = html
window.document.body.appendChild(list)
}
function _prepareSpeakButton() {
const speakButton = document.getElementById('play')
const textarea = document.getElementById('text')
const languages = document.getElementById('languages')
speakButton.addEventListener('click', () => {
Speech.setLanguage(languages.value)
Speech.setVoice(languages.options[languages.selectedIndex].dataset.name)
Speech.speak({
text: textarea.value,
onEnd: () => {
console.log('end of text')
}
})
})
}
Speech.init({
onVoicesLoaded: (data) => {
console.log("loaded voices", data.voices)
_addVoicesList(data.voices)
_prepareSpeakButton()
Speech.speak({
text: 'Hello, how are you today ?',
onEnd: () => {
console.log('end of text')
},
})
}
});
const text = (Speech.browserSupport()) ? 'Hurray, your browser supports speech synthesis' : "Your browser does NOT support speech synthesis. Try using Chrome of Safari instead !"
document.getElementById("support").innerHTML = text
These will be added soon. Please do not hesitate to add some !
I am a full-stack Javascript developer based in Lyon, France.
speak-tts is dual licensed under the MIT license and GPL. For more information click here.
FAQs
Browser TTS (using Web speech API) made easy
The npm package speak-tts receives a total of 2,391 weekly downloads. As such, speak-tts popularity was classified as popular.
We found that speak-tts demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.
Security News
A Stanford study reveals 9.5% of engineers contribute almost nothing, costing tech $90B annually, with remote work fueling the rise of "ghost engineers."
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.