【Android语音合成TTS】百度语音接入方法,和使用技巧详解

标签: TTS 语音合成 Android tts Android语音合成
8979人阅读 评论(5) 收藏 举报
分类:

请尊重他人的劳动成果,转载请注明出处:【Android语音合成TTS】百度语音接入方法,和使用技巧详解 

Ps.

依托于百度开放云,百度语音为合作伙伴提供了业界领先、永久免费的语音技术服务,目前已上线的服务包括语音识别、语义解析、语音合成,后续会继续带来开放资源、多轮对话等技术服务;通过SDKREST API及离线开发包等多种服务方式,满足不同开发者的开发需求。

目前百度语音提供免费的语音接入,语音合成质量尚可,但还没开放离线TTS

服务接入流程

服务接入流程

具体详情可查看:http://yuyin.baidu.com/dev.php

集成开发

导入百度语音的相关jar包和so文件如图:

百度语音库

提示:

将开发包中的 libs目录整体拷贝到工程目录,libs目录包括了各平台的 SO库,开发者视应用需要可以进行删减。galaxy_lite.jar是百度 Android公共基础库,如果项目中还集成了其它百度 SDK PushSDK,在打包过程中出现类似如下的错误信息:

[2013-10-22 11:02:57 - Dex Loader] Unableto execute dex: Multiple dex files defineLcom/baidu/android/common/logging/Configuration; [2013-10-22 11:02:57 -VoiceRecognitionDemo] Conversion to Dalvik format failed: Unable to executedex: Multiple dex files define Lcom/baidu/android/common/logging/Configuration;

请将此 Jar 包移除。如果 Eclipse ADT版本插件低于 17,需要手工添加依赖库,添加方法为:Project => Properties => Java Build Path => Libraries => AddJAR... 3


为了方便使用我这里将百度语音合成引擎做了进一步的封装,封装成了SpeechUtil以方便调用:

package com.jph.tts;

import android.content.Context;
import android.media.AudioManager;
import android.util.Log;

import com.baidu.speechsynthesizer.SpeechSynthesizer;
import com.baidu.speechsynthesizer.SpeechSynthesizerListener;
import com.baidu.speechsynthesizer.publicutility.SpeechError;

/**
 * 语音合成工具类
 * 
 * @author JPH
 * @date 2015-4-14 下午1:33:37
 */
public class SpeechUtil implements SpeechSynthesizerListener {

	protected static final int UI_LOG_TO_VIEW = 0;
	private SpeechSynthesizer speechSynthesizer;
	private Context context;

