android语音输入,借助科大讯飞语音转化为文字实例

语音输入集成的是科大讯飞的SDK,简单的实现了语音转换为文字的过程,当然科大讯飞还提供了很多接口用来实现更加复杂的语音识别系统。

布局文件 :

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center_horizontal"
>

<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="0dip"
>
<EditText
android:id="@+id/txt_result"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:textSize="20sp"
android:paddingBottom="40dip"
android:gravity="top|left"
android:editable="false" />

</RelativeLayout>
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<Button
android:id="@+id/bt_search"
android:layout_width="0dip"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="开始说话"
>
</Button>

</LinearLayout>
</LinearLayout>
mainActivity 注释很详细,不再赘述,不明白的可以留言一起学习。

package com.test.demo;
import java.util.ArrayList;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.EditText;
import com.iflytek.speech.RecognizerResult;
import com.iflytek.speech.SpeechConfig.RATE;
import com.iflytek.speech.SpeechError;
import com.iflytek.ui.RecognizerDialog;
import com.iflytek.ui.RecognizerDialogListener;

public class HelloDemoActivity extends Activity implements OnClickListener {
protected static final String TAG = "ThirdActivity";
private EditText txt_result;
private RecognizerDialog rd;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.demo);

findView();
//RecognizerDialog(Context context, String params); "appid=1234567,usr=test,pwd=12345" usr、pwd不是必选的
//创建语音识别dailog对象,appid到讯飞就注册获取
rd = new RecognizerDialog(this ,"appid=此处填你申请到的ID");
}
private void findView() {
txt_result = (EditText) findViewById(R.id.txt_result);
findViewById(R.id.bt_search).setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.bt_search:
showReconigizerDialog();
break;
default:
break;
}
}
private void showReconigizerDialog() {
//setEngine(String engine,String params,String grammar);
/**
* 识别引擎选择,目前支持以下五种
“sms”:普通文本转写
“poi”:地名搜索
“vsearch”:热词搜索
“vsearch”:热词搜索
“video”:视频音乐搜索
“asr”:命令词识别

params 引擎参数配置列表
附加参数列表,每项中间以逗号分隔,如在地图搜索时可指定搜索区域:“area=安徽省合肥市”,无附加参数传null
*/
rd.setEngine("sms", null, null);

//设置采样频率,默认是16k,android手机一般只支持8k、16k.为了更好的识别,直接弄成16k即可。
rd.setSampleRate(RATE.rate16k);

final StringBuilder sb = new StringBuilder();
Log.i(TAG, "识别准备开始.............");

//设置识别后的回调结果
rd.setListener(new RecognizerDialogListener() {
@Override
public void onResults(ArrayList<RecognizerResult> result, boolean isLast) {
for (RecognizerResult recognizerResult : result) {
sb.append(recognizerResult.text);
Log.i(TAG, "识别一条结果为::"+recognizerResult.text);
}
}
@Override
public void onEnd(SpeechError error) {
Log.i(TAG, "识别完成.............");
txt_result.setText(sb.toString());
Log.i(TAG, "识别完成:"+txt_result.getText().toString());
}
});

txt_result.setText(""); //先设置为空,等识别完成后设置内容
rd.show();
}
}


提几个需要注意的地方:

1,如果用的是ADT开发的朋友,请连接真机测试,因为语音识别需要进行录音。

2,科大讯飞的ID请到科大讯飞(http://open.voicecloud.cn/)的开放平台进行申请,前提你先有一个提供有语音接口的APP,上传APP后会给你一个未经审核的APPID,这个ID每天的访问次数限制为500次。如果想不限次访问,可提交APP进行审批,工作人员会联系你进行确认信息,一般1-3天就可以审批通过。

 

本文由来源 开源中国,由 八百里秦川 整理编辑,其版权均为 开源中国 所有,文章内容系作者个人观点,不代表 LOCALHOST.COM.CN 对观点赞同或支持。如需转载,请注明文章来源。