科大讯飞的语音合成(播放)功能

版权声明:本文为博主原创文章,如需转载请同Joern私信联系。 https://blog.csdn.net/sdsh1880gm/article/details/78672231

1.去官网注册账号

科大讯飞要求使用SDK必须注册账号并设定你的应用绑定,这样才会生成一个你的AppID,用这个ID才能在你的应用中使用讯飞的SDK

科大讯飞开放平台

2.下载SDK

注册好了以后,你必须添加你的应用,然后会出现你的专属的AppID,之后进入SDK下载界面,选择语音合成SDK包-Android-你的应用,然后就可以下载了。

3.添加libs(注意Android studio有一个坑)

  • 下载下来的文件夹里面有多个文件
assets:原生的UI资源,帮助你做一个官方的语音Dialog用的。
libs:最重要,需要把这部分移动到你的工程的libs下面
sample:官方的示例
  • 注意一点,对于Eclipse开发而言直接把libs下面的移动到你的工程的libs就可以了。但是对于Android studio(比如我)而言,你需要把这些文件移动到你的libs下,然后在你的gradle(app的)里面需要添加如下注释,然后会看到你的main目录下面多了jniLibs这个目录,这样就成功了
  sourceSets {
        main{
            jniLibs.srcDirs = ['libs']
        }
    }

我就是因为这个问题折腾了一晚上!

4.Android应用程序

1.申请权限

需要的权限包括如下

<!--连接网络权限,用于执行云端语音能力 -->  
<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"/>  

记得Android6.0之后上面有一些权限需要动态申请,主要是手机信息权限,联系人权限。

2.初始化讯飞

在Activity的onCreate中输入

SpeechUtility.createUtility(context, SpeechConstant.APPID +”=12345678”);

此处的AppID换成之前你申请的自己的ID

3.初始化语音合成功能与参数

//1.创建SpeechSynthesizer对象, 第二个参数:本地合成时传InitListener  
SpeechSynthesizer mTts= SpeechSynthesizer.createSynthesizer(context, null);  
//2.合成参数设置,详见《科大讯飞MSC API手册(Android)》SpeechSynthesizer 类  
mTts.setParameter(SpeechConstant.VOICE_NAME, "xiaoyan");//设置发音人  
mTts.setParameter(SpeechConstant.SPEED, "50");//设置语速  
mTts.setParameter(SpeechConstant.VOLUME, "80");//设置音量,范围0~100  
mTts.setParameter(SpeechConstant.ENGINE_TYPE, SpeechConstant.TYPE_CLOUD); //设置云端  
//设置合成音频保存位置(可自定义保存位置),保存在“./sdcard/iflytek.pcm”  
//保存在SD卡需要在AndroidManifest.xml添加写SD卡权限  
//如果不需要保存合成音频,注释该行代码  
mTts.setParameter(SpeechConstant.TTS_AUDIO_PATH, "./sdcard/iflytek.pcm");   

上面那些参数都可以自己调的,具体参数请参见官方SDK文档

4.设置监听器

/**
     * 语音合成监听
     */
    private SynthesizerListener mSynListener = new SynthesizerListener() {
        // 会话结束回调接口,没有错误时,error为null
        public void onCompleted(SpeechError error) {
            if (error != null) {
                Log.d("mySynthesiezer complete code:", error.getErrorCode()
                        + "");
            } else {
                Log.d("mySynthesiezer complete code:", "0");
            }
        }

        // 缓冲进度回调
        // percent为缓冲进度0~100,beginPos为缓冲音频在文本中开始位置,endPos表示缓冲音频在文本中结束位置,info为附加信息。
        public void onBufferProgress(int percent, int beginPos, int endPos,
                String info) {
        }

        // 开始播放
        public void onSpeakBegin() {
        }

        // 暂停播放
        public void onSpeakPaused() {
        }

        // 播放进度回调
        // percent为播放进度0~100,beginPos为播放音频在文本中开始位置,endPos表示播放音频在文本中结束位置.
        public void onSpeakProgress(int percent, int beginPos, int endPos) {
        }

        // 恢复播放回调接口
        public void onSpeakResumed() {
        }

        // 会话事件回调接口
        public void onEvent(int arg0, int arg1, int arg2, Bundle arg3) {
        }
    };

监听器是必要的,具体如何回调可以参考文档,只是直接进行文字语音播放则不需要改动。

5.开始播放

 mTts.startSpeaking(content, mSynListener);

猜你喜欢

转载自blog.csdn.net/sdsh1880gm/article/details/78672231