У меня есть класс, который использует Android TTS API для транскрипции текста в аудио. Я могу контролировать шаг и скорость; но я заметил, что движок требует текстовую строку, а также хэш-объект. Я заметил, что некоторые слова произносятся слишком быстро, чтобы их легко распознать, а перегибы выглядят слишком противоестественными. Есть ли способ управлять этими двумя вещами? возможно через HashMap
? Далее, как я использую двигатель:Как я могу контролировать, как Android TTS воспроизводит аудио?
mTts = new TextToSpeech(Globals.context, this); // context, listener
}
@Override
public void onInit(int status) {
HashMap<String, String> myHashRender = new HashMap();
myHashRender.put(TextToSpeech.Engine.KEY_PARAM_UTTERANCE_ID, speech);
mTts.setPitch(0.8f);
mTts.setSpeechRate(0.6f);
mTts.synthesizeToFile(speech, myHashRender, fileOutPath);
while (mTts.isSpeaking()) try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
mTts.stop();
mTts.shutdown();
Google TTS в настоящее время не поддерживает изменение перегибов и не поддерживает встроенные теги просодии, как определено в [SSML] (http://help.voxeo.com/go/help/xml.vxml.elements.prosody). Возможно, что другие TTS-модули поддерживают эти функции, но я ничего не знаю. – alanv
Тогда почему метод принимает хэш-карту и строку? – motoku
Есть параметры, которые вы можете установить, но ни один из них не контролирует перегиб или просодию на слово. – alanv