Android实现语音合成与识别功能
作者:suancaiyucoding 发布时间:2023-10-01 01:41:00
标签:Android,语音合成,语音识别
Android语音合成与语音识别,供大家参考,具体内容如下
这里调用科大讯飞语音的API,语音云开放平台介绍
调用科大讯飞语音的API,需要加添库文件Msc.jar,添加libmsc.so文件,还需添加权限,具体步骤可参看SDK里的文档
参看开发的文档写了一个简单的语音合成和识别demo,图示如下
在EditText里输入文字,点击语音合成,可以实现文字转化为语音
点击语音合成,输入语音,识别的文字以提示的形式显示,并且显示在EditText中
主要代码如下,注意appid需要自己申请
package com.example.voice;
import java.util.ArrayList;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import com.iflytek.cloud.speech.*;
public class VoiceActivity extends Activity {
private static final String APPID = "appid=52cddb99";
private EditText et = null;
private Button btn1 = null;
private Button btn2 = null;
String text = "";
String temp="";
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_voice);
et = (EditText) findViewById(R.id.et);
btn1 = (Button) findViewById(R.id.btn1);
btn1.setOnClickListener(mylistener);
btn2 = (Button) findViewById(R.id.btn2);
btn2.setOnClickListener(mylistener);
}
private OnClickListener mylistener = new OnClickListener() {
public void onClick(View v) {
SpeechUser.getUser().login(VoiceActivity.this, null, null, APPID,
loginListener);
Button btn = (Button) v;
switch (btn.getId()) {
case R.id.btn1:
SpeechSynthesizer mSpeechSynthesizer = SpeechSynthesizer
.createSynthesizer(VoiceActivity.this);
mSpeechSynthesizer.setParameter(SpeechConstant.VOICE_NAME,
"xiaoyu");
mSpeechSynthesizer.setParameter(SpeechConstant.SPEED, "50");
mSpeechSynthesizer.startSpeaking(et.getText().toString(),
mSynListener);
break;
case R.id.btn2:
text = "";
temp="";
SpeechRecognizer recognizer = SpeechRecognizer
.createRecognizer(VoiceActivity.this);
recognizer.setParameter(SpeechConstant.DOMAIN, "iat");
recognizer.setParameter(SpeechConstant.LANGUAGE, "zh_cn");
recognizer.setParameter(SpeechConstant.ACCENT, "accent");
recognizer.startListening(mRecoListener);
break;
}
}
};
private SynthesizerListener mSynListener = new SynthesizerListener() {
public void onBufferProgress(int arg0, int arg1, int arg2, String arg3) {
}
public void onCompleted(SpeechError arg0) {
}
public void onSpeakBegin() {
}
public void onSpeakPaused() {
}
public void onSpeakProgress(int arg0, int arg1, int arg2) {
}
public void onSpeakResumed() {
}
};
private RecognizerListener mRecoListener = new RecognizerListener() {
public void onBeginOfSpeech() {
}
public void onEndOfSpeech() {
}
public void onError(SpeechError error) {
}
public void onEvent(int arg0, int arg1, int arg2, String arg3) {
}
public void onVolumeChanged(int arg0) {
}
public void onResult(RecognizerResult results, boolean isLast) {
//将解析后的字符串连在一起
temp=results.getResultString();
JsonParser json = new JsonParser();
text+=json.parseIatResult(temp);
if(isLast==true)
{
et.setText(text, null);
Toast.makeText(VoiceActivity.this,text,Toast.LENGTH_LONG).show();
}
}
};
private SpeechListener loginListener = new SpeechListener() {
public void onCompleted(SpeechError arg0) {
}
public void onData(byte[] arg0) {
}
public void onEvent(int arg0, Bundle arg1) {
}
};
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.voice, menu);
return true;
}
}
布局文件
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".VoiceActivity" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:text="VoiceApplication" />
<EditText
android:id="@+id/et"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="top"
android:layout_weight="0.32" />
<Button
android:id="@+id/btn1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0.03"
android:text="语音合成" />
<Button
android:id="@+id/btn2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0.03"
android:text="语音识别" />
</TableLayout>
解析Json格式的数据是参照讯飞的文档中的
package com.example.voice;
import org.json.JSONArray;
import org.json.JSONObject;
import org.json.JSONTokener;
import android.text.TextUtils;
//import com.iflytek.speech.ErrorCode;
//import com.iflytek.speech.SpeechError;
/**
* 对云端返回的Json结果进行解析
*
* @author iFlytek
* @since 20131211
*/
public class JsonParser {
/**
* 听写结果的Json格式解析
*
* @param json
* @return
*/
public static String parseIatResult(String json) {
if (TextUtils.isEmpty(json))
return "";
StringBuffer ret = new StringBuffer();
try {
JSONTokener tokener = new JSONTokener(json);
JSONObject joResult = new JSONObject(tokener);
JSONArray words = joResult.getJSONArray("ws");
for (int i = 0; i < words.length(); i++) {
// 听写结果词,默认使用第一个结果
JSONArray items = words.getJSONObject(i).getJSONArray("cw");
JSONObject obj = items.getJSONObject(0);
ret.append(obj.getString("w"));
// 如果需要多候选结果,解析数组其他字段
// for(int j = 0; j < items.length(); j++)
// {
// JSONObject obj = items.getJSONObject(j);
// ret.append(obj.getString("w"));
// }
}
} catch (Exception e) {
e.printStackTrace();
}
return ret.toString();
}
}
来源:https://blog.csdn.net/suancaiyucoding/article/details/19121799


