为了让大家容易理解,做了一个简单的Demo,先上效果图吧:
首先在科大讯飞官网先创建应用,审核通过后会返回一个APPID号,这个号在开发时会使用;
成功申请到appid号之后,下载在线语音合成SDK压缩包;
将 SDK压缩包解压后内容如图;
将压缩包中libs文件下的文件拷进安卓libs目录下(务必导入完整,不能缺东少西,不然后面出现莫名其妙的问题);
将压缩包中asserts的文件拷进安卓目录asserts目录下(安卓目录结构没有asserts目录则新建一个就好了);
接下来在build.gradle(Module:app)里面配置ndk和jni(这里经常被很多人忽略,要十分注意!!);
MainActivity.java代码:
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import com.iflytek.cloud.SpeechConstant;
import com.iflytek.cloud.SpeechError;
import com.iflytek.cloud.SpeechSynthesizer;
import com.iflytek.cloud.SpeechUtility;
import com.iflytek.cloud.SynthesizerListener;
public class MainActivityextends Activity {
private EditTexteditText;
private SpeechSynthesizermTts;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
editText=findViewById(R.id.editText1);
SpeechUtility.createUtility(this, SpeechConstant.APPID +"=这里用你申请到的appid");
mTts = SpeechSynthesizer.createSynthesizer(this, null);
set_mTts();
Button btn = (Button) findViewById(R.id.btn);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mTts.startSpeaking(editText.getText().toString(),mTtsListener);
// mTts.startSpeaking(
// "7月14日,2014年英国范堡罗W/////////////航展正式开幕。瑞典萨伯公司研制的最新型“鹰狮NG”战斗机首次亮相该航展。该机在Jas-39“鹰狮”基础上进行全面改进,更换了最新型的AESA雷达,并配备有“流星”中程空空导弹、IRIS-T近距格斗导弹、KEPD-350远程防区外空地导弹等最新一代机载武器,战斗力得到空前飞跃。",
// mTtsListener);
}
});
}
private void set_mTts() {
// 设置发音人
mTts.setParameter(SpeechConstant.VOICE_NAME, "xiaoyan");
// 设置语速
mTts.setParameter(SpeechConstant.SPEED, "20");
// 设置音调
mTts.setParameter(SpeechConstant.PITCH, "50");
// 设置音量0-100
mTts.setParameter(SpeechConstant.VOLUME, "100");
// 设置播放器音频流类型
mTts.setParameter(SpeechConstant.STREAM_TYPE, "3");
// 如果不需要保存保存合成音频,请注释下行代码
// mTts.setParameter(SpeechConstant.TTS_AUDIO_PATH,
// "./sdcard/iflytek.pcm");
}
private SynthesizerListenermTtsListener =new SynthesizerListener() {
// 缓冲进度回调,arg0为缓冲进度,arg1为缓冲音频在文本中开始的位置,arg2为缓冲音频在文本中结束的位置,arg3为附加信息
@Override
public void onBufferProgress(int arg0, int arg1, int arg2, String arg3) {
// TODO Auto-generated method stub
}
// 会话结束回调接口,没有错误时error为空
@Override
public void onCompleted(SpeechError error) {
// TODO Auto-generated method stub
}
@Override
public void onEvent(int i, int i1, int i2, Bundle bundle) {
}
// 开始播放
@Override
public void onSpeakBegin() {
// TODO Auto-generated method stub
}
// 停止播放
@Override
public void onSpeakPaused() {
// TODO Auto-generated method stub
}
// 播放进度回调,arg0为播放进度0-100;arg1为播放音频在文本中开始的位置,arg2为播放音频在文本中结束的位置。
@Override
public void onSpeakProgress(int arg0, int arg1, int arg2) {
// TODO Auto-generated method stub
}
// 恢复播放回调接口
@Override
public void onSpeakResumed() {
// TODO Auto-generated method stub
}
};
@Override
protected void onDestroy() {
mTts.stopSpeaking();
mTts.destroy();// 退出时释放连接
super.onDestroy();
}
}
接下来是activity_main.xml代码:
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
android:id="@+id/editText1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
/>
android:id="@+id/btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="speak" />
最后记得加权限;
然后运行(记得要联网),就可以听到人声了,所谓懒人听书就是这效果。
实例应用(界面还没优化完,大拿莫喷):