diff options
| author | Charles Chen <clchen@google.com> | 2009-06-29 14:04:24 -0700 |
|---|---|---|
| committer | Charles Chen <clchen@google.com> | 2009-06-29 14:06:48 -0700 |
| commit | 03454f8932b7fd79471ae6f95f2de7b75b0ded8a (patch) | |
| tree | bfeb427fcde6397186c29bbba9dee8ed1e131f60 | |
| parent | bd9aa793b19f7aa529ca4123492f8940b96486b8 (diff) | |
| download | frameworks_base-03454f8932b7fd79471ae6f95f2de7b75b0ded8a.zip frameworks_base-03454f8932b7fd79471ae6f95f2de7b75b0ded8a.tar.gz frameworks_base-03454f8932b7fd79471ae6f95f2de7b75b0ded8a.tar.bz2 | |
Adding support for params.
| -rwxr-xr-x | packages/TtsService/src/android/tts/TtsService.java | 27 |
1 files changed, 23 insertions, 4 deletions
diff --git a/packages/TtsService/src/android/tts/TtsService.java b/packages/TtsService/src/android/tts/TtsService.java index 421b2ca..c6b5bee 100755 --- a/packages/TtsService/src/android/tts/TtsService.java +++ b/packages/TtsService/src/android/tts/TtsService.java @@ -91,6 +91,7 @@ public class TtsService extends Service implements OnCompletionListener { } private static final int MAX_SPEECH_ITEM_CHAR_LENGTH = 4000; + private static final int MAX_FILENAME_LENGTH = 250; private static final String ACTION = "android.intent.action.USE_TTS"; private static final String CATEGORY = "android.intent.category.TTS"; @@ -414,6 +415,26 @@ public class TtsService extends Service implements OnCompletionListener { synth.start(); return; } + if (params != null){ + String language = ""; + String country = ""; + String variant = ""; + for (int i = 0; i < params.size() - 1; i = i + 2){ + String param = params.get(i); + if (param.equals(TextToSpeech.Engine.TTS_KEY_PARAM_RATE)){ + setSpeechRate(Integer.parseInt(params.get(i+1))); + } else if (param.equals(TextToSpeech.Engine.TTS_KEY_PARAM_LANGUAGE)){ + language = params.get(i+1); + } else if (param.equals(TextToSpeech.Engine.TTS_KEY_PARAM_COUNTRY)){ + country = params.get(i+1); + } else if (param.equals(TextToSpeech.Engine.TTS_KEY_PARAM_VARIANT)){ + variant = params.get(i+1); + } + } + if (language.length() > 0){ + setLanguage(language, country, variant); + } + } nativeSynth.speak(text); } catch (InterruptedException e) { e.printStackTrace(); @@ -614,8 +635,7 @@ public class TtsService extends Service implements OnCompletionListener { return false; } // Don't allow a filename that is too long - // TODO use platform constant - if (filename.length() > 250) { + if (filename.length() > MAX_FILENAME_LENGTH) { return false; } nativeSynth.synthesizeToFile(text, filename); @@ -660,8 +680,7 @@ public class TtsService extends Service implements OnCompletionListener { return false; } // Don't allow a filename that is too long - // TODO use platform constant - if (filename.length() > 250) { + if (filename.length() > MAX_FILENAME_LENGTH) { return false; } // TODO: Add nativeSynth.synthesizeIpaToFile(text, filename); |
