关于项目中个使用到的自然语言语音转文字&文字转语言的个人总结:

VOICE_NAME, "xiaoyan");speechSynthesizer.setParameter(SpeechConstant.SPEED, "50");//语速
speechSynthesizer.setParameter(SpeechConstant.VOLUME, "50");//音量,范围是0---100
speechSynthesizer.setParameter(SpeechConstant.PITCH, "50");
}
/**
* percent 缓冲进度 0-100
* beginPos 缓冲音频在文中的开始位置
* endPos 缓冲音频在文中的末位置
* info 附加信息
* */
@Override
public void onBufferProgress(int percent, int beginPos, int endPos, String info) { }
//会话结束回调接口,无错误时err为null
@Override
public void onCompleted(SpeechError err) { }
//开始播放
@Override
public void onSpeakBegin() { }
//暂停播放
@Override
public void onSpeakPaused() { }
/**
* percent 播放进度 0-100
* beginPos 播放音频在文中的开始位置
* endPos 播放音频在文中的末位置
* */
@Override
public void onSpeakProgress(int percent, int beginPos, int endPos) { }
//恢复 播放
@Override
public void onSpeakResumed() { }}

最后的是把你的话转为文字

package zy.voice;
import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.os.Environment;
import android.text.TextUtils;
import android.widget.Toast;
import com.iflytek.cloud.speech.SpeechConstant;
import com.iflytek.cloud.speech.SpeechError;
import com.iflytek.cloud.speech.SpeechListener;
import com.iflytek.cloud.speech.SpeechRecognizer;
import com.iflytek.cloud.speech.SpeechUser;
import com.iflytek.cloud.ui.RecognizerDialog;
import com.iflytek.cloud.ui.RecognizerDialogListener;
import com.iflytek.sunflower.FlowerCollector;
public class VoiceToWord extends Activity {
private Context context;
private Toast mToast;
// 识别窗口
private RecognizerDialog iatDialog;
// 识别对象
private SpeechRecognizer iatRecognizer;
// 缓存,保存当前的引擎参数到下一次启动应用程序使用.
private SharedPreferences mSharedPreferences;
private RecognizerDialogListener recognizerDialogListener = null;
public VoiceToWord(Context context, String APP_ID) {
// TODO Auto-generated constructor stub
// 用户登录
this.context = context;
// 初始化缓存对象.
mSharedPreferences = context.getSharedPreferences(
context.getPackageName(), MODE_PRIVATE);
SpeechUser.getUser().login(context, null, null, "appid=" + APP_ID,
listener);
// 初始化听写Dialog,如果只使用有UI听写功能,无需创建SpeechRecognizer
iatDialog = new RecognizerDialog(context);
mToast = Toast.makeText(context, "", Toast.LENGTH_LONG);
// 初始化听写Dialog,如果只使用有UI听写功能,无需创建SpeechRecognizer
iatDialog = new RecognizerDialog(context);
iatDialog.setCanceledOnTouchOutside(false);
}
public VoiceToWord(Context context, String APP_ID,
RecognizerDialogListener recognizerDialogListener) {
this.context = context;
SpeechUser.getUser().login(context, null, null, "appid=" + APP_ID,
listener);
// 初始化听写Dialog,如果只使用有UI听写功能,无需创建SpeechRecognizer
iatDialog = new RecognizerDialog(context);
mToast = Toast.makeText(context, "", Toast.LENGTH_LONG);
// 初始化听写Dialog,如果只使用有UI听写功能,无需创建SpeechRecognizer
iatDialog = new RecognizerDialog(context);
// 在dialog外面不能取消
iatDialog.setCanceledOnTouchOutside(false);
// 初始化缓存对象.
mSharedPreferences = context.getSharedPreferences(
context.getPackageName(), MODE_PRIVATE);
this.recognizerDialogListener = recognizerDialogListener;
}
public void GetWordFromVoice() {
boolean isShowDialog = mSharedPreferences.getBoolean("iat_show", true);
if (isShowDialog) {
// 显示语音听写Dialog.
showIatDialog();
} else {
if (null == iatRecognizer) {
iatRecognizer = SpeechRecognizer.createRecognizer(this);
// 设置返回结果格式
// iatRecognizer.setParameter(SpeechConstant.RESULT_TYPE, "json");
//
// String lag = mSharedPreferences.getString(
// "iat_language_preference", "mandarin");
// if (lag.equals("en_us")) {
// // 设置语言
// iatRecognizer
// .setParameter(SpeechConstant.LANGUAGE, "en_us");
// } else {
// // 设置语言
// iatRecognizer
// .setParameter(SpeechConstant.LANGUAGE, "zh_cn");
// // 设置语言区域
// iatRecognizer.setParameter(SpeechConstant.ACCENT, lag);
// }
// // 设置语音前端点
// iatRecognizer.setParameter(SpeechConstant.VAD_BOS,
// mSharedPreferences.getString("iat_vadbos_preference",
// "4000"));
// // 设置语音后端点
// iatRecognizer.setParameter(SpeechConstant.VAD_EOS,
// mSharedPreferences.getString("iat_vadeos_preference",
// "1000"));
// // 设置标点符号
// iatRecognizer.setParameter(SpeechConstant.ASR_PTT,
// mSharedPreferences
// .getString("iat_punc_preference", "1"));
// // 设置音频保存路径
// iatRecognizer.setParameter(SpeechConstant.ASR_AUDIO_PATH,
// Environment.getExternalStorageDirectory()
// + "/iflytek/wavaudio.pcm");//需在清单文件里添加sd卡的权限
}
if (iatRecognizer.isListening()) {
iatRecognizer.stopListening();
// ((Button)
// findViewById(android.R.id.button1)).setEnabled(false);
} else {
}
}
} /**
* 显示听写对话框.
*
* @param
*/
public void showIatDialog() {
if (null == iatDialog) {
// 初始化听写Dialog
iatDialog = new RecognizerDialog(this);
}
// 获取引擎参数
String engine = mSharedPreferences.getString("iat_engine", "iat");
// 清空Grammar_ID,防止识别后进行听写时Grammar_ID的干扰
iatDialog.setParameter(SpeechConstant.CLOUD_GRAMMAR, null);
// 设置听写Dialog的引擎
iatDialog.setParameter(SpeechConstant.DOMAIN, engine);
// 设置采样率参数,支持8K和16K
String rate = mSharedPreferences.getString("sf", "sf");
if (rate.equals("rate8k")) {
iatDialog.setParameter(SpeechConstant.SAMPLE_RATE, "8000");
} else {
iatDialog.setParameter(SpeechConstant.SAMPLE_RATE, "16000");
}
if (recognizerDialogListener == null) {
getRecognizerDialogListener();
}
// 显示听写对话框
iatDialog.setListener(recognizerDialogListener);
iatDialog.show();
}
private void getRecognizerDialogListener() {
/**
* 识别回调监听器
*/
recognizerDialogListener = new MyRecognizerDialogLister(context);
}
/**
* 用户登录回调监听器.
*/
private SpeechListener listener = new SpeechListener() {
@Override
public void onData(byte[] arg0) {
}
@Override
public void onCompleted(SpeechError error) {
if (error != null) {
System.out.println("user login success");
}
}
@Override
public void onEvent(int arg0, Bundle arg1) {
}
};
protected void onDestroy() {
// 退出时释放连接
iatRecognizer.cancel();
iatRecognizer.destroy();
};
@Override
protected void onResume() {
// 移动数据统计分析
FlowerCollector.onResume(this);
FlowerCollector.onPageStart("VoiceToWord");
super.onResume();
}
@Override
protected void onPause() {
// 移动数据统计分析
FlowerCollector.onPageEnd("VoiceToWord");
FlowerCollector.onPause(this);
super.onPause();
}
}

