Android科大讯飞语音集成,非常详细的使用讲解

讯飞语音开发集成地址http://www.xfyun.cn/ 解压后的doc文件夹下的msc develop 文件中有详细集成步骤 
这里写图片描述 
AppId:

这里写图片描述 
1.先要注册开发者账户, 添加我的应用 , 下载sdk

这里写图片描述

2.下载后将sdk解压, 把案例导入工程中运行看看效果 
这里写图片描述

3.将libs下的两个jar包添加到libs目录下, 将同路径下的其它 .so文件(与c进行交互)复制到main路径下新建的 jniLibs(L要大写)目录下(别忘了jar包要add) , 将assert目录拷贝到main目录下 
注意 : 这些都是自己创建的应用生成的, 在申请appid时就与自己的应用绑定了, 拷贝别人的是没有用的

这里写图片描述

4.添加权限

5.创建类 , 以下是代码: initSpeech()方法下的APPID需要改成上面介绍中自己应用生成的appId

 package atguigu.com.speechdemo2;import android.app.Activity ;
import android.os.Bundle ;
import android.util.Log ;
import android.view.View ;
import android.widget.Button ;
import android.widget.EditText ;
import android.widget.Toast ;import com.iflytek.cloud.ErrorCode ;
import com.iflytek.cloud.InitListener ;
import com.iflytek.cloud.RecognizerListener ;
import com.iflytek.cloud.RecognizerResult ;
import com.iflytek.cloud.SpeechConstant ;
import com.iflytek.cloud.SpeechError ;
import com.iflytek.cloud.SpeechRecognizer ;
import com.iflytek.cloud.SpeechSynthesizer ;
import com.iflytek.cloud.SpeechUtility ;
import com.iflytek.cloud.SynthesizerListener ;
import com.iflytek.cloud.ui.RecognizerDialog ;
import com.iflytek.cloud.ui.RecognizerDialogListener ;import org.json.JSONException ;
import org.json.JSONObject ;import java.util.HashMap ;
import java.util.LinkedHashMap ;public class MainActivity extends Activity implements View.OnClickListener {private static final String TAG = MainActivity.class .getSimpleName();private EditText et_input;private Button btn_startspeech, btn_startspeektext ;// 用HashMap存储听写结果private HashMap<String, String> mIatResults = new LinkedHashMap<String , String>();@Overrideprotected void onCreate(Bundle savedInstanceState) {super .onCreate(savedInstanceState) ;initView() ;initSpeech() ;}private void initView() {setContentView(R.layout.activity_main) ;et_input = (EditText) findViewById(R.id.et_input );btn_startspeech = (Button) findViewById(R.id.btn_startspeech );btn_startspeektext = (Button) findViewById(R.id.btn_startspeektext );btn_startspeech .setOnClickListener(this) ;btn_startspeektext .setOnClickListener(this) ;}private void initSpeech() {// 将“12345678”替换成您申请的 APPID,申请地址: http://www.xfyun.cn// 请勿在 “ =”与 appid 之间添加任务空字符或者转义符SpeechUtility. createUtility( this, SpeechConstant. APPID + "=56ffe0ae" ); }@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.btn_startspeech: //语音识别(把声音转文字)startSpeechDialog();break;case R.id. btn_startspeektext:// 语音合成(把文字转声音)speekText();break;}}private void speekText() {//1. 创建 SpeechSynthesizer 对象 , 第二个参数: 本地合成时传 InitListenerSpeechSynthesizer mTts = SpeechSynthesizer.createSynthesizer( this, null);
//2.合成参数设置,详见《 MSC Reference Manual》 SpeechSynthesizer 类
//设置发音人(更多在线发音人,用户可参见 附录 13.2mTts.setParameter(SpeechConstant. VOICE_NAME, "vixyun" ); // 设置发音人mTts.setParameter(SpeechConstant. SPEED, "50" );// 设置语速mTts.setParameter(SpeechConstant. VOLUME, "80" );// 设置音量,范围 0~100mTts.setParameter(SpeechConstant. ENGINE_TYPE, SpeechConstant. TYPE_CLOUD); //设置云端
//设置合成音频保存位置(可自定义保存位置),保存在 “./sdcard/iflytek.pcm”
//保存在 SD 卡需要在 AndroidManifest.xml 添加写 SD 卡权限
//仅支持保存为 pcm 和 wav 格式, 如果不需要保存合成音频,注释该行代码mTts.setParameter(SpeechConstant. TTS_AUDIO_PATH, "./sdcard/iflytek.pcm" );
//3.开始合成mTts.startSpeaking( et_input.getText().toString(), new MySynthesizerListener()) ;}class MySynthesizerListener implements SynthesizerListener {@Overridepublic void onSpeakBegin() {showTip(" 开始播放 ");}@Overridepublic void onSpeakPaused() {showTip(" 暂停播放 ");}@Overridepublic void onSpeakResumed() {showTip(" 继续播放 ");}@Overridepublic void onBufferProgress(int percent, int beginPos, int endPos ,String info) {// 合成进度}@Overridepublic void onSpeakProgress(int percent, int beginPos, int endPos) {// 播放进度}@Overridepublic void onCompleted(SpeechError error) {if (error == null) {showTip("播放完成 ");} else if (error != null ) {showTip(error.getPlainDescription( true));}}@Overridepublic void onEvent(int eventType, int arg1 , int arg2, Bundle obj) {// 以下代码用于获取与云端的会话 id,当业务出错时将会话 id提供给技术支持人员,可用于查询会话日志,定位出错原因// 若使用本地能力,会话 id为null//if (SpeechEvent.EVENT_SESSION_ID == eventType) {//     String sid = obj.getString(SpeechEvent.KEY_EVENT_SESSION_ID);//     Log.d(TAG, "session id =" + sid);//}}}private void startSpeechDialog() {//1. 创建RecognizerDialog对象RecognizerDialog mDialog = new RecognizerDialog(this, new MyInitListener()) ;//2. 设置accent、 language等参数mDialog.setParameter(SpeechConstant. LANGUAGE, "zh_cn" );// 设置中文mDialog.setParameter(SpeechConstant. ACCENT, "mandarin" );// 若要将UI控件用于语义理解,必须添加以下参数设置,设置之后 onResult回调返回将是语义理解// 结果// mDialog.setParameter("asr_sch", "1");// mDialog.setParameter("nlp_version", "2.0");//3.设置回调接口mDialog.setListener( new MyRecognizerDialogListener()) ;//4. 显示dialog,接收语音输入mDialog.show() ;}class MyRecognizerDialogListener implements RecognizerDialogListener {/*** @param results* @param isLast  是否说完了*/@Overridepublic void onResult(RecognizerResult results, boolean isLast) {String result = results.getResultString(); //为解析的showTip(result) ;System. out.println(" 没有解析的 :" + result);String text = JsonParser.parseIatResult(result) ;//解析过后的System. out.println(" 解析后的 :" + text);String sn = null;// 读取json结果中的 sn字段try {JSONObject resultJson = new JSONObject(results.getResultString()) ;sn = resultJson.optString("sn" );} catch (JSONException e) {e.printStackTrace();}mIatResults .put(sn, text) ;//没有得到一句,添加到StringBuffer resultBuffer = new StringBuffer();for (String key : mIatResults.keySet()) {resultBuffer.append(mIatResults .get(key));}et_input.setText(resultBuffer.toString());// 设置输入框的文本et_input .setSelection(et_input.length()) ;//把光标定位末尾}@Overridepublic void onError(SpeechError speechError) {}}class MyInitListener implements InitListener {@Overridepublic void onInit(int code) {if (code != ErrorCode.SUCCESS) {showTip("初始化失败 ");}}}/*** 语音识别*/private void startSpeech() {//1. 创建SpeechRecognizer对象,第二个参数: 本地识别时传 InitListenerSpeechRecognizer mIat = SpeechRecognizer.createRecognizer( this, null); //语音识别器//2. 设置听写参数,详见《 MSC Reference Manual》 SpeechConstant类mIat.setParameter(SpeechConstant. DOMAIN, "iat" );// 短信和日常用语: iat (默认)mIat.setParameter(SpeechConstant. LANGUAGE, "zh_cn" );// 设置中文mIat.setParameter(SpeechConstant. ACCENT, "mandarin" );// 设置普通话//3. 开始听写mIat.startListening( mRecoListener);}// 听写监听器private RecognizerListener mRecoListener = new RecognizerListener() {// 听写结果回调接口 (返回Json 格式结果,用户可参见附录 13.1);
//一般情况下会通过onResults接口多次返回结果,完整的识别内容是多次结果的累加;
//关于解析Json的代码可参见 Demo中JsonParser 类;
//isLast等于true 时会话结束。public void onResult(RecognizerResult results, boolean isLast) {Log.e (TAG, results.getResultString());System.out.println(results.getResultString()) ;showTip(results.getResultString()) ;}// 会话发生错误回调接口public void onError(SpeechError error) {showTip(error.getPlainDescription(true)) ;// 获取错误码描述Log. e(TAG, "error.getPlainDescription(true)==" + error.getPlainDescription(true ));}// 开始录音public void onBeginOfSpeech() {showTip(" 开始录音 ");}//volume 音量值0~30, data音频数据public void onVolumeChanged(int volume, byte[] data) {showTip(" 声音改变了 ");}// 结束录音public void onEndOfSpeech() {showTip(" 结束录音 ");}// 扩展用接口public void onEvent(int eventType, int arg1 , int arg2, Bundle obj) {}};private void showTip (String data) {Toast.makeText( this, data, Toast.LENGTH_SHORT).show() ;}
}

