SpeechRecognizer не запускается
ВСТУПЛЕНИЕ
Мне нужно реализовать распознавание голоса в моем коде. Я следовал за другими постами здесь и некоторыми учебниками, чтобы получить это, но это не работает правильно для меня.
ПОДХОД
Это код в onCreate для его инициализации:
Log.d("SPEECH", "speech recognition available: " + SpeechRecognizer.isRecognitionAvailable(this));
mSpeechRecognizer = SpeechRecognizer.createSpeechRecognizer(this);
mSpeechRecognizer.setRecognitionListener(mRecognitionListener);
mSpeechRecognizerIntent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
mSpeechRecognizerIntent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,
RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
mSpeechRecognizerIntent.putExtra(RecognizerIntent.EXTRA_CALLING_PACKAGE,
this.getPackageName());
Деятельность реализует TextToSpeech.OnInitListener
Итак, я вызываю метод main, когда эта реализация инициализируется в своем собственном методе:
@Override
public void onInit(int status) {
myMethod();
}
Затем внутри myMethod() я начинаю распознавание речи следующим образом:
mSpeechRecognizer.startListening(mSpeechRecognizerIntent);
И наконец, это слушатель результатов:
private final RecognitionListener mRecognitionListener = new RecognitionListener() {
@Override
public void onBufferReceived(byte[] buffer) {
Log.d("SPEECH", "onBufferReceived");
}
@Override
public void onError(int error) {
Log.d("SPEECH", "onError: " + error);
mSpeechRecognizer.startListening(mSpeechRecognizerIntent);
}
@Override
public void onEvent(int eventType, Bundle params) {
Log.d("SPEECH", "onEvent");
}
@Override
public void onPartialResults(Bundle partialResults) {
Log.d("SPEECH", "onPartialResults");
}
@Override
public void onReadyForSpeech(Bundle params) {
Log.d("SPEECH", "onReadyForSpeech");
}
@Override
public void onResults(Bundle results) {
Log.d("SPEECH", "onResult");
matches = results.getStringArrayList(SpeechRecognizer.RESULTS_RECOGNITION);
}
@Override
public void onRmsChanged(float rmsdB) {
Log.d("SPEECH", "onRmsChanged");
}
@Override
public void onBeginningOfSpeech() {
Log.d("SPEECH", "onBeginningOfSpeech");
}
@Override
public void onEndOfSpeech() {
Log.d("SPEECH", "onEndOfSpeech");
}
};
Когда я делаю mSpeechRecognizer.startListening(mSpeechRecognizerIntent);
Он не показывает ошибок или ошибок в logcat, но слушатель не инициализирован, я не вижу журналы в LogCat, поэтому я предполагаю, что он не инициализируется должным образом.
Может я плохо начинаю слушателя или что может быть?
ОБНОВЛЕНИЕ-- структура деятельности
public class GameActivity extends Activity implements TextToSpeech.OnInitListener {
@Override
public void onCreate(Bundle savedInstanceState) {
tts = new TextToSpeech(this, this);
Log.d("SPEECH", "speech recognition available: " + SpeechRecognizer.isRecognitionAvailable(this));
mSpeechRecognizer = SpeechRecognizer.createSpeechRecognizer(this);
mSpeechRecognizer.setRecognitionListener(new SpeechListener());
mSpeechRecognizerIntent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
mSpeechRecognizerIntent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,
RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
mSpeechRecognizerIntent.putExtra(RecognizerIntent.EXTRA_CALLING_PACKAGE,
this.getPackageName());
mSpeechRecognizer.startListening(mSpeechRecognizerIntent);
}
/*Method implemented by texttospeech*/
@Override
public void onInit(int status) {
if (status == TextToSpeech.SUCCESS) {
/*set Language*/
tts.setLanguage(Locale.getDefault());
/*STARTS MAIN METHOD*/
SpeechWhenMotion();
} else {
Log.e("TTS", "Initilization Failed");
}
}
/*Main method, does all the work*/
public void SpeechWhenMotion() {
}
1 ответ
Согласно документации распознаватель речи должен вызываться из основного потока. Вы пытаетесь запустить распознаватель в обратном вызове onInit из движка TTS. Это не основной поток, обратный вызов tts engine выполняется в отдельном потоке.
Вам нужно запустить инициализатор ASR в главном потоке, сначала вы можете запустить распознаватель речи в onCreate()
метод, а затем инициализировать текст в речь.
Кроме того, вы можете опубликовать обработчик для инициализации ASR в ветке TTS:
handler.postDelayed(new Runnable() {
@Override
run() {
MyASRInit()
}
}