2015-03-03 2 views
1

Я пытаюсь сделать функцию в стекле google, что позволяет мне перемещаться между картами, не говоря о горячем слове «ok glass».

Я попытался создать SpeechRecognizer, который будет постоянно слушать, если что-то говорит или нет, и если указывается правильная «команда», приложение будет действовать соответствующим образом.

Однако метод OnError говорит мне

Error occured: RecognitionService busy. 

и бросает ошибку, которая говорит

Activity com.example.sw_stage.topfinder.MainActivity has leaked ServiceConnection [email protected] that was originally bound here 
android.app.ServiceConnectionLeaked: Activity com.example.sw_stage.topfinder.MainActivity has leaked ServiceConnection [email protected] that was originally bound here 
     at android.app.LoadedApk$ServiceDispatcher.<init>(LoadedApk.java:970) 
     at android.app.LoadedApk.getServiceDispatcher(LoadedApk.java:864) 
     at android.app.ContextImpl.bindServiceCommon(ContextImpl.java:1575) 
     at android.app.ContextImpl.bindService(ContextImpl.java:1558) 
     at android.content.ContextWrapper.bindService(ContextWrapper.java:517) 
     at android.speech.SpeechRecognizer.startListening(SpeechRecognizer.java:287) 
     at com.example.sw_stage.topfinder.SpeechDetector.<init>(SpeechDetector.java:35) 
     at com.example.sw_stage.topfinder.MainActivity.onCreate(MainActivity.java:58) 
     at android.app.Activity.performCreate(Activity.java:5235) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1089) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2188) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2273) 
     at android.app.ActivityThread.access$800(ActivityThread.java:138) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1236) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:149) 
     at android.app.ActivityThread.main(ActivityThread.java:5045) 
     at java.lang.reflect.Method.invokeNative(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:515) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602) 
     at dalvik.system.NativeStart.main(Native Method) 

настоящее время я использую этот проект, чтобы проверить некоторые из функций, которые я хочу, чтобы в моем окончательное приложение. В настоящее время я использую

  • Глава Жесты навигации
  • Сочетание живой карты и погружения
  • класс использовать команды оболочки, чтобы simulate touch gestures

Вот класс I написал для SpeechRecognizer

package com.example.sw_stage.topfinder; 

import android.content.Context; 
import android.content.Intent; 
import android.media.AudioManager; 
import android.os.Bundle; 
import android.speech.RecognitionListener; 
import android.speech.RecognizerIntent; 
import android.speech.SpeechRecognizer; 
import android.util.Log; 

import java.util.ArrayList; 


public class SpeechDetector { 
AudioManager mAudioManager; 
SpeechRecognizer mSpeechRecognizer; 
Intent intent; 
issueKey mIssueKey = new issueKey(); 

public SpeechDetector(Context context) 
{ 
    Log.i("speechdetector", "calling speech detector"); 
    mAudioManager = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE); 

    mSpeechRecognizer = SpeechRecognizer.createSpeechRecognizer(context); 
    mSpeechRecognizer.setRecognitionListener(new listener(context)); 

    intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH); 
    intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM); 
    Log.i("package name", context.getPackageName()); 
    intent.putExtra(RecognizerIntent.EXTRA_CALLING_PACKAGE, context.getPackageName()); 
    mSpeechRecognizer.startListening(intent); 
    Log.i("111111","11111111"+"in"); 
} 

class listener implements RecognitionListener 
{ 
    Context context1; 
    public listener(Context context) 
    { 
     context1 = context; 
    } 

    @Override 
    public void onReadyForSpeech(Bundle bundle) { 

    } 

    @Override 
    public void onBeginningOfSpeech() { 

    } 

    @Override 
    public void onRmsChanged(float v) { 

    } 

    @Override 
    public void onBufferReceived(byte[] bytes) { 

    } 

    @Override 
    public void onEndOfSpeech() { 
     mSpeechRecognizer.startListening(intent); 
    } 