6.json解析类:

package atguigu.com.speechdemo2;import org.json.JSONArray ;
import org.json.JSONObject ;
import org.json.JSONTokener ;/**
* Json结果解析类
*/
public class JsonParser {public static String parseIatResult(String json) {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();}public static String parseGrammarResult(String json) {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" );for (int j = 0; j < items.length() ; j++){JSONObject obj = items.getJSONObject(j);if (obj.getString("w").contains( "nomatch")){ret.append( "没有匹配结果.") ;return ret.toString();}ret.append( "【结果】" + obj.getString("w" ));ret.append("【置信度】 " + obj.getInt("sc" ));ret.append("\n ");}}} catch (Exception e) {e.printStackTrace();ret.append(" 没有匹配结果 .");}return ret.toString();}public static String parseLocalGrammarResult(String json) {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" );for (int j = 0; j < items.length() ; j++){JSONObject obj = items.getJSONObject(j);if (obj.getString("w").contains( "nomatch")){ret.append( "没有匹配结果.") ;return ret.toString();}ret.append( "【结果】" + obj.getString("w" ));ret.append("\n ");}}ret.append("【置信度】 " + joResult.optInt("sc" ));} catch (Exception e) {e.printStackTrace();ret.append(" 没有匹配结果 .");}return ret.toString();}
}

