科大讯飞Android语音识别onResult()方法的理解

简介

在使用语音识别的时候,想通过对语音的识别转换为文字,然后再对文本进行分析,实现对应语义的识别进而发出相应命令控制外设。但发现每次识别成功后,都会重复发出至少两次以上的命令,通过阅读官方文档,找到问题的原因是系统为了能够更好的对识别结果进行处理,会多次调用onResult()方法。

官方文档

http://mscdoc.xfyun.cn/android/api/
科大讯飞Android语音识别onResult()方法的理解

解决办法

--------------------分割线更新2019.4.30----------------------------------
void onResult(RecognizerResult result, boolean islast)方法里有两个参数,后面的islast是用来判断是否为最后一次调用该方法,当是true时为最后一个结果,否则不是;也就是说,可以对其进行判断识别,当为true时,再进行相应功能的实现

@Override
        public void onResult(RecognizerResult recognizerResult, boolean b) {

            System.out.println(recognizerResult.getResultString());
           //printResulit()为 自定义方法,可以对识别的语音进行一系列的处理,比如说将语音转换为文字
            printResult(recognizerResult);
            //最后确定识别的结果
            if(b){
                doSomething();
            }
        }

--------------------------分割线------------------------------------------
不要把相应的发送命令功能写到onResult()方法里,可以设置一个flag,然后对其进行标记,最后再通过对flag的识别再进行相应的命令发送。

总结

写代码时一定要注意代码的简洁性,一个函数只做一件事,并把这件事做好