我的Android笔记(十四)—— 在应用中集成科大讯飞的语音识别技术

原创 2012年03月27日 23:57:36

语音识别技术最近貌似是越来越火了。再前几天科大讯飞还刚刚发布了讯飞语点——一个据说要挑战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的方法

	@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<RecognizerResult> 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<RecognizerResult> 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下载地址:http://download.csdn.net/detail/barryhappy/4178459


版权声明:本文为博主原创文章,未经博主允许不得转载。

科大讯飞自定义弹出框的类

科大讯飞使用点1.有两个可以进行语音听写的类 *// 语音听写对象(可自定UI视图)* *com.iflytek.cloud.SpeechRecognizer;* `privat...

讯飞语音开发之语音语音听写

语音听写是讯飞语音的一大组成部分,也是语音开发的一个主要部分。讯飞语音听写分为带ui界面的开发和不带ui界面开发,今天我们要说的是带ui界面的开发。 在开发之前我们需要将我们从讯飞语音开放平台下载的开...
  • sz0268
  • sz0268
  • 2016年06月13日 13:59
  • 1095

Android开发集成科大讯飞语音识别+语音合成功能

1.下载SDK(地址:http://www.xfyun.cn/sdk/dispatcher),选择语音听写SDK(如下图) ,下载前会让你先创建应用,创建应用后会得到一个appid。然后点“立即开通”...
  • highboys
  • highboys
  • 2016年08月09日 12:25
  • 10445

讯飞语音听写常见问题

最近,项目中要用讯飞语音听写的功能,于是在官网学习了一下,并尝试做个小Demo,期间遇到了一些问题,列举一下:  (1)常报错误码11201,是未经授权的语音应用,意思是官方每天允许你使用的次数你已经...

讯飞语音的使用及常遇到的问题

讯飞语音是科大讯飞推出的以语音交互技术为核心的人工智能开放平台,为开发者免费提供语音识别、语音合成等语音技术SDK,人脸识别、声纹识别等。   最常遇到问题:      一、错误码21001,没有安装...

你想要的这都有-Android关于日期的工具类dateUtils:

关于日期的工具类dateUtils:直接上代码: package com.itlanbao.applib.util.date; import java.text.DateFormat; impo...

科大讯飞自定义弹出框的类

科大讯飞使用点1.有两个可以进行语音听写的类 *// 语音听写对象(可自定UI视图)* *com.iflytek.cloud.SpeechRecognizer;* `privat...

在应用中集成科大讯飞的语音识别技术

语音识别技术最近貌似是越来越火了。再前几天科大讯飞还刚刚发布了讯飞语点——一个据说要挑战siri的应用。……好吧,对这些的东西讨论要说起来就多了。 本文主要讲如何在自己的android应用中集成...

在应用中集成科大讯飞的语音识别技术

语音识别技术最近貌似是越来越火了。再前几天科大讯飞还刚刚发布了讯飞语点——一个据说要挑战siri的应用。……好吧,对这些的东西讨论要说起来就多了。 本文主要讲如何在自己的android应用中集成语音...

科大讯飞发布四川话语音识别技术,号称识别准确率超过85%

如果你实在闲的蛋疼,不妨拿起你的 iPhone 用标准的四川话对 Siri 说,“放心巴适得很绝对正宗 ”,当然来自美帝国的 Siri 是不可能听明白四川话的(但她可以听懂粤语......)。事实上不...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:我的Android笔记(十四)—— 在应用中集成科大讯飞的语音识别技术
举报原因:
原因补充:

(最多只允许输入30个字)