赞
踩
最近用到了,讯飞语音,所以简单给大家介绍一下怎么加入语音朗读;
在工程 AndroidManifest.xml 文件中添加如下权限
- <!--连接网络权限,用于执行云端语音能力 -->
- <uses-permission android:name="android.permission.INTERNET"/>
- <!--获取手机录音机使用权限,听写、识别、语义理解需要用到此权限 -->
- <uses-permission android:name="android.permission.RECORD_AUDIO"/>
- <!--读取网络信息状态 -->
- <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
- <!--获取当前wifi状态 -->
- <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
- <!--允许程序改变网络连接状态 -->
- <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE"/>
- <!--读取手机信息权限 -->
- <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
- <!--读取联系人权限,上传联系人需要用到此权限 -->
- <uses-permission android:name="android.permission.READ_CONTACTS"/>
- <!--外存储写权限,构建语法需要用到此权限 -->
- <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
- <!--外存储读权限,构建语法需要用到此权限 -->
- <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
- <!--配置权限,用来记录应用配置信息 -->
- <uses-permission android:name="android.permission.WRITE_SETTINGS"/>
- <!--手机定位信息,用来为语义等功能提供定位,提供更精准的服务-->
- <!--定位信息是敏感信息,可通过Setting.setLocationEnable(false)关闭定位请求 -->
- <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
- <!--如需使用人脸识别,还要添加:摄相头权限,拍照需要用到 -->
- <uses-permission android:name="android.permission.CAMERA" />
初始化即 创建 语音配置对象 语音配置对象 ,只有初始化 ,只有初始化 ,只有初始化 后才可以使用 后才可以使用 后才可以使用 MSC MSC的各项 服务 。建议 将初始化放 将初始化放 在程 序入口处 (如 、activity 的 onCreate方法 ,一般是放在 Application 里), 方法), 初始化代码如下:
SpeechUtility.createUtility(SpeechApp.this, "appid=" + “你申请的KEY”));
- // 初始化合成对象
- mTts = SpeechSynthesizer.createSynthesizer(this, mTtsInitListener);
-
- //设置参数
-
- // 清空参数
- mTts.setParameter(SpeechConstant.PARAMS, null);
- // 根据合成引擎设置相应参数
- if(mEngineType.equals(SpeechConstant.TYPE_CLOUD)) {
- mTts.setParameter(SpeechConstant.ENGINE_TYPE, SpeechConstant.TYPE_CLOUD);
- // 设置在线合成发音人
- mTts.setParameter(SpeechConstant.VOICE_NAME,voicer);
- }else {
- mTts.setParameter(SpeechConstant.ENGINE_TYPE, SpeechConstant.TYPE_LOCAL);
- // 设置本地合成发音人 voicer为空,默认通过语音+界面指定发音人。
- mTts.setParameter(SpeechConstant.VOICE_NAME,"");
- }
- //设置合成语速
- mTts.setParameter(SpeechConstant.SPEED, "50");
- //设置合成音调
- mTts.setParameter(SpeechConstant.PITCH, "50");
- //设置合成音量
- mTts.setParameter(SpeechConstant.VOLUME,"50");
- //设置播放器音频流类型
- mTts.setParameter(SpeechConstant.STREAM_TYPE,"3");
-
- // 设置播放合成音频打断音乐播放,默认为true
- mTts.setParameter(SpeechConstant.KEY_REQUEST_FOCUS, "true");
-
- // 设置合成音频保存路径,设置路径为sd卡请注意WRITE_EXTERNAL_STORAGE权限
- mTts.setParameter(SpeechConstant.PARAMS,"tts_audio_path="+Environment.getExternalStorageDirectory()+"/test.pcm");
-
完成,给它文字,他就可以说话了;
//这里填写的内容就是会被 朗读的内容
- String sayContext = "你想做什么?";
- int code = mTts.startSpeaking(sayContext, mTtsListener);
就是这么简单,我把demo,再简化了一下,更适合初学者看;
退出时记得:
- mTts.stopSpeaking();
- // 退出时释放连接
http://download.csdn.net/detail/q610098308/8800713
视频教程:https://edu.csdn.net/course/detail/2932 Android 实战开发 三方SDK 讯飞语音SDK
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。