Up to date
This page is up to date for Redot 4.3
.
If you still find outdated information, please create an issue.
Text to speech
Basic Usage
Basic usage of text-to-speech involves the following one-time steps:
Enable TTS in the Redot editor for your project
Query the system for a list of usable voices
Store the ID of the voice you want to use
By default, the Redot project-level setting for text-to-speech is disabled, to avoid unnecessary overhead. To enable it:
Go to Project > Project Settings
Make sure the Advanced Settings toggle is enabled
Click on Audio > General
Ensure the Text to Speech option is checked
Restart Redot if prompted to do so.
Text-to-speech uses a specific voice. Depending on the user's system, they might have multiple voices installed. Once you have the voice ID, you can use it to speak some text:
# One-time steps.
# Pick a voice. Here, we arbitrarily pick the first English voice.
var voices = DisplayServer.tts_get_voices_for_language("en")
var voice_id = voices[0]
# Say "Hello, world!".
DisplayServer.tts_speak("Hello, world!", voice_id)
# Say a longer sentence, and then interrupt it.
# Note that this method is asynchronous: execution proceeds to the next line immediately,
# before the voice finishes speaking.
var long_message = "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur"
DisplayServer.tts_speak(long_message, voice_id)
# Immediately stop the current text mid-sentence and say goodbye instead.
DisplayServer.tts_stop()
DisplayServer.tts_speak("Goodbye!", voice_id)
// One-time steps.
// Pick a voice. Here, we arbitrarily pick the first English voice.
string[] voices = DisplayServer.TtsGetVoicesForLanguage("en");
string voiceId = voices[0];
// Say "Hello, world!".
DisplayServer.TtsSpeak("Hello, world!", voiceId);
// Say a longer sentence, and then interrupt it.
// Note that this method is asynchronous: execution proceeds to the next line immediately,
// before the voice finishes speaking.
string longMessage = "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur";
DisplayServer.TtsSpeak(longMessage, voiceId);
// Immediately stop the current text mid-sentence and say goodbye instead.
DisplayServer.TtsStop();
DisplayServer.TtsSpeak("Goodbye!", voiceId);
Requirements for functionality
Redot includes text-to-speech functionality. You can find these under the DisplayServer class.
Redot depends on system libraries for text-to-speech functionality. These libraries are installed by default on Windows and macOS, but not on all Linux distributions. If they are not present, text-to-speech functionality will not work. Specifically, the tts_get_voices()
method will return an empty list, indicating that there are no usable voices.
Both Redot users on Linux and end-users on Linux running Redot games need to ensure that their system includes the system libraries for text-to-speech to work. Please consult the table below or your own distribution's documentation to determine what libraries you need to install.
Distro-specific one-liners
Arch Linux |
pacman -S speech-dispatcher festival espeakup
|
Troubleshooting
If you get the error Invalid get index '0' (on base: 'PackedStringArray'). for the line var voice_id = voices[0], check if there are any items in voices. If not:
All users: make sure you enabled Text to Speech in project settings
Linux users: ensure you installed the system-specific libraries for text to speech
Best practices
The best practices for text-to-speech, in terms of the ideal player experience for blind players, is to send output to the player's screen reader. This preserves the choice of language, speed, pitch, etc. that the user set, as well as allows advanced features like allowing players to scroll backward and forward through text. As of now, Redot doesn't provide this level of integration.
With the current state of the Redot text-to-speech APIs, best practices include:
Develop the game with text-to-speech enabled, and ensure that everything sounds correct
Allow players to control which voice to use, and save/persist that selection across game sessions
Allow players to control the speech rate, and save/persist that selection across game sessions
This provides your blind players with the most flexibility and comfort available when not using a screen reader, and minimizes the chance of frustrating and alienating them.
Caveats and Other Information
Expect delays when you call tts_speak and tts_stop. The actual delay time varies depending on both the OS and on your machine's specifications. This is especially critical on Android and Web, where some of the voices depend on web services, and the actual time to playback depends on server load, network latency, and other factors.
Non-English text works if the correct voices are installed and used. On Windows, you can consult the instructions in this article to enable additional language voices on Windows.
Non-ASCII characters, such as umlaut, are pronounced correctly if you select the correct voice.
Blind players use a number of screen readers, including JAWS, NVDA, VoiceOver, Narrator, and more.
Windows text-to-speech APIs generally perform better than their equivalents on other systems (e.g. tts_stop followed by tts_speak immediately speaks the new message).