Android语音识别所有结果都是一个数组索引

时间:2011-06-02 16:48:30

标签: android voice-recognition

我正在尝试解析Android语音识别活动的结果,并发现所有单词(由空格分隔)都在数组的第一个索引中。

我期待它将所有单词放入数组的每个索引中。

private void startVoiceRecognitionActivity() 
{
    Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);

    intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,
        RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);

    long wait = 10000;
    intent.putExtra(RecognizerIntent.EXTRA_SPEECH_INPUT_MINIMUM_LENGTH_MILLIS, wait);

    intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "Speak Now");
    startActivityForResult(intent, VOICE_RECOGNITION_REQUEST_CODE);
}

/**
 * Handle the results from the recognition activity.
 */
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    if (requestCode == VOICE_RECOGNITION_REQUEST_CODE && resultCode == RESULT_OK) 
    {
        // Fill the list view with the strings the recognizer thought it could have heard
        ArrayList<String> matches = data.getStringArrayListExtra(
            RecognizerIntent.EXTRA_RESULTS);
        /*mList.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1,
                    matches)); */

        //start intent after we get list of items
        mListIntent = new Intent();
        mListIntent.setClassName(Consts.CLASS_PATH,
        ActivityUtil.getInstance().getClassName()); //get class name based
        //on current activity

        //now set array 'matches' from above and send to next activity...
        Bundle bundle = new Bundle();
        bundle.putStringArrayList(Consts.BUNDLE_KEY_VOICE_LIST, matches);
        mListIntent.putExtras(bundle);

        startActivity(mListIntent);

        //TODO: also how do we add to google dictionary?

    }

    super.onActivityResult(requestCode, resultCode, data);
}

3 个答案:

答案 0 :(得分:2)

这一行你有一个额外的引用:

intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "Speak Now" ");

删除它。
它可能会奏效。

答案 1 :(得分:0)

现在就找到了。如果其他人发现这个问题,问题不在于额外的语音标记(尽管这会阻止代码编译)。

问题是用户对匹配中返回的内容的理解(RecognizerIntent.EXTRA_RESULTS)。这个数组没有每个单词的一个条目,它对于语音识别器的每个匹配都有一个条目,它认为你可能已经说过了。

E.g。如果你说“我在Stack Overflow上写道”,那么数组可能是:

["I wrote on stack overflow",
 "I boat a stack over flow",
 "Ire oh ton stack over flow"]

如果你想得到一个单词的数组,我建议你取第一个匹配字符串并拆分所有的空格。

答案 2 :(得分:0)

我已经提供了一个正在运行的代码,您只需复制粘贴即可完成.. here