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

掌上快递1.4.0(http://app.xiaomi.com/detail/61427)将要更新,新增语音输入订单号功能。

语音输入集成的是科大讯飞的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天就可以审批通过。

 

    原文作者:移动开发
    原文地址: https://my.oschina.net/tomcater/blog/268768
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