自然语言交流系统 phxnet团队 创新实训 个人博客 (四)
关于项目中个使用到的自然语言语音转文字&文字转语言的个人总结: 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团队 创新实训 个人博客 (四)的更多相关文章
- 自然语言交流系统 phxnet团队 创新实训 个人博客 (五)
有关我们这个项目:智能自然语言交流系统,所借鉴的技术有: 第一:我们使用了科大讯飞的在线语音转换,涉及的有文本传给云端服务器的文字转换成语音和本地的语音上传给服务器转换成文字. 涉及的相关的代码有: ...
- 自然语言交流系统 phxnet团队 创新实训 项目博客 (四)
刚开始做时,一点头绪都没有,整天的上网找资料,各种谷歌百度,各种博客论坛,搜索的关键词也无非是智能自然语言交流.智能机器人.中文问答系统等等等等.而我们的思路也是些零散的,例如我们知道会用到分词,会用 ...
- 自然语言交流系统 phxnet团队 创新实训 项目博客 (二)
基本要求 打开软件,即可进入2D文本交流界面, 软件此时已经连接到服务器,点击文本输入框输入你想说的话,点击发送按钮即可进行交流,点击CHAT和STUDY分别切换到聊天模式或是学习模式,聊天模式是机器 ...
- 自然语言交流系统 phxnet团队 创新实训 个人博客 (十一)
名思义是 给游戏场景 添加一个 天空背景 让游戏更加精美,更具有魅力 添加天空盒 有两种方式 1 : 在当前相机上添加skybox 2 : 在当前场景上添加skybox 上面的两种方式的结果是一 ...
- 自然语言交流系统 phxnet团队 创新实训 个人博客 (九)
情感倾向可认为是主体对某一客体主观存在的内心喜恶,内在评价的一种倾向.它由两个方面来衡量:一个情感倾向方向,一个是情感倾向度. 情感倾向方向也称为情感极性.在微博中,可以理解为用户对某客体表达自身观点 ...
- 自然语言交流系统 phxnet团队 创新实训 项目博客 (十四)
项目技术借鉴报告: 一.服务器端(Server) 1.分词 分词使用的是庖丁分词.使用盘古分词词库和词素作为辅助.其中包括下载Jar包并且使用. 2.人工神经网络 以网上已有的初级网络为蓝图,结合机器 ...
- 自然语言交流系统 phxnet团队 创新实训 项目博客 (十三)
对我们项目中的关键技术实现进行总结: 一.3DMax关键技术实现 1.一下的关于3DMax中对于人物的设计和操作均需要在对3DMax基础知识熟练掌握的情况下进行的. 2. 骨骼架设:首先对导入到3DM ...
- 自然语言交流系统 phxnet团队 创新实训 项目博客 (十二)
关于情感词典的学习总结: 情感倾向可认为是主体对某一客体主观存在的内心喜恶,内在评价的一种倾向.它由两个方面来衡量:一个情感倾向方向,一个是情感倾向度. 情感倾向方向也称为情感极性.在微博中,可以理解 ...
- 自然语言交流系统 phxnet团队 创新实训 项目博客 (五)
3DMax方面所涉及的专业知识: (1)一下的关于3DMax中对于人物的设计和操作均需要在对3DMax基础知识熟练掌握的情况下进行的. (2)骨骼架设:首先 ...
随机推荐
- sqlserver自定义函数与存储过程的区别 实例详解
分享下sql server自定义函数与存储过程的区别,一起来学习下. 一.自定义函数: 1. 可以返回表变量 2. 限制颇多,包括 不能使用output参数: 不能用临时表: 函数内部的操作不能影响到 ...
- Atitit 图像处理 halcon类库的使用 范例边缘检测 attilax总结
Atitit 图像处理 halcon类库的使用 范例边缘检测 attilax总结 1.1. 安装halcon11 ..体积大概1g压缩模式1 1.2. Halcon的科技树1 1.3. 启动 &qu ...
- unzip:unzip解压文件到指定目录
1.把文件解压到当前目录下 unzip test.zip 2.如果要把文件解压到指定的目录下,需要用到-d参数. unzip -d /temp test.zip 3.解压的时候,有时候不想覆盖已经存在 ...
- 一个分布式 MySQL Binlog 存储系统的架构设计
1. kingbus简介 1.1 kingbus是什么? kingbus是一个基于raft强一致协议实现的分布式MySQL binlog 存储系统.它能够充当一个MySQL Slave从真正的Mast ...
- 非常详尽的 Shiro 架构解析
Shiro是什么? Apache Shiro是一个强大而灵活的开源安全框架,它干净利落地处理身份认证,授权,企业会话管理和加密. Apache Shiro的首要目标是易于使用和理解.安全有时候是很复杂 ...
- numpy数组-标准化数据
标准化数据的公式: (数据值 - 平均数) / 标准差 import numpy as np employment = np.array([ 55.70000076, 51.40000153, 50. ...
- setRequestedOrientation
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);//通过程序改变屏幕显示的方向 1.landscape:横屏(风景 ...
- 【转】Android项目使用Ant打包,生成build.xml
记不住,于是原帖转过来,请看原帖:http://blog.csdn.net/ms03001620/article/details/8490238 一.生成build.xml Eclipse中使用Ant ...
- 6款漂亮HTML CSS样式用户留言表单
如今我们的网站.页面更加需要注重细节,不论是字体的样式.还是图片的分辨率清晰度都会影响到用户的访问体验和PV,以及用户以后是否会回访我们的网站/博客.如果有时间的时候,老左也会浏览和阅读相关的前端网站 ...
- Lintcode: Sort Colors II 解题报告
Sort Colors II 原题链接: http://lintcode.com/zh-cn/problem/sort-colors-ii/# Given an array of n objects ...