Archive. Date of access: 12 Jan 2022

Thomas Hunter II f791d243a2 0.13.1 hace 7 años
examples 47ad4b56e9 Major refactor, ES6, standard linter hace 7 años
platform cf364be1fc Breaking index.js into different files for each platform hace 7 años
.gitignore f4cef08c82 .gitignore, ignoring node_modules hace 10 años
.npmignore 7278b9d933 Ignoring logo.png and other unneeded files hace 7 años
.travis.yml 47ad4b56e9 Major refactor, ES6, standard linter hace 7 años
LICENSE.txt 59a45e1643 such bolded human readable files hace 10 años
README.md 839b1efa29 Emoji in Feature Matrix hace 7 años
index.d.ts fbdf6cd895 Add TypeScript support (#61) hace 7 años
index.js cf364be1fc Breaking index.js into different files for each platform hace 7 años
logo.png 0b736fad30 [misc] Updated demos. Added logo to repo. Checked freshness of code. hace 14 años
package-lock.json 99489dadb9 0.13.1 hace 7 años
package.json 99489dadb9 0.13.1 hace 7 años
typings.json fbdf6cd895 Add TypeScript support (#61) hace 7 años

README.md

Installing say.js

npm install say

Usage

const say = require('say')

// Use default system voice and speed
say.speak('Hello!')

// Stop the text currently being spoken
say.stop()

// More complex example (with an OS X voice) and slow speed
say.speak("What's up, dog?", 'Alex', 0.5)

// Fire a callback once the text has completed being spoken
say.speak("What's up, dog?", 'Good News', 1.0, (err) => {
  if (err) {
    return console.error(err)
  }

  console.log('Text has been spoken.')
});

// Export spoken audio to a WAV file
say.export("I'm sorry, Dave.", 'Cellos', 0.75, 'hal.wav', (err) => {
  if (err) {
    return console.error(err)
  }

  console.log('Text has been saved to hal.wav.')
})

Methods

Override Platform:

say.setPlatform(say.platforms.WIN32 || say.platforms.MACOS || say.platforms.LINUX)

Speak:

  • Speed: 1 = 100%, 0.5 = 50%, 2 = 200%, etc
say.speak(text, voice || null, speed || null, callback || null)

Export Audio:

  • MacOS Only
  • Speed: 1 = 100%, 0.5 = 50%, 2 = 200%, etc
say.export(text, voice || null, speed || null, filename, callback || null)

Stop Speaking:

say.stop(callback || null)

Feature Matrix

Unfortunately every feature isn't suppored on every platform. PR's welcome!

Platform Speak Export Stop Speed Voice
macOS :white_check_mark: :white_check_mark: :white_check_mark: :white_check_mark: :white_check_mark:
Linux :white_check_mark: :no_entry_sign: :white_check_mark: :white_check_mark: :white_check_mark:
Windows :white_check_mark: :no_entry_sign: :white_check_mark: :no_entry_sign: :no_entry_sign:

macOS Notes

Voices in macOS are associated with different localities. To a list of voices and their localities run the following command:

say -v "?"

As an example, the default voice is Alex and the voice used by Siri is Samantha.

Windows Notes

Voice parameter is not yet available. Uses whatever default system voice is set, ignoring voice parameter.

Speed parameter is not yet available.

The .export() method is not available.

Linux Notes

Linux support requires Festival, which uses less friendly names for its voices. Voices for Festival sometimes need to be installed separately. You can check which voices are available by running festival, typing (voice_, and pressing Tab. Then take the name of the voice you'd like to try, minus the parentheses, and pass it in to say.js.

The .export() method is not available.

Try the following commad to install Festival with a default voice:

sudo apt-get install festival festvox-kallpc16k

Requirements

  • Mac OS X (comes with say)
  • Linux with Festival installed
  • Windows (comes with SAPI.SpVoice)