eSpeak NG is an open source speech synthesizer that supports more than hundred languages and accents.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Reece H. Dunn 58ae6ea33f VoiceSettings.java: Add support for converting to a JSON object. 12 years ago
.settings pull in the espeak activity sources from eyes-free 13 years ago
.tx Add a translation resource mapping for id => android/res/values-in (Android uses the old, deprecated code for Indonesia). 12 years ago
android VoiceSettings.java: Add support for converting to a JSON object. 12 years ago
dictsource Merge branch 'master' into android 12 years ago
docs Merge branch 'development' 12 years ago
espeak-data Fix bad attribute warnings with the different NVDA voice variants. 12 years ago
phsource Merge branch 'master' into android 12 years ago
platforms Merge branch 'master' into android 12 years ago
praat-mod 1.46.02 13 years ago
src Merge branch 'master' into android 12 years ago
ucd-tools @ 2d982956a5 ucd-tools: pick up category classification fixes and data size reductions. 13 years ago
.gitignore Ignore the Android Studio project files. 12 years ago
.gitmodules Use the read-only reference to the ucd-tools git module. 12 years ago
COPYING autotools: add a COPYING file with the GPL v3 license to make autotools happy. 12 years ago
Makefile.am autotools: support running the Android tests from 'make check' 12 years ago
README.md Merge branch 'master' into android 12 years ago
autogen.sh Initialize the git submodules when autogen.sh is run. 12 years ago
configure.ac Merge branch 'master' into android 12 years ago
mkdictlist autotools: corerctly use the libespeak.so.1 file in the src directory when running 'espeak --compile=<lang>' 12 years ago
shadowdir Makefile: shadow the phsource and dictsource directories instead of copying them 14 years ago

README.md

Android Port of eSpeak Text-to-Speech

This branch contains the files needed to build espeak on the android platform. It is derived from the eyes-free project.

Prerequisits

To build eSpeak for Android, you need to have the following installed and configured correctly:

  1. Android SDK
  2. Android NDK
  3. wxWidgets 2.8 (for espeakedit when building android/res/raw/espeakdata.zip)

If you are building with Eclipse, you will also need:

  1. Eclipse
  2. Android Developer Tools (ADT) for Eclipse

If you are building on the command line, you will also need either:

  1. ant (e.g. run sudo apt-get install ant on a Debian-based distribution), or
  2. gradle 1.7, which can be installed from the Ubuntu PPA debian file (including on Debian systems)

Building with Gradle

  1. Set the location of the Android SDK:

  2. Build the project:

    $ ./autogen.sh
    $ ./configure
    $ make
    

This will create an android/build/apk/espeak-release-unsigned.apk file.

Building with Eclipse

  1. Build the JNI binding and espeak data file by running:

    $ ./autogen.sh
    $ ./configure
    $ make jni espeakdata
    
  2. Open Eclipse.

  3. Create a new workspace.

  4. Import the espeak folder as an exising Android project.

  5. Build the espeak apk within Eclipse.

The generated eSpeakActivity.apk can be installed like any other apk build via eclipse, such as by using the Run menu option.

Building with Ant

  1. Build the JNI binding and espeak data file by running:

    $ ./autogen.sh
    $ ./configure
    $ make jni espeakdata
    
  2. Update the project using the Android utility which is part of the SDK:

    $ cd android
    $ android update project -s -t 1 -p .
    
  3. Build the package.

    $ ant release
    

Signing the APK

In order to install the built APK (e.g. bin/eSpeakActivity-release-unsigned.apk) you need to self-sign the package. You can do this by:

  1. Creating a certificate, if you do not already have one:

    $ keytool -genkey -keystore [YOUR_CERTIFICATE] -alias [ALIAS]
    
  2. Sign the package using your certificate:

    $ jarsigner -sigalg MD5withRSA -digestalg SHA1 \
      -keystore [YOUR_CERTIFICATE] \
      bin/eSpeakActivity-release-unsigned.apk [ALIAS]
    
  3. Align the apk using the zipalign tool.

    $ zipalign 4 bin/eSpeakActivity-release-unsigned.apk \
      bin/eSpeakActivity-release-signed.apk
    

Installing the APK

Now, you can install the APK using the adb tool:

$ adb install -r bin/eSpeakActivity-release-signed.apk

Enabling eSpeak on the Device

After running, eSpeakActivity will extract the espeakdata.zip file into its own data directory to set up the available voices.

To enable eSpeak, you need to:

  1. go into the Android Text-to-Speech settings UI;
  2. enable eSpeak TTS in the Engines section;
  3. select eSpeak TTS as the default engine;
  4. use the Listen to an example option to check if everything is working.