Description
Use the chrome.tts
API to play synthesized text-to-speech (TTS). See also the related ttsEngine
API, which allows an extension to implement a speech engine.
Chrome provides this capability on Windows (using SAPI 5), Mac OS X, and ChromeOS, using speech synthesis capabilities provided by the operating system. On all platforms, the user can install extensions that register themselves as alternative speech engines.
Permissions
tts
Concepts and usage
Generate speech
Call speak()
from your extension to speak. For example:
chrome.tts.speak('Hello, world.');
To stop speaking immediately, just call stop()
:
chrome.tts.stop();
You can provide options that control various properties of the speech, such as its rate, pitch, and more. For example:
chrome.tts.speak('Hello, world.', {'rate': 2.0});
It's also a good idea to specify the language so that a synthesizer supporting that language (and regional dialect, if applicable) is chosen.
chrome.tts.speak('Hello, world.', {'lang': 'en-US', 'rate': 2.0});
By default, each call to speak()
interrupts any ongoing speech and speaks immediately. To
determine if a call would be interrupting anything, you can call isSpeaking()
. In addition, you
can use the enqueue
option to cause this utterance to be added to a queue of utterances that will
be spoken when the current utterance has finished.
chrome.tts.speak('Speak this first.');
chrome.tts.speak(
'Speak this next, when the first sentence is done.', {'enqueue': true});
A complete description of all options can be found under tts.speak()
. Not all speech
engines will support all options.
To catch errors and make sure you're calling speak()
correctly, pass a callback function that
takes no arguments. Inside the callback, check runtime.lastError
to see if there were any
errors.
chrome.tts.speak(
utterance,
options,
function() {
if (chrome.runtime.lastError) {
console.log('Error: ' + chrome.runtime.lastError.message);
}
}
);
The callback returns right away, before the engine has started generating speech. The purpose of the callback is to alert you to syntax errors in your use of the TTS API, not to catch all possible errors that might occur in the process of synthesizing and outputting speech. To catch these errors too, you need to use an event listener, described in the next section.
Listen to events
To get more real-time information about the status of synthesized speech, pass an event listener in
the options to speak()
, like this:
chrome.tts.speak(
utterance,
{
onEvent: function(event) {
console.log('Event ' + event.type + ' at position ' + event.charIndex);
if (event.type == 'error') {
console.log('Error: ' + event.errorMessage);
}
}
},
callback
);
Each event includes an event type, the character index of the current speech relative to the utterance, and for error events, an optional error message. The event types are:
'start'
: The engine has started speaking the utterance.'word'
: A word boundary was reached. Useevent.charIndex
to determine the current speech position.'sentence'
: A sentence boundary was reached. Useevent.charIndex
to determine the current speech position.'marker'
: An SSML marker was reached. Useevent.charIndex
to determine the current speech position.'end'
: The engine has finished speaking the utterance.'interrupted'
: This utterance was interrupted by another call tospeak()
orstop()
and did not finish.'cancelled'
: This utterance was queued, but then cancelled by another call tospeak()
orstop()
and never began to speak at all.'error'
: An engine-specific error occurred and this utterance cannot be spoken. Checkevent.errorMessage
for details.
Four of the event types—'end'
, 'interrupted'
, 'cancelled'
, and 'error'
—are final. After
one of those events is received, this utterance will no longer speak and no new events from this
utterance will be received.
Some voices may not support all event types, and some voices may not send any events at all. If you
don't want to use a voice unless it sends certain events, pass the events you require in the
requiredEventTypes
member of the options object, or use getVoices()
to choose a voice that meets
your requirements. Both are described in what follows.
SSML markup
Utterances used in this API may include markup using the Speech Synthesis Markup Language
(SSML). If you use SSML, the first argument to speak()
should be a complete SSML document with
an XML header and a top-level <speak>
tag, not a document fragment.
For example:
chrome.tts.speak(
'<?xml version="1.0"?>' +
'<speak>' +
' The <emphasis>second</emphasis> ' +
' word of this sentence was emphasized.' +
'</speak>'
);
Not all speech engines will support all SSML tags, and some may not support SSML at all, but all engines are required to ignore any SSML they don't support and to still speak the underlying text.
Choose a voice
By default, Chrome chooses the most appropriate voice for each utterance you want to speak, based on the language. On most Windows, Mac OS X, and ChromeOS systems, speech synthesis provided by the operating system should be able to speak any text in at least one language. Some users may have a variety of voices available, though, from their operating system and from speech engines implemented by other Chrome extensions. In those cases, you can implement custom code to choose the appropriate voice, or to present the user with a list of choices.
To get a list of all voices, call getVoices()
and pass it a function that receives an array of
TtsVoice
objects as its argument:
chrome.tts.getVoices(
function(voices) {
for (var i = 0; i < voices.length; i++) {
console.log('Voice ' + i + ':');
console.log(' name: ' + voices[i].voiceName);
console.log(' lang: ' + voices[i].lang);
console.log(' extension id: ' + voices[i].extensionId);
console.log(' event types: ' + voices[i].eventTypes);
}
}
);
Types
EventType
Enum
"start"
"end"
"word"
"sentence"
"marker"
"interrupted"
"cancelled"
"error"
"pause"
"resume"
TtsEvent
An event from the TTS engine to communicate the status of an utterance.
Properties
-
charIndex
number optional
The index of the current character in the utterance. For word events, the event fires at the end of one word and before the beginning of the next. The
charIndex
represents a point in the text at the beginning of the next word to be spoken. -
errorMessage
string optional
The error description, if the event type is
error
. -
length
number optional
Chrome 74+The length of the next part of the utterance. For example, in a
word
event, this is the length of the word which will be spoken next. It will be set to -1 if not set by the speech engine. -
type
The type can be
start
as soon as speech has started,word
when a word boundary is reached,sentence
when a sentence boundary is reached,marker
when an SSML mark element is reached,end
when the end of the utterance is reached,interrupted
when the utterance is stopped or interrupted before reaching the end,cancelled
when it's removed from the queue before ever being synthesized, orerror
when any other error occurs. When pausing speech, apause
event is fired if a particular utterance is paused in the middle, andresume
if an utterance resumes speech. Note that pause and resume events may not fire if speech is paused in-between utterances.
TtsOptions
The speech options for the TTS engine.
Properties
-
desiredEventTypes
string[] optional
The TTS event types that you are interested in listening to. If missing, all event types may be sent.
-
enqueue
boolean optional
If true, enqueues this utterance if TTS is already in progress. If false (the default), interrupts any current speech and flushes the speech queue before speaking this new utterance.
-
extensionId
string optional
The extension ID of the speech engine to use, if known.
-
gender
VoiceGender optional
Deprecated since Chrome 77Gender is deprecated and will be ignored.
Gender of voice for synthesized speech.
-
lang
string optional
The language to be used for synthesis, in the form language-region. Examples: 'en', 'en-US', 'en-GB', 'zh-CN'.
-
pitch
number optional
Speaking pitch between 0 and 2 inclusive, with 0 being lowest and 2 being highest. 1.0 corresponds to a voice's default pitch.
-
rate
number optional
Speaking rate relative to the default rate for this voice. 1.0 is the default rate, normally around 180 to 220 words per minute. 2.0 is twice as fast, and 0.5 is half as fast. Values below 0.1 or above 10.0 are strictly disallowed, but many voices will constrain the minimum and maximum rates further—for example a particular voice may not actually speak faster than 3 times normal even if you specify a value larger than 3.0.
-
requiredEventTypes
string[] optional
The TTS event types the voice must support.
-
voiceName
string optional
The name of the voice to use for synthesis. If empty, uses any available voice.
-
volume
number optional
Speaking volume between 0 and 1 inclusive, with 0 being lowest and 1 being highest, with a default of 1.0.
-
onEvent
void optional
This function is called with events that occur in the process of speaking the utterance.
The
onEvent
function looks like:(event: TtsEvent) => {...}
-
event
The update event from the text-to-speech engine indicating the status of this utterance.
-
TtsVoice
A description of a voice available for speech synthesis.
Properties
-
eventTypes
EventType[] optional
All of the callback event types that this voice is capable of sending.
-
extensionId
string optional
The ID of the extension providing this voice.
-
gender
VoiceGender optional
Deprecated since Chrome 70Gender is deprecated and will be ignored.
This voice's gender.
-
lang
string optional
The language that this voice supports, in the form language-region. Examples: 'en', 'en-US', 'en-GB', 'zh-CN'.
-
remote
boolean optional
If true, the synthesis engine is a remote network resource. It may be higher latency and may incur bandwidth costs.
-
voiceName
string optional
The name of the voice.
VoiceGender
Gender is deprecated and is ignored.
Enum
"male"
"female"
Methods
getVoices()
chrome.tts.getVoices(
callback?: function,
)
Gets an array of all available voices.
Parameters
-
callback
function optional
The
callback
parameter looks like:(voices: TtsVoice[]) => void
-
voices
TtsVoice[]
Array of
tts.TtsVoice
objects representing the available voices for speech synthesis.
-
Returns
-
Promise<TtsVoice[]>
Chrome 101+Promises are supported in Manifest V3 and later, but callbacks are provided for backward compatibility. You cannot use both on the same function call. The promise resolves with the same type that is passed to the callback.
isSpeaking()
chrome.tts.isSpeaking(
callback?: function,
)
Checks whether the engine is currently speaking. On Mac OS X, the result is true whenever the system speech engine is speaking, even if the speech wasn't initiated by Chrome.
Parameters
-
callback
function optional
The
callback
parameter looks like:(speaking: boolean) => void
-
speaking
boolean
True if speaking, false otherwise.
-
Returns
-
Promise<boolean>
Chrome 101+Promises are supported in Manifest V3 and later, but callbacks are provided for backward compatibility. You cannot use both on the same function call. The promise resolves with the same type that is passed to the callback.
pause()
chrome.tts.pause()
Pauses speech synthesis, potentially in the middle of an utterance. A call to resume or stop will un-pause speech.
resume()
chrome.tts.resume()
If speech was paused, resumes speaking where it left off.
speak()
chrome.tts.speak(
utterance: string,
options?: TtsOptions,
callback?: function,
)
Speaks text using a text-to-speech engine.
Parameters
-
utterance
string
The text to speak, either plain text or a complete, well-formed SSML document. Speech engines that do not support SSML will strip away the tags and speak the text. The maximum length of the text is 32,768 characters.
-
options
TtsOptions optional
The speech options.
-
callback
function optional
The
callback
parameter looks like:() => void
Returns
-
Promise<void>
Chrome 101+Promises are supported in Manifest V3 and later, but callbacks are provided for backward compatibility. You cannot use both on the same function call. The promise resolves with the same type that is passed to the callback.
stop()
chrome.tts.stop()
Stops any current speech and flushes the queue of any pending utterances. In addition, if speech was paused, it will now be un-paused for the next call to speak.
Events
onVoicesChanged
chrome.tts.onVoicesChanged.addListener(
callback: function,
)
Called when the list of tts.TtsVoice
that would be returned by getVoices has changed.
Parameters
-
callback
function
The
callback
parameter looks like:() => void