7.布局文件: 

<? xml version="1.0" encoding= "utf-8"?>
<LinearLayout xmlns:android= "http://schemas.android.com/apk/res/android"android :layout_width="match_parent"android :layout_height="match_parent"android :orientation="vertical"><EditTextandroid :id="@+id/et_input"android :layout_margin="10dp"android :layout_width="match_parent"android :layout_height="80dp"android :hint="请输入文本信息 ..." /><Buttonandroid :id="@+id/btn_startspeech"android :text="点击按钮语音输入 "android :layout_width="match_parent"android :layout_height="wrap_content" /><Buttonandroid :id="@+id/btn_startspeektext"android :text="语音合成(把文字转声音) "android :layout_width="match_parent"android :layout_height="wrap_content" /></LinearLayout>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/41818.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android 讯飞语音识别功能开发

以下代码主要参考博客&#xff1a; Android 科大讯飞语音识别 Android蓝牙串口开发部分请参照博客&#xff1a; Android蓝牙串口开发 讯飞语音官方开发文档&#xff1a; 语音听写 Android SDK 文档 文章目录 前言一、SDK的下载和导入1.SDK的下载2.新建工程3.配置项目a.导包b.权…

uniapp - 接入科大讯飞语音评测

欢迎关注微信公众号&#xff1a;FSA全栈行动 &#x1f44b; 一、简介 科大讯飞语音评测可以对字、词、句、篇章等题型进行多维度评分&#xff08;准确度、流畅度、完整度、声韵调型等&#xff09;&#xff0c;支持中文和英文。最新的流式版使用 webSocket 调用接口&#xff0c…

