简介
在使用语音识别的时候,想通过对语音的识别转换为文字,然后再对文本进行分析,实现对应语义的识别进而发出相应命令控制外设。但发现每次识别成功后,都会重复发出至少两次以上的命令,通过阅读官方文档,找到问题的原因是系统为了能够更好的对识别结果进行处理,会多次调用onResult()
方法。
官方文档
http://mscdoc.xfyun.cn/android/api/
解决办法
--------------------分割线更新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的识别再进行相应的命令发送。
总结
写代码时一定要注意代码的简洁性,一个函数只做一件事,并把这件事做好