    @Override 
    public void onError(int i) { 
     //3 Audio recording error. 
     //5 Other client side errors. 
     //6 - No speech input 
     //7 -No recognition result matched. 
     //8 RecognitionService busy. 
     //9 - vInsufficient permissions 


     if(i == 1 || i == 2 || i == 3 || i == 4 || i == 5 || i == 6 || i == 7 || i == 8 || i == 9) 
     { 
      Log.wtf("Error occured", "Error " + i); 
      mSpeechRecognizer.startListening(intent); 
     } 
    } 

    @Override 
    public void onResults(Bundle bundle) { 
     ArrayList data = bundle.getStringArrayList(SpeechRecognizer.RESULTS_RECOGNITION); 
     String result = "enter"; 
     String reslt = ""; 
     for (int i = 0; i < data.size(); i++) 
     { 
      reslt = reslt + " " + data.get(i); 
     } 
     switch(result) 
     { 
      case "next": mIssueKey.issueKey(22); 
       break; 
      case "previous": mIssueKey.issueKey(21); 
       break; 
      case "enter": mIssueKey.issueKey(23); 
       break; 
      case "leave": mIssueKey.issueKey(4); 
     } 

    } 

    @Override 
    public void onPartialResults(Bundle bundle) { 

    } 

    @Override 
    public void onEvent(int i, Bundle bundle) { 

    } 
} 

}

Я вызываю этот класс в свой метод MainActivity onCreate().

private SpeechDetector mSpeechDetector; 

@Override 
protected void onCreate(Bundle bundle) { 
    super.onCreate(bundle); 

    mIssueKey = new issueKey(); 
    mSpeechDetector = new SpeechDetector(getApplicationContext()); 

Я изменил

new SpeechDetector(MainActivity.this); 

в

new SpeechDetector(getApplicationContext()); 

и я не получать просочилась ошибку больше

ОДНАКО

Очевидно, что пропущенная ошибка и занятие RecognitionService не связаны. Так что я до сих пор застрял с тем, что мой speechrecognition не работает, потому что он бросает ошибку RecognitionService busy

EDIT Я просто заметил, что это пишет дополнительный журнал

03-03 13:11:13.252 20018-20018/? A/Error occured﹕ RecognitionService busy 
    03-03 13:11:13.260  825-825/? I/RecognitionService﹕ concurrent startListening received - ignoring this call 
+0

В вашей 'MainActivity', вы случайно объявили свой экземпляр класса' SpeechDetector' как 'static' ?? –

+0

@ZygoteInit Нет, не объявлено как статическое. Я только что обновил свой код с объявлением и вызовом класса SpeechDetector – NoSixties

+0

. Требуется ли вам, чтобы сервис выполнялся все время или просто с жизнью активности, если он работает только до жизни, остановки и деинсталляции паузы или остановки. –

ответ

0

Вы получили RecognitionService busy, потому что этого кода

@Override 
public void onEndOfSpeech() { 
    mSpeechRecognizer.startListening(intent); 
} 

Вы должны позвонить mSpeechRecognizer.startListening(intent) в onResults

+0

попробовал это, однако теперь он выдает ошибку в x раз, когда MainActivity запущен, а затем ничего. Но это не так, как в методе OnResults(), либо – NoSixties

1

Похоже, что RecognitionService уже используется в точке, которую вы называете startListening(). Я считаю, что это потому, что вы уже вызвали startListening() в своем конструкторе, а затем снова вызвали его в onEndOfSpeech().

Перед тем как позвонить по телефону startListening(), необходимо сделать необходимые звонки cancel().

+0

. Я добавил .cancel() в необязательные фрагменты кода. И теперь все изменилось. Я больше не получаю «RecognitionService busy». Я теперь либо получаю «Нет речевого ввода», либо «Другие ошибки на стороне клиента», – NoSixties