Cloud Text-to-Speech API C++ Client Library

An idiomatic C++ client library for the Cloud Text-to-Speech API, a service to synthesize natural-sounding speech by applying powerful neural network models.

While this library is GA, please note Google Cloud C++ client libraries do not follow Semantic Versioning.

Quickstart

The following shows the code that you'll run in the google/cloud/texttospeech/quickstart/ directory, which should give you a taste of the Cloud Text-to-Speech API C++ client library API.

#include "google/cloud/texttospeech/v1/text_to_speech_client.h"
#include <iostream>

auto constexpr kText = R"""(
Four score and seven years ago our fathers brought forth on this
continent
, a new nation, conceived in Liberty, and dedicated to
the proposition that all men are created equal
.)""";

int main(int argc, char* argv[]) try {
 
if (argc != 1) {
    std
::cerr << "Usage: " << argv[0] << "\n";
   
return 1;
 
}

 
namespace texttospeech = ::google::cloud::texttospeech_v1;
 
auto client = texttospeech::TextToSpeechClient(
      texttospeech
::MakeTextToSpeechConnection());

  google
::cloud::texttospeech::v1::SynthesisInput input;
  input
.set_text(kText);
  google
::cloud::texttospeech::v1::VoiceSelectionParams voice;
  voice
.set_language_code("en-US");
  google
::cloud::texttospeech::v1::AudioConfig audio;
  audio
.set_audio_encoding(google::cloud::texttospeech::v1::LINEAR16);

 
auto response = client.SynthesizeSpeech(input, voice, audio);
 
if (!response) throw std::move(response).status();
 
// Normally one would play the results (response->audio_content()) over some
 
// audio device. For this quickstart, we just print some information.
 
auto constexpr kWavHeaderSize = 48;
 
auto constexpr kBytesPerSample = 2;  // we asked for LINEAR16
 
auto const sample_count =
     
(response->audio_content().size() - kWavHeaderSize) / kBytesPerSample;
  std
::cout << "The audio has " << sample_count << " samples\n";

 
return 0;
} catch (google::cloud::Status const& status) {
  std
::cerr << "google::cloud::Status thrown: " << status << "\n";
 
return 1;
}

Main classes

The main class in this library is texttospeech_v1::TextToSpeechClient. All RPCs are exposed as member functions of this class. Other classes provide helpers, configuration parameters, and infrastructure to mock texttospeech_v1::TextToSpeechClient when testing your application.

More Information