最后别忘了添加权限

如果您愿意花几块钱请我喝杯茶的话,可以用手机扫描下方的二维码,通过 支付宝 捐赠。我会努力写出更好的文章。 
(捐赠不显示捐赠者的个人信息,如需要,请注明您的联系方式) 
Thank you for your kindly donation!!


 
 

自然语言交流系统 phxnet团队 创新实训 个人博客 (四)的更多相关文章

  1. 自然语言交流系统 phxnet团队 创新实训 个人博客 (五)

    有关我们这个项目:智能自然语言交流系统,所借鉴的技术有: 第一:我们使用了科大讯飞的在线语音转换,涉及的有文本传给云端服务器的文字转换成语音和本地的语音上传给服务器转换成文字. 涉及的相关的代码有: ...

  2. 自然语言交流系统 phxnet团队 创新实训 项目博客 (四)

    刚开始做时,一点头绪都没有,整天的上网找资料,各种谷歌百度,各种博客论坛,搜索的关键词也无非是智能自然语言交流.智能机器人.中文问答系统等等等等.而我们的思路也是些零散的,例如我们知道会用到分词,会用 ...

  3. 自然语言交流系统 phxnet团队 创新实训 项目博客 (二)

    基本要求 打开软件,即可进入2D文本交流界面, 软件此时已经连接到服务器,点击文本输入框输入你想说的话,点击发送按钮即可进行交流,点击CHAT和STUDY分别切换到聊天模式或是学习模式,聊天模式是机器 ...

  4. 自然语言交流系统 phxnet团队 创新实训 个人博客 (十一)

    名思义是 给游戏场景 添加一个 天空背景 让游戏更加精美,更具有魅力 添加天空盒 有两种方式  1 : 在当前相机上添加skybox   2 : 在当前场景上添加skybox 上面的两种方式的结果是一 ...

  5. 自然语言交流系统 phxnet团队 创新实训 个人博客 (九)

    情感倾向可认为是主体对某一客体主观存在的内心喜恶,内在评价的一种倾向.它由两个方面来衡量:一个情感倾向方向,一个是情感倾向度. 情感倾向方向也称为情感极性.在微博中,可以理解为用户对某客体表达自身观点 ...

  6. 自然语言交流系统 phxnet团队 创新实训 项目博客 (十四)

    项目技术借鉴报告: 一.服务器端(Server) 1.分词 分词使用的是庖丁分词.使用盘古分词词库和词素作为辅助.其中包括下载Jar包并且使用. 2.人工神经网络 以网上已有的初级网络为蓝图,结合机器 ...

  7. 自然语言交流系统 phxnet团队 创新实训 项目博客 (十三)

    对我们项目中的关键技术实现进行总结: 一.3DMax关键技术实现 1.一下的关于3DMax中对于人物的设计和操作均需要在对3DMax基础知识熟练掌握的情况下进行的. 2. 骨骼架设:首先对导入到3DM ...

  8. 自然语言交流系统 phxnet团队 创新实训 项目博客 (十二)

    关于情感词典的学习总结: 情感倾向可认为是主体对某一客体主观存在的内心喜恶,内在评价的一种倾向.它由两个方面来衡量:一个情感倾向方向,一个是情感倾向度. 情感倾向方向也称为情感极性.在微博中,可以理解 ...

  9. 自然语言交流系统 phxnet团队 创新实训 项目博客 (五)

    3DMax方面所涉及的专业知识:                       (1)一下的关于3DMax中对于人物的设计和操作均需要在对3DMax基础知识熟练掌握的情况下进行的. (2)骨骼架设:首先 ...