目标检测算法——YOLOv5/YOLOv7改进之结合​PP-LCNet(轻量级CPU网络)

>>>深度学习Tricks&#xff0c;第一时间送达<<< 目录 ​PP-LCNet——轻量级且超强悍的CPU级骨干网络&#xff01;&#xff01; &#xff08;一&#xff09;前沿介绍 1.PP-LCNet主要模块 2.相关实验结果 &#xff08;二&#xff09;YOLOv5/YOLOv7改进之结…

从Blip2到Segment Anything视觉语义金字塔+ChatGPT= 把图片变文本段落, 8G显存即可Run...

关注公众号&#xff0c;发现CV技术之美 8G GPU显存即可以运行 Twitter链接&#xff1a;https://twitter.com/awinyimgprocess/status/1646225454599372800?s46&tHvOe9T2n35iFuCHP5aIHpQ 代码链接&#xff1a;https://github.com/showlab/Image2Paragraph https:// 01 …

目标检测算法——YOLOv5/YOLOv7改进之结合​ASPP(空洞空间卷积池化金字塔)

&#x1f496;&#x1f496;>>>加勒比海带&#xff0c;QQ2479200884<<<&#x1f496;&#x1f496; &#x1f340;&#x1f340;>>>【YOLO魔法搭配&论文投稿咨询】<<<&#x1f340;&#x1f340; ✨✨>>>学习交流 | 温澜潮…

从BLIP-2到SAM视觉语义金字塔+ChatGPT= 把图片变文本段落, 8G显存即可Run

点击下方卡片&#xff0c;关注“CVer”公众号 AI/CV重磅干货&#xff0c;第一时间送达 点击进入—>【图像分割】微信技术交流群 作者&#xff1a;老大 |&#xff08;已授权转载&#xff09;编辑&#xff1a;CVer https://zhuanlan.zhihu.com/p/621503837 8G GPU显存即可以运…

问一下ChatGPT:DIKW金字塔模型

经常看到这张DIKW金字塔模型图&#xff0c;还看到感觉有点过份解读的图&#xff0c;后面又加上了insight&#xff0c;impact等内容。 Data&#xff1a;是数据&#xff0c;零散的、无规则的呈现到人们眼前&#xff0c;如果你只看到这些数字&#xff0c;如果没有强大的知识背景&a…

QCon: 工程师成长的金字塔思维

QCon 线下会议终于来了&#xff0c;但这次的分享有一些意外&#xff0c;不是性能、架构、内核、缓存&#xff0c;而不是AI实践相关的内容&#xff0c;论坛的主题是“工程师成长实践”&#xff0c;而我的topic 是“工程师成长的金字塔思维”。本以为这是一个非热门话题&#xff…

拉普拉斯金字塔

原文 高斯金字塔G0层下采样后为G1&#xff0c;用G0减去G1的上采样&#xff0c;就得到了拉普拉斯层L0. 高斯金字塔G1层上采样后与拉普拉斯金字塔L0层相加后就得到了G0层。 import numpy as np import cv2 as cv from matplotlib import pyplot as pltimg cv.imread(left_01.png…

微信称不会推出「已读」功能;马斯克宣布成立 AI 公司 xAI;GPT-4 架构曝光,有 1.8 万亿参数|极客头条

「极客头条」—— 技术人员的新闻圈&#xff01; CSDN 的读者朋友们早上好哇&#xff0c;「极客头条」来啦&#xff0c;快来看今天都有哪些值得我们技术人关注的重要新闻吧。 整理 | 梦依丹 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 一分钟速览新闻点&…

