Android编程:循环语音识别

时间:2013-01-21 21:00:56

标签: java android audio-recording voice-recognition mediarecorder

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

  1. 应用程序(通过语音识别)接受他的演讲
  2. 该应用程序解析他的演讲并执行他的命令(“电子邮件爸爸”,“文本fred”,“现在几点?”等,以及我将添加的其他东西来控制他的电视,灯光等)
  3. 执行后,应用程序等待下一个命令(循环回#1)
  4. 我有#1& #2工作正常,但我无法找到#3的好方法。我无法让Google的语音识别视图无限期运行,因为它可能比下一个命令要好几个小时。但“触发器”必须基于声音/声音。必须完全免提。

    理想情况下,应用程序只会听一个声音,如果声音高于某个预编程的分贝级别,我就会开始进行语音识别。是否可以不断地循环只听一个噪音,然后反应是否“如此”响亮?

    有什么想法吗?

    由于

2 个答案:

答案 0 :(得分: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秒左右没有说出某些内容,则会重置并显示结果。这对我来说很有用。

答案 1 :(得分:0)

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

  1. 您可以轻松连续收听,提供语音检测API
  2. 您可以提高自定义命令集的准确性
  3. 您可以使模型适应用户语音,从而显着提高准确性
  4. 有关在Android上使用CMUSphinx的详细信息,请参阅

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