随机推荐

  1. 2.2 Apache Axis2 快速学习手册之 AXIOM 构建 Web Service

    和上一篇的POJO 部署相比主要是services.xml 中配置的消息接受处理器类不一样和Java 类中写法不一样. 使用AXIOM构建服务 样例源码路径: C:\Apps\axis2\axis2- ...

  2. CSS中字体响应式的设置

    在进行页面响应式设计中,往往需要根据屏幕分辨率来显示不同大小的字体.通常的做法是通过media queries给不同的分辨率指定不同的字体样式,例如: body { font-size: 22px; ...

  3. redis-3.0.0_rc5的RPM包制定

    首先查看脚本: # cat /tmp/redis_before.sh #!/bin/bash if [ ! -d /apps/redis-3.0.0-rc5 ];then mkdir -p /apps ...

  4. HTML5学习笔记(二十三):DOM应用之动态加载脚本

    同步加载和执行JS的情况 在HTML页面的</body>表情之前添加的所有<script>标签,无论是直接嵌入JS代码还是引入外部js代码都是同步执行的,这里的同步执行指的是在 ...

  5. Python2.7 fabric理论学习

    在python中有一个可以实现批量管理服务器的工具:fabric,在本地和远程机器上提供了一些基本的操作,并且可以上传/下载文件.执行sudo等功能. 学习环境:ubuntu 12.10+python ...

  6. [iOS]终极横竖屏切换解决方案

    [iOS]终极横竖屏切换解决方案 大家的项目都是只支持竖屏的吧?大多数朋友(这其中当然也包括博主),都没有做过横屏开发,这次项目刚好有这个需求,因此把横竖屏相关的心得写成一遍文章供诸位参考. 01.综 ...

  7. MyBatis 问题列表

    问题表现:The content of elements must consist of well-formed character data or markup 解决办法:1.配置的动态SQL语句里 ...

  8. webpack的代码分割/离

    两种方法: 1.webpack的methods----require.ensure 2.ES 2015的Loader spec //require.ensure语法 require.ensure [] ...

  9. git file mode change

    近期在做ffmpeg版本合并时发现,TortoiseGit的Check for Modifications的修改对话框中有未修改的问题,直接导出diff,会有类似下面的输出: compat/plan9 ...

  10. android下使用adb启动程序或者服务

    susetprop service.adb.tcp.prot 5555stop adbdstart adbdnetstat 使用 adb install hello.apk可以安装一个apk但并不能启 ...