博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在应用中集成科大讯飞的语音识别技术
阅读量:6567 次
发布时间:2019-06-24

本文共 3763 字,大约阅读时间需要 12 分钟。

语音识别技术最近貌似是越来越火了。再前几天科大讯飞还刚刚发布了讯飞语点——一个据说要挑战siri的应用。……好吧,对这些的东西讨论要说起来就多了。

本文主要讲如何在自己的android应用中集成语音识别技术——自然,是使用科大讯飞的sdk。

 

讯飞的语音sdk是需要申请的,地址是: 。申请一个讯飞的开发者账号,然后申请一个appid,申请的时候需要填写开发者信息和你的应用的信息。

申请之后经过审核通过,会得到一个appid,这个是在使用语音服务时需要用到的。(笔者感觉申请还是比较容易通过的,简单地填写一下就通过了。速度也很快,我在晚上十一点多申请的,到第二天早上九点多就收到审核通过的邮件。个人感觉这个审核只是为了防止恶意使用,毕竟语音服务是要使用讯飞的服务器资源的。)

申请到appid之后就可以下载SDK了,然后使用语音服务了。

 

以下我试用的过程,(点击button,弹出语音框,说完之后将识别的结果显示在EditText中):

 

  • 在eclipse里新建一个android工程
  • 导入讯飞的语音jar包
  • 讯飞的服务是需要一堆权限的,在manifest.xml中加入

分别为:通过麦克风录音、联网、获取网络信息状态、获取wifi状态、改变网络状态如是否能联网、访问电话状态

 

  • 在main.xml中添加一个EditText和一个Button,如下

 

  • 然后在MainActivity中编写代码实现了

 

(这里可以看到在线的文档:)

通过阅读讯飞给的文档,可以发现标准的识别控件是RecognizerDialog——是一个Dialog的子类,所以我们是可以在Activity中通过showDialog(int)方法来调用它的。

重写Activity的方法

@Override    protected 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() {            @Override            public void onResults(ArrayList
results, boolean arg1) { StringBuffer result = new StringBuffer(); for (RecognizerResult r : results) { result.append(r.text); } editText.setText(result.toString()); } @Override public 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;    @Override    public 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() {            @Override            public void onClick(View v) {                showDialog(1);            }        });    }    @Override    protected Dialog onCreateDialog(int id) {        RecognizerDialog recognizerDialog = new RecognizerDialog(                MainActivity.this, "appid=1234567");// 这里应该写从科大讯飞申请到的appid        recognizerDialog.setEngine("sms", null, null);        recognizerDialog.setListener(new RecognizerDialogListener() {            @Override            public void onResults(ArrayList
results, boolean arg1) { StringBuffer result = new StringBuffer(); for (RecognizerResult r : results) { result.append(r.text); } editText.setText(result.toString()); } @Override public void onEnd(SpeechError arg0) { } }); return recognizerDialog; }}

程序在真机运行截图,经过检验,科大讯飞的识别率还是很高的。

 

         

      

demo下载:

原文:

转载于:https://www.cnblogs.com/shanzei/archive/2012/05/10/2494487.html

你可能感兴趣的文章
敏捷开发中Scrum方法
查看>>
PG流复制一些东西
查看>>
服务器安全配置之注册表设置
查看>>
java 定时任务
查看>>
如何让头发长得更快
查看>>
Java类的连接与初始化 (及2013阿里初始化笔试题解析)
查看>>
unity优化笔记
查看>>
haproxy+keepalived应用实战
查看>>
linux
查看>>
Mongodb集群 - 副本集内部选举机制
查看>>
微软宣布 SQL Server 2019 预览版
查看>>
Lync2013 恢复-整残之后如何重新安装
查看>>
SSO 单点登录会话管理
查看>>
jpa查询记录重复
查看>>
mysql-事物实现原理
查看>>
上下滚动播报特效
查看>>
iOS 隐藏导航栏整个视图上移闪屏问题
查看>>
CentOS6.5 安装 ntopng
查看>>
python中字符串格式化
查看>>
12cR2 RAC+RAC+ADG ORA-16854
查看>>