	public SpeechUtil(Context activity) {
		this.context = activity;
		init();
	}
	/**
	 * 初始化合成相关组件
	 * 
	 * @author JPH
	 * @date 2015-4-14 下午1:36:53
	 */
	private void init() {
		speechSynthesizer = new SpeechSynthesizer(context, "holder", this);
		// 此处需要将setApiKey方法的两个参数替换为你在百度开发者中心注册应用所得到的apiKey和secretKey
		speechSynthesizer.setApiKey("your apiKey",
				"your secretKey");
		speechSynthesizer.setAudioStreamType(AudioManager.STREAM_MUSIC);
//		activity.setVolumeControlStream(AudioManager.STREAM_MUSIC);
		setParams();
	}
	/**
	 * 开始文本合成并朗读
	 * @author JPH
	 * @date 2015-4-14 下午1:47:05
	 * @param content
	 */
	public void speak(final String content) {
		 new Thread(new Runnable() {
             @Override
             public void run() {
//                 setParams();
                 int ret = speechSynthesizer.speak(content.toString());
                 if (ret != 0) {
                     Log.e("inf","开始合成器失败:"+ret);
                 }
             }
         }).start();
	}
	/**
	 * 取消本次合成并停止朗读
	 * @author JPH
	 * @date 2015-4-14 下午2:20:33
	 */
	public void cancle() {
		speechSynthesizer.cancel();
	}
	/**
	 * 暂停文本朗读,如果没有调用speak(String)方法或者合成器初始化失败,该方法将无任何效果
	 * @author JPH
	 * @date 2015-4-14 下午2:21:07
	 */
	public void pause() {
		speechSynthesizer.pause();
	}
	/**
	 * 继续文本朗读,如果没有调用speak(String)方法或者合成器初始化失败,该方法将无任何效果
	 * @author JPH
	 * @date 2015-4-14 下午2:21:29
	 */
	public void resume() {
		speechSynthesizer.resume();
	}
	/**
	 * 为语音合成器设置相关参数
	 * @author JPH
	 * @date 2015-4-14 下午1:45:11
	 */
	private void setParams() {
		speechSynthesizer.setParam(SpeechSynthesizer.PARAM_SPEAKER, "0");//发音人,目前支持女声(0)和男声(1) 
		speechSynthesizer.setParam(SpeechSynthesizer.PARAM_VOLUME, "9");//音量,取值范围[0, 9],数值越大,音量越大
		speechSynthesizer.setParam(SpeechSynthesizer.PARAM_SPEED, "5");//朗读语速,取值范围[0, 9],数值越大,语速越快
		speechSynthesizer.setParam(SpeechSynthesizer.PARAM_PITCH, "5");//音调,取值范围[0, 9],数值越大,音量越高
		speechSynthesizer.setParam(SpeechSynthesizer.PARAM_AUDIO_ENCODE,
				SpeechSynthesizer.AUDIO_ENCODE_AMR);//音频格式,支持bv/amr/opus/mp3,取值详见随后常量声明
		speechSynthesizer.setParam(SpeechSynthesizer.PARAM_AUDIO_RATE,
				SpeechSynthesizer.AUDIO_BITRATE_AMR_15K85);//音频比特率,各音频格式支持的比特率详见随后常量声明
	}
	@Override
	public void onStartWorking(SpeechSynthesizer synthesizer) {
		Log.i("msg", "开始工作,请等待数据...");
	}

	@Override
	public void onSpeechStart(SpeechSynthesizer synthesizer) {
		Log.i("msg", "朗读开始");
	}

	@Override
	public void onSpeechResume(SpeechSynthesizer synthesizer) {
		Log.i("msg", "朗读继续");
	}

	@Override
	public void onSpeechProgressChanged(SpeechSynthesizer synthesizer,
			int progress) {
		// TODO Auto-generated method stub

	}

	@Override
	public void onSpeechPause(SpeechSynthesizer synthesizer) {
		Log.i("msg", "朗读已暂停");
	}

	@Override
	public void onSpeechFinish(SpeechSynthesizer synthesizer) {
		Log.i("msg", "朗读已停止");
	}

	@Override
	public void onNewDataArrive(SpeechSynthesizer synthesizer,
			byte[] audioData, boolean isLastData) {
		Log.i("msg", "新的音频数据:" + audioData.length
				+ (isLastData ? "(end)" : ""));
	}

	@Override
	public void onError(SpeechSynthesizer synthesizer, SpeechError error) {
		Log.i("msg", "发生错误:" + error.errorDescription + "(" + error.errorCode
				+ ")");
	}

	@Override
	public void onCancel(SpeechSynthesizer synthesizer) {
		Log.i("msg", "已取消");
	}

	@Override
	public void onBufferProgressChanged(SpeechSynthesizer synthesizer,
			int progress) {
		// TODO Auto-generated method stub

	}
}

使用方法: 

package com.jph.tts;

import android.app.Activity;
import android.os.Bundle;
import android.text.method.ScrollingMovementMethod;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

import com.baidu.tts.sample.R;

public class HomeActivity extends Activity implements OnClickListener {

	protected static final int UI_LOG_TO_VIEW = 0;
	private TextView logView;
	private EditText inputTextView;
	private Button startButton;
	private SpeechUtil speechUtil;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_home);
		logView = (TextView) findViewById(R.id.logView);
		logView.setMovementMethod(new ScrollingMovementMethod());
		inputTextView = (EditText) findViewById(R.id.inputTextView);
		speechUtil = new SpeechUtil(this);
	}

	@Override
    public void onClick(View v) {
        switch (v.getId()) {
        case R.id.btnStart:
        	speechUtil.speak(inputTextView.getText().toString());
            break;
        case R.id.btnPause:
        	speechUtil.pause();
        	break;
        case R.id.btnResume:
        	speechUtil.resume();
        	break;
        case R.id.btnStop:
        	speechUtil.cancle();
        	break;
        default:
            break;
        }
    }
}

