¿Por qué no se llama a UtteranceProgress Listener a Text to Speach?

He intentado llamar a algunos métodos de inicio y final de texto a voz, así que he utilizado el setOnUtteranceProgressListener, pero no funciona / get llamado.

¿Qué estoy haciendo mal?

Aquí el código necesario:

Clase:

public class SpeechRecognizerActivity extends Activity implements TextToSpeech.OnInitListener 

Método de Init:

  @Override public void onInit(int status) { if (status == TextToSpeech.SUCCESS) { String language = Locale.getDefault().getLanguage(); int result = tts.setLanguage(Locale.US); if (result == TextToSpeech.LANG_MISSING_DATA || result == TextToSpeech.LANG_NOT_SUPPORTED) { Log.e("TTS", "This Language is not supported"); } else { } } else { Log.e("TTS", "Initilization Failed!"); } } 

Método donde comienza hablando:

 private void speakOut(String text) { setTtsListener(); tts.setPitch(1.5f); tts.setSpeechRate(1.5f); tts.speak(text, TextToSpeech.QUEUE_FLUSH, null); } 

El Listener (Método se llama en speakOut): Ninguno de esos registros se muestran en Logcat.

 private void setTtsListener() { if (Build.VERSION.SDK_INT >= 15) { int listenerResult = tts.setOnUtteranceProgressListener(new UtteranceProgressListener() { @Override public void onDone(String utteranceId) { Log.d(TAG,"progress on Done " + utteranceId); } @Override public void onError(String utteranceId) { Log.d(TAG,"progress on Error " + utteranceId); } @Override public void onStart(String utteranceId) { Log.d(TAG,"progress on Start " + utteranceId); } }); if (listenerResult != TextToSpeech.SUCCESS) { Log.e(TAG, "failed to add utterance progress listener"); } } else { int listenerResult = tts.setOnUtteranceCompletedListener(new TextToSpeech.OnUtteranceCompletedListener() { @Override public void onUtteranceCompleted(String utteranceId) { Log.d(TAG,"progress on Completed " + utteranceId); } }); if (listenerResult != TextToSpeech.SUCCESS) { Log.e(TAG, "failed to add utterance completed listener"); } } } 

Una pequeña solución que encontré fue esta:

 boolean speakingEnd = tts.isSpeaking(); do { speakingEnd = tts.isSpeaking(); } while ((speakingEnd)); Log.d(TAG,"talking stopped"); 

Lo he añadido al final del método speakOut, pero esta solución no es muy buena. Trabajar con los oyentes sería perfecto.

Entonces, ¿qué estoy haciendo mal?

Cuando llama a tts.speak(text, TextToSpeech.QUEUE_FLUSH, null); Necesita pasarle un mapa con el KEY_PARAM_UTTERANCE_ID

  HashMap<String, String> map = new HashMap<String, String>(); map.put(TextToSpeech.Engine.KEY_PARAM_UTTERANCE_ID,"messageID"); tts.speak(text, TextToSpeech.QUEUE_FLUSH, map); 

Esto permite que TextToSpeech sepa utilizar su oyente de emisión para ese text

  • ¿Cómo comprobar si TtsService (o un servicio de Android) está detenido?
  • TTS omite al azar las primeras letras de la oración
  • Android TTS no habla
  • Android: dos instancias de Text-to-Speech funcionan muy lentamente
  • ¿Cómo puedo guardar el archivo Text to Speech como formato .wav / .mp3 en idioma árabe en External Storage?
  • SpeechToText y ejecutando la intención ACTION_CHECK_TTS_DATA
  • TextToSpeech.OnInitListener.onInit (int) que se llama continuamente
  • Referencia no resuelta en el anonimo oyente de Kotlin
  • Android TTS no habla gran cantidad de texto
  • Android TTS añadir idiomas
  • Cómo utilizar TTS (TextToSpeech) mientras que la cadena tiene más de 4000 caracteres en Android
  • FlipAndroid es un fan de Google para Android, Todo sobre Android Phones, Android Wear, Android Dev y Aplicaciones para Android Aplicaciones.