Android 轻松实现语音识别详解及实例代码
程序员文章站
2024-03-06 12:32:49
使用intent调用语音识别程序
说明
android中主要通过recognizerintent来实现语音识别,其实代码比较简单,但是如果找不到语音识别设备,就会抛出异...
使用intent调用语音识别程序
说明
android中主要通过recognizerintent来实现语音识别,其实代码比较简单,但是如果找不到语音识别设备,就会抛出异常 activitynotfoundexception,所以我们需要捕捉这个异常。而且语音识别在模拟器上是无法测试的,因为语音识别是访问google 云端数据,所以如果手机的网络没有开启,就无法实现识别声音的!一定要开启手机的网络,如果手机不存在语音识别功能的话,也是无法启用识别!
注意:使用前需要安装语音识别程序。如《语音搜索》,其使用的语音识别技术来自于google,intent可以识别到该程序。
本例参考自android例程:
development/samples/apidemos/src/com/example/android/apis/app/voicerecognition.java
核心代码及说明
package com.example.test; import android.app.activity; import android.content.intent; import android.content.pm.packagemanager; import android.os.bundle; import android.speech.recognizerintent; import android.view.view; import android.view.view.onclicklistener; import android.widget.button; import android.widget.toast; import java.util.arraylist; import java.util.list; public class mainactivity extends activity implements onclicklistener { private static final int voice_recognition_request_code = 1234; @override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.activity_main); button btn = (button) findviewbyid(r.id.btn); // 识别按钮 packagemanager pm = getpackagemanager(); list activities = pm.queryintentactivities(new intent( recognizerintent.action_recognize_speech), 0); // 本地识别程序 // new intent(recognizerintent.action_web_search), 0); // 网络识别程序 /* * 此处没有使用捕捉异常,而是检测是否有语音识别程序。 * 也可以在startrecognizeractivity()方法中捕捉activitynotfoundexception异常 */ if (activities.size() != 0) { btn.setonclicklistener(this); } else { // 若检测不到语音识别程序在本机安装,测将扭铵置灰 btn.setenabled(false); btn.settext("未检测到语音识别设备"); } } public void onclick(view v) { if (v.getid() == r.id.btn) { startrecognizeractivity(); } } // 开始识别 private void startrecognizeractivity() { // 通过intent传递语音识别的模式,开启语音 intent intent = new intent(recognizerintent.action_recognize_speech); // 语言模式和*模式的语音识别 intent.putextra(recognizerintent.extra_language_model, recognizerintent.language_model_free_form); // 提示语音开始 intent.putextra(recognizerintent.extra_prompt, "开始语音"); // 开始语音识别 startactivityforresult(intent, voice_recognition_request_code); // 调出识别界面 } @override protected void onactivityresult(int requestcode, int resultcode, intent data) { // 回调获取从谷歌得到的数据 if (requestcode == voice_recognition_request_code && resultcode == result_ok) { // 取得语音的字符 arraylist<string> results = data .getstringarraylistextra(recognizerintent.extra_results); string resultstring = ""; for (int i = 0; i < results.size(); i++) { resultstring += results.get(i); } toast.maketext(this, resultstring, toast.length_short).show(); } // 语音识别后的回调,将识别的字串以toast显示 super.onactivityresult(requestcode, resultcode, data); } }
其主要原理就是将语音发送到google云端,然后云端处理,匹配相应的数据,发送到客户端。
最后不要忘记,在manifest中加入网络访问权限:
<uses-permission android:name="android.permission.internet" />
运行后效果:
以上就是对android 实现语音识别的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!
上一篇: asp.NET连接数的设置方法