猜你喜欢
- Java类之间的关系图在Java以及其他的面向对象设计模式中,类与类之间主要有6种关系,他们分别是:依赖、关联、聚合、组合、继承、实现。他们
- 区块链是目前最热门的话题,广大读者都听说过比特币,或许还有智能合约,相信大家都非常想了解这一切是如何工作的。这篇文章就是帮助你使用 Java
- 简单介绍一下Java中的Excel文件导出功能(基于HttpServletResponse实现下载)首先,引入需要依赖的jar包:<d
- xUtils简介xUtils 包含了很多实用的android工具。xUtils 支持大文件上传,更全面的http请求协议支持(10种谓词),
- 本文实例讲述了WinForm实现的图片拖拽与缩放功能。分享给大家供大家参考,具体如下:最近做项目的时候遇到上传施工平面布置图,查看,因为图片
- 在上一篇文章中我介绍了使用Intent显式来实现页面向下跳转,接下来这篇文章主要介绍的是使用Intent隐式来实现向上跳转,什么意思呢,就是
- 网络应用分为客户端和服务端两部分,而Socket类是负责处理客户端通信的Java类。通过这个类可以连接到指定IP或域名的服务器上,并且可以和
- 在移动端,各个平台或 UI 系统的原始指针事件模型基本都是一致,即:一次完整的事件分为三个阶段:手指按下、手指移动、和手指抬起,而更高级别的
- 1.EazyEmail邮件发送类库Net 类库自带了邮件发送功能。笔者对该类库,从使用的角度进行了二次封装,nuget上可搜索EazyEma
- 当初学的是通信专业,毕业以后,同学们各奔东西,去追逐自己的梦想,奔波于大大小小的工地之间。哈哈,开个玩笑,也有厉害的,进了某某研究所,嗯?他
- 本文实例为大家分享了Java实现串口通信的具体代码,供大家参考,具体内容如下1.介绍使用Java实现的串口通信程序,支持十六进制数据的发送与
- 本文实例为大家分享了Android实现选项菜单的具体代码,供大家参考,具体内容如下创建选项菜单步骤:(1)覆盖Activity的onCrea
- 本文实例为大家分享了Flutter实现顶部导航栏的具体代码,供大家参考,具体内容如下import 'package:flutter/
- 国家气象局提供了三种数据的形式网址在:http://www.weather.com.cn/data/sk/101010100.htmlhtt
- Mybatis-Plus(简称MP)是一个 Mybatis 的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发、提高效率而
- 可以用抽象工厂模式来造车。车的品牌有很多,而且车的属性也不少,比如车的类型、排量、门的数量,等等。可以提炼出有关车的一个抽象类:public
- 一:Java创建线程方式继承Thread类或者实现Runnable接口。但是Runnable 的 run() 方法是不带返回值的,那如果我们
- 开门见山 项目运行的环境里面已经有该项目的所有代码依赖,所以项目的代码只要将自己的代码打入进去就能提交到环境中运行了。但是不好的地方就是项
- NTP是Android原生通过网络获取时间的机制,其中关键代码逻辑都在NetworkTimeUpdateService,它是Android系
- 最近在做一个“温湿度控制”的项目,项目要求通过用户设定的温湿度数值和实时采集到的数值进行比对分析,因为数据的对比与分析是一个通过前端页面控制