我的Android笔记(十四)—— 在应用中集成科大讯飞的语音识别技术
来源:互联网 发布:怎么注销淘宝卖家账号 编辑:程序博客网 时间:2024/05/18 23:16
语音识别技术最近貌似是越来越火了。再前几天科大讯飞还刚刚发布了讯飞语点——一个据说要挑战siri的应用。……好吧,对这些的东西讨论要说起来就多了。
本文主要讲如何在自己的android应用中集成语音识别技术——自然,是使用科大讯飞的sdk。
讯飞的语音sdk是需要申请的,地址是:http://dev.voicecloud.cn/developer.php?vt=1 。申请一个讯飞的开发者账号,然后申请一个appid,申请的时候需要填写开发者信息和你的应用的信息。
申请之后经过审核通过,会得到一个appid,这个是在使用语音服务时需要用到的。(笔者感觉申请还是比较容易通过的,简单地填写一下就通过了。速度也很快,我在晚上十一点多申请的,到第二天早上九点多就收到审核通过的邮件。个人感觉这个审核只是为了防止恶意使用,毕竟语音服务是要使用讯飞的服务器资源的。)
申请到appid之后就可以下载SDK了,然后使用语音服务了。
以下我试用的过程,(点击button,弹出语音框,说完之后将识别的结果显示在EditText中):
- 在eclipse里新建一个android工程
- 导入讯飞的语音jar包
- 讯飞的服务是需要一堆权限的,在manifest.xml中加入
<uses-permission android:name="android.permission.RECORD_AUDIO" /> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> <uses-permission android:name="android.permission.READ_PHONE_STATE" />
分别为:通过麦克风录音、联网、获取网络信息状态、获取wifi状态、改变网络状态如是否能联网、访问电话状态 - 在main.xml中添加一个EditText和一个Button,如下
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <EditText android:id="@+id/editText" android:layout_width="fill_parent" android:layout_height="300dp" android:gravity="top" android:inputType="textMultiLine" > <requestFocus /> </EditText> <Button android:id="@+id/button_start" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="点击开始说话" /></LinearLayout>
- 然后在MainActivity中编写代码实现了
(这里可以看到在线的文档:http://dev.voicecloud.cn/developer.php?category=YW5kcm9pZA%3D%3D&column=ZG9jdW1lbnQ%3D&type=d2lkZ2V0)
通过阅读讯飞给的文档,可以发现标准的识别控件是RecognizerDialog——是一个Dialog的子类,所以我们是可以在Activity中通过showDialog(int)方法来调用它的。
重写Activity的方法
@Overrideprotected Dialog onCreateDialog(int id) {}在其中创建并设置好一个RecognizerDialog即可。
创建RecognizerDialog方法为
RecognizerDialog recognizerDialog = new RecognizerDialog(MainActivity.this, "appid=1234567");// 这里应该写从科大讯飞申请到的appid(其中appid应该写自己从讯飞申请到的appid,由于协议的问题,我不便把自己申请的id公开,所以这里用了1234567来代替。根据讯飞的说明,非法的appid是不能使用语音服务的,但是我用随机数字试验了一下,居然也是能用的,不知道是不是BUG。)
官方的文档:
然后需要设置识别参数
recognizerDialog.setEngine("sms", null, null);第一个参数“sms”表示为请求的服务为“语音识别”。后两个参数暂时设为null就好。
官方文档:
最后还需给recognizerDialog设置一个listener,回调接口用以获取结果,
recognizerDialog.setListener(RecognizerDialogListener listener)的参数为RecognizerDialogListener接口,实现此接口要重写两个方法:onResults(ArrayList results,boolean isLast)和onEnd(SpeechError error)。用以获取和处理结果。
我的实现为直接写了一个匿名类:
recognizerDialog.setListener(new RecognizerDialogListener() {@Overridepublic void onResults(ArrayList<RecognizerResult> results,boolean arg1) {StringBuffer result = new StringBuffer();for (RecognizerResult r : results) {result.append(r.text);}editText.setText(result.toString());}@Overridepublic void onEnd(SpeechError arg0) {}});然后将此RecognizerDialog返回即可。
完整的MainActivity代码:
import com.iflytek.speech.RecognizerResult;import com.iflytek.speech.SpeechError;import com.iflytek.ui.RecognizerDialog;import com.iflytek.ui.RecognizerDialogListener;public class MainActivity extends Activity {EditText editText = null;Button startButton = null;@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);editText = (EditText) findViewById(R.id.editText);startButton = (Button) findViewById(R.id.button_start);startButton.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {showDialog(1);}});}@Overrideprotected Dialog onCreateDialog(int id) {RecognizerDialog recognizerDialog = new RecognizerDialog(MainActivity.this, "appid=1234567");// 这里应该写从科大讯飞申请到的appidrecognizerDialog.setEngine("sms", null, null);recognizerDialog.setListener(new RecognizerDialogListener() {@Overridepublic void onResults(ArrayList<RecognizerResult> results,boolean arg1) {StringBuffer result = new StringBuffer();for (RecognizerResult r : results) {result.append(r.text);}editText.setText(result.toString());}@Overridepublic void onEnd(SpeechError arg0) {}});return recognizerDialog;}}
程序在真机运行截图,经过检验,科大讯飞的识别率还是很高的。
demo下载地址:http://download.csdn.net/detail/barryhappy/4178459
- 我的Android笔记(十四)—— 在应用中集成科大讯飞的语音识别技术
- 在应用中集成科大讯飞的语音识别技术
- 在应用中集成科大讯飞的语音识别技术
- 关于在呼叫中心业务中应用语音识别技术的探讨
- 语音识别的技术路线学习笔记
- tcpcopy在语音识别的应用
- 语音识别系统中增加图像识别技术的设计
- 使用科大讯飞的语音技术实现语音识别
- 使用科大讯飞的语音技术实现语音识别
- 语音识别学习笔记(二)【基于矢量量化的识别技术】
- 语音识别学习笔记(三)【动态时间归正的识别技术】
- 语音识别技术的基础
- 语音识别技术的先锋
- 语音识别的技术原理
- 语音识别技术的最新进展
- 中英文语音合成与中文语音识别技术在c#中的应用(一)
- 中英文语音合成与中文语音识别技术在c#中的应用(一)
- [转]中英文语音合成与中文语音识别技术在c#中的应用(一)
- Django新手需要注意的10个要点
- encodeURIcomponent编码和ASP.NET之间编码转换
- Html5 Canvas初探学习笔记(6) -变换
- Apache and mod_jk
- 网络配置
- 我的Android笔记(十四)—— 在应用中集成科大讯飞的语音识别技术
- Nehe第13课图像字体
- Android增加SNTP网络时间同步功能
- grub
- 传统监控向IP网络监控的演变
- 在linux和windows中安装lua
- 题目1343:城际公路网
- 网卡驱动注册到PCI总线这一过程的分析 [复制链接]
- 分支结构函数设计小结