`

android语音识别之科大讯飞语音API的使用

阅读更多
布局文件:

<?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/et"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content" />

    <Button
        android:id="@+id/bt_recognize"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text="Recognize" />

    <Button
        android:id="@+id/bt_speek"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text="Speek" />

    <Button
        android:id="@+id/bt_speek_bg"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text="Speek-Background" />

</LinearLayout>


Activity代码如下:
package sina.CreAmazing.voice;

import java.util.ArrayList;

import com.iflytek.speech.RecognizerResult;
import com.iflytek.speech.SpeechError;
import com.iflytek.speech.SynthesizerPlayer;
import com.iflytek.ui.RecognizerDialog;
import com.iflytek.ui.RecognizerDialogListener;
import com.iflytek.ui.SynthesizerDialog;
import com.iflytek.ui.SynthesizerDialogListener;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;

public class Voice1Activity extends Activity {
	/** Called when the activity is first created. */
	// 声明控件
	private EditText et;
	private Button bt1;
	private Button bt2;
	private Button bt3;
	//全局只设一个String,因为String为final类型,这样做节省内存
	String text = "";
	private static final String APPID = "appid=4f2d3a06";

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		bt1 = (Button) findViewById(R.id.bt_recognize);
		bt2 = (Button) findViewById(R.id.bt_speek);
		bt3 = (Button) findViewById(R.id.bt_speek_bg);
		et = (EditText) findViewById(R.id.et);
		// 初始化监听器
		initListener();

	}

	private void initListener() {
		bt1.setOnClickListener(myListener);
		bt2.setOnClickListener(myListener);
		bt3.setOnClickListener(myListener);

	}

	OnClickListener myListener = new OnClickListener() {

		@Override
		public void onClick(View v) {
			// 根据不同View的id调用不同方法
			switch (v.getId()) {
			case R.id.bt_recognize:
				// 这是语言识别部分,最重要的实例化一个
				// RecognizerDialog并把你在官方网站申请的appid填入进去,非法id不能进行识别
				RecognizerDialog isrDialog = new RecognizerDialog(
						Voice1Activity.this, APPID);

				/*
				 * 设置引擎目前支持五种 ”sms”:普通文本转写 “poi”:地名搜索 ”vsearch”:热词搜索
				 * ”video”:视频音乐搜索 ”asr”:命令词识别
				 */
				isrDialog.setEngine("sms", null, null);
				isrDialog.setListener(recoListener);
				isrDialog.show();
				break;
			case R.id.bt_speek:
				// 这是语言合成部分 同样需要实例化一个SynthesizerDialog ,并输入appid
				SynthesizerDialog syn = new SynthesizerDialog(
						Voice1Activity.this, APPID);
				syn.setListener(new SynthesizerDialogListener() {

					@Override
					public void onEnd(SpeechError arg0) {

					}
				});
				// 根据EditText里的内容实现语音合成
				syn.setText(et.getText().toString(), null);
				syn.show();
				break;
			case R.id.bt_speek_bg:
				// 这是后台朗读,实例化一个SynthesizerPlayer
				SynthesizerPlayer player = SynthesizerPlayer
						.createSynthesizerPlayer(Voice1Activity.this, APPID);
				// 设置语音朗读者,可以根据需要设置男女朗读,具体请看api文档和官方论坛
				player.setVoiceName("vivixiaomei");
				player.playText(et.getText().toString(), "ent=vivi21,bft=5",
						null);
				break;
			default:
				break;
			}

		}
	};
	// 语言识别监听器,有两个方法
	RecognizerDialogListener recoListener = new RecognizerDialogListener() {

		@Override
		public void onResults(ArrayList<RecognizerResult> results,
				boolean isLast) {
			// 服务器识别完成后会返回集合,我们这里就只得到最匹配的那一项
			text += results.get(0).text;
			System.out.println(text);
		}

		@Override
		public void onEnd(SpeechError error) {
			if (error == null) {
				// 完成后就把结果显示在EditText上
				et.setText(text);
			}

		}

	};

}
分享到:
评论

相关推荐

    基于科大讯飞语音识别demo(离线)

    科大讯飞提供了Android SDK,包含了一系列用于语音识别的API接口,开发者可以方便地将其集成到自己的应用程序中。这个SDK包含了录音、识别、合成等功能,其中离线语音识别部分则需要配合离线语音包使用。 **三、...

    科大讯飞语音识别(离线+在线)完整工程源代码可运行

    本文将详细讲解基于科大讯飞的语音识别技术,包括离线和在线两种模式,并结合提供的源代码工程,深入解析其工作原理和实现步骤。在Android平台上,利用Java语言进行开发,开发者可以有效地将语音转化为文字,提升...

    基于科大讯飞语音识别demo

    科大讯飞作为国内领先的语音技术提供商,其提供的语音识别API和服务在业界享有较高的声誉。本文将基于一个名为“基于科大讯飞语音识别demo”的C#项目,深入探讨如何利用科大讯飞的SDK进行语音识别,并解决实际开发中...

    Android 科大讯飞 离线版 命令词识别

    首先,我们要了解科大讯飞的离线语音识别引擎是如何工作的。它基于深度学习算法,通过预先训练的模型,将接收到的语音信号转换为文字。这个过程包括声学模型和语言模型的匹配,声学模型负责将声音转化为特征向量,而...

    科大讯飞语音识别SDK——java版

    **科大讯飞语音识别SDK——Java版** 科大讯飞作为国内领先的语音技术提供商,其推出的语音识别SDK为开发者提供了强大的语音处理能力。在Java平台上,科大讯飞的SDK使得开发者能够轻松地将语音识别功能集成到自己的...

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

    科大讯飞的SDK为开发者提供了丰富的API,可以轻松地将语音识别和语音合成功能集成到Android应用中。 1. **语音识别**: - **SDK引入**:首先,你需要在项目中引入科大讯飞的语音识别SDK。这通常通过在`build....

    科大讯飞语音识别demo

    科大讯飞的`iat-js-demo`很可能是一个基于JavaScript的演示项目,展示了如何在Web应用中使用科大讯飞的语音识别API。开发者可以通过这个Demo了解以下内容: 1. **API集成**:学习如何在JavaScript代码中调用科大讯...

    Android 科大讯飞语音引擎

    综上所述,Android 科大讯飞语音引擎以其先进的语音识别和合成技术,为开发者和用户提供了高效、便捷的语音交互解决方案。无论是在日常生活还是工作中,都能看到其广泛且深远的影响。对于想要提升应用互动体验的...

    科大讯飞语音转写基于科大讯飞WebApi接口的安卓实现源码

    语音转写基于科大讯飞WebApi接口的安卓实现--上传录音音频翻译成文字 实现方法链接:https://blog.csdn.net/qq_33315364/article/details/104668152#comments_12152992

    谷歌和科大讯飞语音识别

    1. **科大讯飞语音接口** 科大讯飞提供了SDK供开发者集成,主要包含两个关键组件:语音识别服务和语音合成服务。对于语音识别,科大讯飞的API支持在线和离线模式。在线模式需要网络连接,提供实时的语音转文本功能...

    Android实战——科大讯飞语音听写SDK的使用,实现语音识别功能

    以上就是Android项目中集成并使用科大讯飞语音听写SDK的基本流程。实际开发中,可能还需要根据具体需求进行定制化调整,比如增加语音唤醒、离线识别等功能。通过熟练掌握这些技术,你可以构建出具有强大语音识别能力...

    高版本Android科大讯飞语音引擎3.0 已修改版本号,可安装高版本Android

    本文将详细介绍科大讯飞语音引擎3.0针对高版本Android的适配与优化,帮助开发者和用户更好地理解和使用这一强大的语音技术。 一、科大讯飞语音引擎3.0概述 科大讯飞语音引擎3.0是一款集成了多种语音识别、合成、...

    科大讯飞SDK语言人脸识别Demo,Android Studio可用

    本篇文章将深入探讨如何在Android Studio环境下利用科大讯飞的SDK实现语言人脸识别功能,并涉及语音识别、语音合成以及声纹识别等多个关键知识点。 1. **科大讯飞SDK介绍** 科大讯飞SDK提供了丰富的AI服务,包括但...

    ReactNative下的科大讯飞语音库可以进行语音识别与语音合成

    在React Native框架中,开发者可以利用各种第三方库来扩展原生功能,其中之一就是科大讯飞的语音库。本文将详细探讨如何在React Native项目中集成科大讯飞的语音识别与语音合成功能,以及相关的JavaScript开发和混合...

    qt实现科大讯飞在线语音识别

    在本文中,我们将深入探讨如何使用Qt框架来实现科大讯飞在线语音识别功能,以及这一过程中的关键知识点。科大讯飞是中国领先的语音技术提供商,其API接口为开发者提供了强大的语音转文字服务。Qt是一个跨平台的C++...

    android科大讯飞语音识别

    首先,我们要了解**科大讯飞语音SDK**的基本概念。科大讯飞SDK包含了一系列API和工具,可以帮助开发者快速地在Android应用中实现语音交互。这些API涵盖了语音识别、语音合成、语音唤醒等多个领域,为开发者提供了...

    语音合成和语音听写,科大讯飞android

    VioceDemo可能是科大讯飞提供的一个演示程序,展示了如何使用SDK进行语音听写的全过程,包括启动录音、处理语音流、接收识别结果等关键步骤。 在实际开发中,为了保证用户体验,还需要关注以下几点: 1. 权限管理:...

Global site tag (gtag.js) - Google Analytics