3

我正在寻找一个定制的 Android 应用程序来帮助一个身体残疾的人。我需要严重依赖语音识别。这个想法是:

  1. 应用程序(通过语音识别)接受他的讲话
  2. 该应用程序解析他的讲话并执行他的命令(“给爸爸发电子邮件”、“发短信”、“现在几点了?”等,以及我将添加的其他内容来控制他的电视、灯光等)
  3. 执行后,应用程序等待他的下一个命令(循环回到#1)

我的#1 和#2 工作正常,但我想不出#3 的好方法。我不能让谷歌的语音识别视图无限期地运行,因为它可能在下一个命令之前几个小时。但是“触发器”确实必须基于声音/声音。必须完全解放双手。

理想情况下,该应用程序只会听声音,如果该声音高于某个预编程的分贝水平,我会开始语音识别。是否可以不断循环只听噪音,然后在它“如此”响亮时做出反应?

有任何想法吗?

谢谢

4

2 回答 2

0

CMUSphinx是一个很好的解决方案:

  1. 您可以轻松连续收听,提供语音检测API
  2. 您可以提高一组自定义命令的准确性
  3. 您可以使模型适应用户的声音,从而显着提高准确性

有关在 Android 上使用 CMUSphinx 的更多详细信息,请参阅

http://cmusphinx.sourceforge.net/2011/05/building-pocketsphinx-on-android/

于 2013-05-04T09:35:58.683 回答
0

所以这个想法是你希望语音识别持续进行。很难做到这一点。但我实现这一点的方法是使用:

   try {
       Thread.sleep(4500);
       mSpeechRecognizer.startListening(mSpeechRecognizerIntent);
   }  catch (InterruptedException e) {
        // It depends on your app logic what to do with InterruptedException
        // You can process it or rethrow or restore interrupted flag
   }

之后onReady(因此,如果用户在 4.5 秒左右没有说什么,它会重置并显示结果。这对我来说非常有用。

于 2013-05-04T01:35:18.287 回答