因为百度TTS需要联网解析所以要赋予应用相应的权限: 

<uses-permission android:name="android.permission.INTERNET"></uses-permission>
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
推荐阅读:

【Android语音合成TTS】国内主流引擎对比 
【Android语音合成TTS】云知声离线TTS使用详解


 

查看评论

百度语音SDK使用

百度语音SDK提供: 语音识别:将声音转成文字 语音合成:将文字转成语音文件,然后播放语音文件,即文字变声音。 语音唤醒:语音唤醒,激活运用程序...
  • hexingen
  • hexingen
  • 2017-03-09 18:09:03
  • 3717

E/art: No implementation found for int com.baidu.speechsynthesizer

今天写一个百度得文字转语音功能 因为之前写过demo 所以直接复制得代码 但是问题来。。。 再播放语音得时候一只报这个错 大概就是说.so文件找不到  但是一共就4个文件 都有了了  为什么会不行呢 ...
  • qq_34709056
  • qq_34709056
  • 2017-06-06 17:04:16
  • 1006

Android 调用.so包时报错:No implementation found for native Lxxx, java.lang.UnsatisfiedLinkError: XXX时的解决办法

No implementation found for native Lxxx, java.lang.UnsatisfiedLinkError: XXX时的解决办法
  • huanzhongying
  • huanzhongying
  • 2016-06-17 16:53:58
  • 10271

百度地图定位集成及问题汇总No implementation found for int com.baidu.platform.comjni.tools.JNITools.initClass

由于在百度地图使用的过程中遇到各种问题,这里简单整理一下。 1.地图定位集成 导入库文件 在下载页面下载最新的库文件。将liblocSDK2.4.so文件拷贝到libs/armeabi目录下。...
  • Maiduoudo
  • Maiduoudo
  • 2017-10-31 09:11:35
  • 1089

android 百度语音合成例子eclipse版和studio版

package com.example.baiduspeechmydemo; import java.io.File; import java.io.FileNotFoundException; im...
  • a346254964
  • a346254964
  • 2015-07-09 22:17:36
  • 3480

调用百度地图 5.0手机报错java.lang.UnsatisfiedLinkError: No implementation found for int

转载请注明:http://blog.csdn.net/seven2729/article/details/47979263 调用百度地图   5.0手机报错,黑屏并闪退 报错日志 java.lang...
  • seven2729
  • seven2729
  • 2015-09-08 11:54:40
  • 24407

android平台tts中文语音合成核心代码及设置流程

因项目需要中文朗读推送信息,做了一个简单调查。现站在应用开发者角度介绍一下android系统下语音合成的开发配置流程: 1)核心代码 android自带api,引入包import android....
  • liaoyundababe
  • liaoyundababe
  • 2015-03-21 16:40:43
  • 2930

百度语音合成(TTS) 在Android的使用方法

项目中有新的需求,要求对一些人名进行 语音播报, 那么这样就需要用到语音合成技术(Text To Speech),查了网上比较多的资料,在Android方面能用的貌似比价少,首先找到的是科大讯飞的 ...
  • chang_1134
  • chang_1134
  • 2016-07-29 16:41:58
  • 6123

云知声离线TTS使用Demo

  • 2015年04月15日 04:24
  • 17.01MB
  • 下载

AndroidTTS离线文字转语音技术

在我们开发过程中,用到语音技术大概就是文字转语音以及语音转文字了,知会一种另外一种也就会了。最近项目里用到了语音提示,并且要离线使用,体验会更好,因为网络差或者其他情况,在线文字转语音会有问题,下面说...
  • weixin_37730482
  • weixin_37730482
  • 2017-06-28 09:43:24
  • 2165
    个人资料
    专栏达人 持之以恒
    等级:
    访问量: 107万+
    积分: 1万+
    排名: 1389
    你需要的,才是干货@开源项目
    博客专栏
    最新评论