SayIt Adapter can convert text to speech and play it on some device.
Actual following outputs are supported:
-
Browser - the text will be played by browser with opened iobroker.vis page. It is supported almost by every desktop browser and by few mobily Browsers.
-
Home24- MediaPlayer - the text will be sent and played to the Android device with Home24 - MediaPlayer installed. For this will be used build in Android text to speech engine. The port cannot be changed and set to 50000.
-
Home24 - MediaPlayer and FTP Server - the text will be sent and played on the Android device with Home24 - MediaPlayer installed. For this will be used the Google text to speech engine. Generated mp3 file will be copied over FTP to android device and played with Home24 - MediaPlayer. Both apps have to have same home directories. (E.g. root directory of "sd card").
-
System - the text will be played by OS, where the ioBroker adapter runs. Following OS are supported: Windows, linux, Mac OSx.
-
Windows engine - the text will be played by windows, where the sayIt adapter runs. For this will be used windows text to speech engine, that should be preconfigured by user. You can check here how to setup it.
-
Sonos - play text on sonos device. Be sure the Web Adapter is enabled. It is required to enable SONOS to read the generated mp3 files.
-
Chromecast - play text on Chromecast device.
-
MPD - play text on Music Player Daemon. Use only http for web adapter, don't use https.
To enable the text to speech on RaspberryPI or linux system call one time following command sudo apt-get -y install mpg321
to install mpg321.
The mp3/wav files can be played to by writing its name into the object. (e.g. "/vis.0/main/img/door-bell.mp3")
The file must be first loaded.
online:
- Google: English, German, Russian, Italian, Spanish, French
- Yandex: Russian
To use Yandex voices you must request the API key here: https://tech.yandex.ru/speechkit/cloud/doc/dg/concepts/About-docpage/. [This service will be disabled 1st of Jan 2019 and replaced by Yandex.cloud] To use Yandex.cloud you should register here: [https://cloud.yandex.ru/], install SpeechKIT API in the Cloud and get Auth Token and Folder ID as described in API instructions. - Ivona: English, German, Russian, Italian, Spanish, French, Dansk, Welsh, Icelandic, Dutch, Polish, Portuguese, Romanian, Swedish, Turkish
To use Amazon(Ivona) voices you need to get access key and secret key here. - Cloud: To use Cloud voices you need configured cloud adapter. (It can be disabled, but must be configured). This service use AWS Polly and it can be used directly.
- Amazon Web Services Polly: To use AWS Polly voices you need to create access key and secret key here. The Amazon documentation can you find here.
offline:
- PicoTTS (linux only): English, German, Italian, Spanish, French
For PicoTTS it is necessary to install the following packages: libttspico-utils and lame.
Installation command: 'sudo apt-get install libttspico-utils lame'
You can format your text with Speech Synthesis Markup Language.
Most useful features:
<break time="3s"/>
- make a pause for x seconds (max 10 seconds).<emphasis> big </emphasis>
- make an emphasis on some word.<prosody volume="+6dB" rate="90%">I am speaking this</prosody>
- control speed and volume parameters.<say-as interpret-as="digits">12345</say-as>
- say every digit separately.
More info.
If you have some program, that can play audio files locally or somewhere else, you can write this command here. E.g.
myCustomPlayer --option
If System output is selected, the sayit adapter will execute following command on local system:
myCustomPlayer --option /opt/iobroker/node_modules/iobroker.sayit/say.mp3
If file name must stay somewhere in the middle you can use %s to specify where the file name must be placed:
myCustomPlayer --option "%s" > /dev/null
sayIt will make myCustomPlayer --option "/opt/iobroker/node_modules/iobroker.sayit/say.mp3" > /dev/null
from it.
SayIt adapter cannot be used alone. It must be controlled from javascript adapter or from "vis" with specific widget. After creation of adapter instance will can find following objects:
- sayit.N.tts.text: Phrase to be spoken.
- sayit.N.tts.volume: volume which will be used by playing of the phrase.
- sayit.N.tts.playing: true if text is now playing and false if not. Supported only for "windows" and "system" play mode.
- sayit.N.tts.cachetext: Phrase to be cached and then it can be used without internet. E.g. you can enter here manually "No internet" and if ping to google.com is negative, write "No internet" to "tts.text" and it will pronounced. Of course cache must be enabled.
State tts.text supports extended syntax, so the langugage/engine and volume can be defined together with text. It is used to enable multi-language text2speech engines.
E.g. if adapter has engine "Google-english", it is possible with phrase de:Sag es
to force to use Google-Deustch speech engine.
With ru;75;Погода хорошая
we can force to use russian language and volume 75%.
You can specify the volume of announcement in percent from current or given volume (not from maximal). E.g. if command is de;75;Gutes Wetter
and "announce volume" is 50%, the announce will be played with volume 38% from 100% possible.
The system command to play the mp3 file can be specified too. If you leave it blank, the default settings will be used: windows - cmdmp3.exe, OSX - /usr/bin/afplay, linux - mpg321 or omxplayer (recommended).
To install omxplayer write sudo apt-get install omxplayer
or write sudo apt-get install mpg321
to install mpg321.
Note: The default announce selection will be possible only after start of the instance.
To immediately pronounce the text despite the queued texts you have 2 possibilities:
- place "!" as a first character in text, so this text will be pronounced immediately after current one.
- write true into "tts.clearQueue" state and the queue will be cleared. After that you can write a new text into "tts.text", but all queued texts are thrown away.
Following values for engines are possible:
- en - English
- de - Deutsch
- ru - Русский
- it - Italiano
- es - Espaniol
- fr - Français
- ru_YA:Yandex - Русский
- ru_YA_CLOUD:Yandex Cloud - Русский [Yandex.Cloud API generates files in OGG format. To play ogg files on linux mplayer should be installed and selected as system player]
- ru-RU_CLOUD_Female - Русский - Татьяна
- ru-RU_CLOUD_Male - Русский - Максим
- de-DE_CLOUD_Female - Deutsch - Marlene
- de-DE_CLOUD_Male - Deutsch - Hans
- en-US_CLOUD_Female - en-US - Female - Salli
- en-US_CLOUD_Male - en-US - Male - Joey
- da-DK_CLOUD_Female - da-DK - Female - Naja
- da-DK_CLOUD_Male - da-DK - Male - Mads
- en-AU_CLOUD_Female - en-AU - Female - Nicole
- en-AU_CLOUD_Male - en-AU - Male - Russell
- en-GB_CLOUD_Female_Amy - en-GB - Female - Amy
- en-GB_CLOUD_Male - en-GB - Male - Brian
- en-GB_CLOUD_Female_Emma - en-GB - Female - Emma
- en-GB-WLS_CLOUD_Female - en-GB-WLS - Female - Gwyneth
- en-GB-WLS_CLOUD_Male - en-GB-WLS - Male - Geraint
- cy-GB_CLOUD_Female - cy-GB - Female - Gwyneth
- cy-GB_CLOUD_Male - cy-GB - Male - Geraint
- en-IN_CLOUD_Female - en-IN - Female - Raveena
- en-US_CLOUD_Male_Chipmunk - en-US - Male - Chipmunk
- en-US_CLOUD_Male_Eric - en-US - Male - Eric
- en-US_CLOUD_Female_Ivy - en-US - Female - Ivy
- en-US_CLOUD_Female_Jennifer - en-US - Female - Jennifer
- en-US_CLOUD_Male_Justin - en-US - Male - Justin
- en-US_CLOUD_Female_Kendra - en-US - Female - Kendra
- en-US_CLOUD_Female_Kimberly - en-US - Female - Kimberly
- es-ES_CLOUD_Female - es-ES - Female - Conchita
- es-ES_CLOUD_Male - es-ES - Male - Enrique
- es-US_CLOUD_Female - es-US - Female - Penelope
- es-US_CLOUD_Male - es-US - Male - Miguel
- fr-CA_CLOUD_Female - fr-CA - Female - Chantal
- fr-FR_CLOUD_Female - fr-FR - Female - Celine
- fr-FR_CLOUD_Male - fr-FR - Male - Mathieu
- is-IS_CLOUD_Female - is-IS - Female - Dora
- is-IS_CLOUD_Male - is-IS - Male - Karl
- it-IT_CLOUD_Female - it-IT - Female - Carla
- it-IT_CLOUD_Male - it-IT - Male - Giorgio
- nb-NO_CLOUD_Female - nb-NO - Female - Liv
- nl-NL_CLOUD_Female - nl-NL - Female - Lotte
- nl-NL_CLOUD_Male - nl-NL - Male - Ruben
- pl-PL_CLOUD_Female_Agnieszka - pl-PL - Female - Agnieszka
- pl-PL_CLOUD_Male_Jacek - pl-PL - Male - Jacek
- pl-PL_CLOUD_Female_Ewa - pl-PL - Female - Ewa
- pl-PL_CLOUD_Male_Jan - pl-PL - Male - Jan
- pl-PL_CLOUD_Female - pl-PL - Female - Maja
- pt-BR_CLOUD_Female - pt-BR - Female - Vitoria
- pt-BR_CLOUD_Male - pt-BR - Male - Ricardo
- pt-PT_CLOUD_Male - pt-PT - Male - Cristiano
- pt-PT_CLOUD_Female - pt-PT - Female - Ines
- ro-RO_CLOUD_Female - ro-RO - Female - Carmen
- sv-SE_CLOUD_Female - sv-SE - Female - Astrid
- tr-TR_CLOUD_Female - tr-TR - Female - Filiz
- en-US - Englisch US
- en-GB - Englisch GB
- de-DE - Deutsch
- it-IT - Italiano
- es-ES - Espaniol
- fr-FR - Français
- (ru-RU_AP_Female) - Русский - Татьяна
- (ru-RU_AP_Male) - Русский - Максим
- (de-DE_AP_Female) - Deutsch - Marlene
- (de-DE_AP_Male) - Deutsch - Hans
- (en-US_AP_Female) - en-US - Female - Salli
- (en-US_AP_Male) - en-US - Male - Joey
- (da-DK_AP_Female) - da-DK - Female - Naja
- (da-DK_AP_Male) - da-DK - Male - Mads
- (en-AU_AP_Female) - en-AU - Female - Nicole
- (en-AU_AP_Male) - en-AU - Male - Russell
- (en-GB_AP_Female_Amy) - en-GB - Female - Amy
- (en-GB_AP_Male) - en-GB - Male - Brian
- (en-GB_AP_Female_Emma) - en-GB - Female - Emma
- (en-GB-WLS_AP_Female) - en-GB-WLS - Female - Gwyneth
- (en-GB-WLS_AP_Male) - en-GB-WLS - Male - Geraint
- (cy-GB_AP_Female) - cy-GB - Female - Gwyneth
- (cy-GB_AP_Male) - cy-GB - Male - Geraint
- (en-IN_AP_Female) - en-IN - Female - Raveena
- (en-US_AP_Male_Chipmunk) - en-US - Male - Chipmunk
- (en-US_AP_Male_Eric) - en-US - Male - Eric
- (en-US_AP_Female_Ivy) - en-US - Female - Ivy
- (en-US_AP_Female_Jennifer) - en-US - Female - Jennifer
- (en-US_AP_Male_Justin) - en-US - Male - Justin
- (en-US_AP_Female_Kendra) - en-US - Female - Kendra
- (en-US_AP_Female_Kimberly) - en-US - Female - Kimberly
- (es-ES_AP_Female) - es-ES - Female - Conchita
- (es-ES_AP_Male) - es-ES - Male - Enrique
- (es-US_AP_Female) - es-US - Female - Penelope
- (es-US_AP_Male) - es-US - Male - Miguel
- (fr-CA_AP_Female) - fr-CA - Female - Chantal
- (fr-FR_AP_Female) - fr-FR - Female - Celine
- (fr-FR_AP_Male) - fr-FR - Male - Mathieu
- (is-IS_AP_Female) - is-IS - Female - Dora
- (is-IS_AP_Male) - is-IS - Male - Karl
- (it-IT_AP_Female) - it-IT - Female - Carla
- (it-IT_AP_Male) - it-IT - Male - Giorgio
- (nb-NO_AP_Female) - nb-NO - Female - Liv
- (nl-NL_AP_Female) - nl-NL - Female - Lotte
- (nl-NL_AP_Male) - nl-NL - Male - Ruben
- (pl-PL_AP_Female_Agnieszka) - pl-PL - Female - Agnieszka
- (pl-PL_AP_Male_Jacek) - pl-PL - Male - Jacek
- (pl-PL_AP_Female_Ewa) - pl-PL - Female - Ewa
- (pl-PL_AP_Male_Jan) - pl-PL - Male - Jan
- (pl-PL_AP_Female) - pl-PL - Female - Maja
- (pt-BR_AP_Female) - pt-BR - Female - Vitoria
- (pt-BR_AP_Male) - pt-BR - Male - Ricardo
- (pt-PT_AP_Male) - pt-PT - Male - Cristiano
- (pt-PT_AP_Female) - pt-PT - Female - Ines
- (ro-RO_AP_Female) - ro-RO - Female - Carmen
- (sv-SE_AP_Female) - sv-SE - Female - Astrid
- (tr-TR_AP_Female) - tr-TR - Female - Filiz
- (bluefox) Priority for the text was added
- (BuZZy1337) fixed error in Blockly-Block
- (bluefox) Ivona removed
- (bluefox) Error was fixed by upload of file to FTP
- (bluefox) admin3
- (BuZZy1337) Generate separate mp3 files for each instance.
- Fixes Issue#34
- (BuZZy1337) Always upload mp3 files to the state sayit.X.tts.mp3
- (Apollon77) Remove unneeded logging
- (bondrogeen) Admin3 Fixes
- (angelnu) Wait for Google Home announcement to complete
- (bluefox) Fix cloud .pro
- (bluefox) Fix system commands
- (bluefox) Code refactoring
- (bluefox) Add google home as output
- (bluefox) Remove ivona because not more supported
- (bluefox) Catch error if some directory in mp3 folder
- (bluefox) Fix blockly language
- (DarkChaos) Add AWS Polly as source
- (bluefox) Add cloud as source
- (bluefox) fix install problem
- (bluefox) add PicoTTS as source
- (bluefox) show only installed instances in blockly
- (angelnu) changes for new chromecast tts
- (bluefox) small fix of config dialog
- (AirKing555) Fix Volume change
- (instalator) add mpd
- (bluefox) Fix cache
- (bluefox) Finish sayit
- (bluefox) Fix changing of engine
- (bluefox) Add omxplayer option
- (bluefox) support of blockly
- (bluefox) Make the type of mp3 as file
- (Vegetto) Support for Chromecast devices
- (bluefox) enable play of mp3 files from disk
- (bluefox) fill default settings by first start
- (bluefox) fix error with sayItWindows
- (bluefox) fix error with sayItSystem
- (bluefox) fix error if received mp3 file is too short
- (bluefox) try to implement cache datapoint (you can use sayit.0.tts.cachetext to create cache for phrases and use sayit without internet)
- (bluefox) change google requests from http to https
- (bluefox) add new voice Russian-Maxim
- (bluefox) fix error with mp24ftp
- (bluefox) fix error by mediaplayer24
- (bluefox) make the volume for announce configurable
- (bluefox) make the command for "system" configurable
- (bluefox) fix volume for announce
- (bluefox) support of play files from internal filesystem, like "/sayit.0/tts.userfiles/myGong.mp3"
- (bluefox) fix error with volume by sonos
- (bluefox) fix error in announcement
- (bluefox) fix error in announcement
- (bluefox) enable announcement
- (bluefox) clear cache if engine changed
- (bluefox) fix small error with log
- (bluefox) add ivona/Amazon voices
- (bluefox) fix error by buffering of non-generated texts.
- (bluefox) fix error by buffering of non-generated texts.
- (bluefox) add yandex-russian support
- (bluefox) queue texts
- (bluefox) initial commit
The MIT License (MIT)
Copyright (c) 2014-2018, bluefox[email protected]
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.