百度版本gactgpt即将来临,gpt人工智能机器横空出世

百度版本gactgpt即将来临&#xff0c;gpt人工智能机器横空出世&#xff0c;“一言”为定&#xff01;百度版ChatGPT确认&#xff01;李彦宏OKR曝光&#xff0c;率先应用于收索业务 gactCBT 大获&#xff0c;当下极有可能成为人工智能的 iPhone 时刻。为了在这场人工智能竞赛中…

解锁实盘交易,打通量化系统交易环节!股票量化分析工具QTYX-V2.3.9

前言 本期我们把股票量化分析工具QTYX的“交易”子页面给解锁了&#xff0c;这样一来&#xff0c;就打通了量化交易系统从分析到交易的完整过程&#xff0c;注意当前的QTYX版本升级到了2.3.9。 QTYX完整架构如下所示&#xff0c;其中包括了QTYX股票量化分析系统和实盘机器人两部…

自己做量化交易软件(43)小白量化实战16--利用小白量化金融模块在恒生PTrade交易系统(交易端)上仿大智慧指标回测及实战交易设计

自己做量化交易软件(43)小白量化实战16–利用小白量化金融模块在恒生PTrade交易系统(交易端)上仿大智慧指标回测及实战交易设计 量化产品PTrade(Personalise Trade)交易系统采用事件驱动式回测平台&#xff0c;与聚宽量化平台类似的量化框架&#xff0c;内置Ta-lib金融模块&am…

量化投资 | 量化交易平台工具汇总

量化投资必备手册&#xff0c;分享30个量化交易平台给你们&#xff0c;转需&#xff0c;不用谢&#xff01; 1. 掘金量化 量化交易系统官方网址&#xff1a;https://www.myquant.cn/ 2、国泰君安量化交易系统 量化交易系统网址&#xff1a;https://quant.gtja.com/ 3. 量化云…

初学Linux—解决开机卡在用户登录界面的问题

1.Linux关机之后开机界面卡在登录界面没有反应&#xff1b; 可能是我删除了某个文件… 2.解决办法&#xff1a; ctrlaltF2 ;切换终端 su root ;切换到超级用户 然后会弹出输入密码提示&#xff0c;直接输入超级用户的密码&#xff08;注意&#xff1a;linux中密码不会回显&am…

centos6.8开机一直卡在登录界面,无法登录

** **后面发现&#xff0c;问题出在&#xff0c;前几天配置的 java的jdk&#xff0c;还有mysql的环境变量上。 ** 解决问题的方法 使用CtrlAIt F3&#xff0c;竟然命令控制面板&#xff08;但是&#xff0c;进去后&#xff0c;你使用指令&#xff0c;比如&#xff0c;vi,ls -…

Ubuntu开机后卡在登陆界面进去不

系统&#xff1a;Ubuntu18.03 系统跑代码卡死了&#xff0c;导致鼠标键盘都用不了&#xff0c;直接强制关机后&#xff0c;卡在登陆界面进不去 步骤&#xff1a; 1. 系统启动后&#xff0c;在BIOS引导界面按"ESC"键进入选择菜单&#xff0c;选择第一个"*Ubun…

记一次绕过安全狗与360艰难提权

0x01 前言背景 端午短暂休息三天&#xff0c;复工之后朋友又丢给我一个Webshell&#xff0c;在打台球途中了解了一下这个奇怪的shell&#xff0c;说是无法执行命令&#xff0c;经过测试发现只能执行dir命令&#xff0c;确实奇怪&#xff0c;草草打了几局台球就回去拿起电脑开日…

为什么我骂360弱智 周鸿祎却说“谢谢”

好吧&#xff0c;我承认我标题党了&#xff01; 不过&#xff0c;有图有真相&#xff01; 事情的起因是我在360开发者平台&#xff0c;提交了我们的客户端“缘创派”&#xff0c;这是一个给互联网创业者找创业合伙人的应用。之前上传的是1.0版本&#xff0c;最近更新了功能更为…