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()
   }
}
Другие вопросы по тегам