主要是使用科大讯飞的api,进行语音识别,语音播报
科大讯飞的sdk可以到它的官网上面去下载,下载后导入到工程的lib里面,在去网上注册时会有一个appID,把ID保存下来,在代码中会使用到。
可以通过讯飞提供的api进行对语音的识别
//这里面主要是创建识别的recoginzer
SpeechUtility.createUtility(this, SpeechConstant.APPID + "=54466772");
recognizer = SpeechRecognizer.createRecognizer(this,
null);
recognizer.setParameter(SpeechConstant.DOMAIN,"iat");
recognizer.setParameter(SpeechConstant.LANGUAGE, "zh-cn");
recognizer.setParameter(SpeechConstant.ACCENT, "mandarin");
//开始识别,这里传入mRecognizerListener
int recognizerCode = recognizer.startListening(mRecognizerListener);
当识别完成后,会去调用RecognizerListener中的onResult方法,根据返回过来的json字符串进行解析之后得到的结果,然后根据返回过来的结果去做对应的操作,如下面的打电话操作,这只是一个小样历
public void onResult(RecognizerResult results, boolean isLast) {
String json = results.getResultString();
String result = JsonParser.parserIatResult(json);
mTts.startSpeaking(result,mSynListener);
if ("打电话".equals(result)) {
call();
}else{
}
}
//这个方法是解析Json数据
public static String parserIatResult(String json){
StringBuffer buffer = new StringBuffer();
try {
JSONTokener token = new JSONTokener(json);
JSONObject jsonObject = new JSONObject(token);
JSONArray words = jsonObject.getJSONArray("ws");
for(int i = 0;i < words.length();i++){
JSONArray items = words.getJSONObject(i).getJSONArray("cw");
JSONObject obj = items.getJSONObject(0);
buffer.append(obj.getString("w"));
}
} catch (Exception e) {
e.printStackTrace();
}
return buffer.toString();
}
这里也可以通过对应的api去将文字转换成语音
//这个是讯飞自己的语音合成
mTts = SpeechSynthesizer.createSynthesizer(this, null);
mTts.setParameter(SpeechConstant.VOICE_NAME, "xiaoyan");
mTts.setParameter(SpeechConstant.SPEED, "50");
mTts.setParameter(SpeechConstant.VOLUME, "80");
mTts.setParameter(SpeechConstant.ENGINE_TYPE, SpeechConstant.TYPE_CLOUD);
//这个是会播报的result
mTts.startSpeaking(result,mSynListener);