日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

java jacob语音合成_Java使用Jacob调用SAPI合成语音

發(fā)布時間:2024/1/1 java 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java jacob语音合成_Java使用Jacob调用SAPI合成语音 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

基于語音測試需要,需要將文字?jǐn)?shù)據(jù)轉(zhuǎn)換成語音數(shù)據(jù),文章未經(jīng)原作者允許轉(zhuǎn)載,只用于記錄。

1.Jar包

版本號:1.18

maven地址:https://mvnrepository.com/artifact/com.hynnet/jacob

2.環(huán)境設(shè)置

JDK版本:1.8(原來采用1.7設(shè)置與1.8一致,一直報錯,還不知道是不是版本的原因,原作者使用1.7沒問題)

具體設(shè)置:解壓后,將x86或x64的dll文件放入c:\windows\system32或syswow64目錄下;同時也放入jdk和jre的bin、lib目錄里;

3.MSTTSSpeech代碼

package com.thinkgem.jeesite.common.utils;

import com.jacob.activeX.ActiveXComponent;

import com.jacob.com.ComThread;

import com.jacob.com.Dispatch;

import com.jacob.com.Variant;

public class MSTTSSpeech {

private int volume=100;// 聲音:1到100

private int rate=0;// 頻率:-10到10

private int voice=0;// 語音庫序號

private int audio=0;// 輸出設(shè)備序號

private ActiveXComponent ax=null;

private Dispatch spVoice=null;// 聲音對象

private Dispatch spFileStream=null;// 音頻文件輸出流對象,在讀取或保存音頻文件時使用

private Dispatch spAudioFormat=null;// 音頻格式對象

private Dispatch spMMAudioOut=null;// 音頻輸出對象

private int formatType=22;// 音頻的輸出格式,默認(rèn)為:SAFT22kHz16BitMono

public MSTTSSpeech()

{

ComThread.InitSTA();

if(ax==null)

{

ax=new ActiveXComponent("Sapi.SpVoice");

spVoice=ax.getObject();

}

}

/**

* 改變語音庫

* @param voice 語音庫序號

*/

public void changeVoice(int voice)

{

if(this.voice != voice)

{

this.voice=voice;

}

try

{

Dispatch voiceItems=Dispatch.call(spVoice,"GetVoices").toDispatch();

int count=Integer.valueOf(Dispatch.call(voiceItems,"Count").toString());

if(count>0)

{

Dispatch voiceItem=Dispatch.call(voiceItems,"Item",new Variant(this.voice)).toDispatch();

Dispatch.put(spVoice,"Voice",voiceItem);

}

}

catch(Exception e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

}

/**

* 改變音頻輸出設(shè)備

* @param audio 音頻設(shè)備序號

*/

public void changeAudioOutput(int audio)

{

if(this.audio != audio)

{

this.audio=audio;

}

try

{

Dispatch audioOutputs=Dispatch.call(spVoice,"GetAudioOutputs").toDispatch();

int count=Integer.valueOf(Dispatch.call(audioOutputs,"Count").toString());

if(count > 0)

{

Dispatch audioOutput=Dispatch.call(audioOutputs,"Item",new Variant(this.audio)).toDispatch();

Dispatch.put(spVoice,"AudioOutput",audioOutput);

}

}

catch(Exception e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

}

/**

* 播放語音

* @param text 要轉(zhuǎn)換成語音的文本

*/

public void speak(String text)

{

this.speak(text,0);

}

/**

* 停止播放語音

*/

public void stop()

{

// this.speak("", 1);

Dispatch.call(spVoice,"Pause");

}

/**

* 播放語音

* @param text 要轉(zhuǎn)換成語音的文本

* @param type 類型0:播放,1:停止

*/

private void speak(String text,int type)

{

switch(type)

{

case 0:

try

{

// 調(diào)整音量和讀的速度

Dispatch.put(spVoice,"Volume",new Variant(this.volume));// 設(shè)置音量

Dispatch.put(spVoice,"Rate",new Variant(this.rate));// 設(shè)置速率

// 設(shè)置音頻格式類型

if(spAudioFormat==null)

{

ax=new ActiveXComponent("Sapi.SpAudioFormat");

spAudioFormat=ax.getObject();

ax=new ActiveXComponent("Sapi.SpMMAudioOut");

spMMAudioOut=ax.getObject();

}

Dispatch.put(spAudioFormat,"Type",new Variant(this.formatType));

Dispatch.putRef(spMMAudioOut,"Format",spAudioFormat);

Dispatch.put(spVoice,"AllowAudioOutputFormatChangesOnNextSet",new Variant(false));

Dispatch.putRef(spVoice,"AudioOutputStream",spMMAudioOut);

// 開始朗讀

Dispatch.call(spVoice,"Speak",new Variant(text));

}

catch(Exception e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

break;

case 1:

try

{

Dispatch.call(spVoice,"Speak",new Variant(text),new Variant(2));

}

catch(Exception e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

break;

default:

break;

}

}

/**

* 獲取系統(tǒng)中所有的語音庫名稱數(shù)組

* @return String[]

*/

public String[] getVoices()

{

String[] voices=null;

try

{

Dispatch voiceItems=Dispatch.call(spVoice,"GetVoices").toDispatch();

int count=Integer.valueOf(Dispatch.call(voiceItems,"Count").toString());

if(count > 0)

{

voices=new String[count];

for(int i=0;i

{

Dispatch voiceItem=Dispatch.call(voiceItems,"Item",new Variant(i)).toDispatch();

String voice=Dispatch.call(voiceItem,"GetDescription").toString();

voices[i]=voice;

}

}

}

catch(Exception e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

return voices;

}

/**

* 獲取音頻輸出設(shè)備名稱數(shù)組

* @return String[]

*/

public String[] getAudioOutputs()

{

String[] result=null;

try

{

Dispatch audioOutputs=Dispatch.call(spVoice,"GetAudioOutputs").toDispatch();

int count=Integer.valueOf(Dispatch.call(audioOutputs,"Count").toString());

if(count > 0)

{

result=new String[count];

for(int i=0;i

{

Dispatch voiceItem=Dispatch.call(audioOutputs,"Item",new Variant(i)).toDispatch();

String voice=Dispatch.call(voiceItem,"GetDescription").toString();

result[i]=voice;

}

}

}

catch(Exception e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

return result;

}

/**

* 將文字轉(zhuǎn)換成音頻信號,然后輸出到.WAV文件

* @param text 文本字符串

* @param filePath 輸出文件路徑

*/

public void saveToWav(String text,String filePath)

{

// 創(chuàng)建輸出文件流對象

ax=new ActiveXComponent("Sapi.SpFileStream");

spFileStream=ax.getObject();

// 創(chuàng)建音頻流格式對象

if(spAudioFormat==null)

{

ax=new ActiveXComponent("Sapi.SpAudioFormat");

spAudioFormat=ax.getObject();

}

// 設(shè)置音頻流格式類型

Dispatch.put(spAudioFormat,"Type",new Variant(this.formatType));

// 設(shè)置文件輸出流的格式

Dispatch.putRef(spFileStream,"Format",spAudioFormat);

// 調(diào)用輸出文件流對象的打開方法,創(chuàng)建一個.wav文件

Dispatch.call(spFileStream,"Open",new Variant(filePath),new Variant(3),new Variant(true));

// 設(shè)置聲音對象的音頻輸出流為輸出文件流對象

Dispatch.putRef(spVoice,"AudioOutputStream",spFileStream);

// 調(diào)整音量和讀的速度

Dispatch.put(spVoice,"Volume",new Variant(this.volume));// 設(shè)置音量

Dispatch.put(spVoice,"Rate",new Variant(this.rate));// 設(shè)置速率

// 開始朗讀

Dispatch.call(spVoice,"Speak",new Variant(text));

// 關(guān)閉輸出文件流對象,釋放資源

Dispatch.call(spFileStream,"Close");

Dispatch.putRef(spVoice,"AudioOutputStream",null);

}

/**

* @return the volume

*/

public int getVolume()

{

return volume;

}

/**

* @param volume

* the volume to set

*/

public void setVolume(int volume)

{

this.volume = volume;

}

/**

* @return the rate

*/

public int getRate()

{

return rate;

}

/**

* @param rate

* the rate to set

*/

public void setRate(int rate)

{

this.rate = rate;

}

/**

* @return the voice

*/

public int getVoice()

{

return voice;

}

/**

* @param voice

* the voice to set

*/

public void setVoice(int voice)

{

this.voice = voice;

}

/**

* @return the audio

*/

public int getAudio()

{

return audio;

}

/**

* @param audio

* the audio to set

*/

public void setAudio(int audio)

{

this.audio=audio;

}

/**

* @return the ax

*/

public ActiveXComponent getAx()

{

return ax;

}

/**

* @param ax

* the ax to set

*/

public void setAx(ActiveXComponent ax)

{

this.ax=ax;

}

/**

* @return the formatType

*/

public int getFormatType()

{

return formatType;

}

/**

* 設(shè)置音頻輸出格式類型

* SAFTDefault = -1

* SAFTNoAssignedFormat = 0

* SAFTText = 1

* SAFTNonStandardFormat = 2

* SAFTExtendedAudioFormat = 3

* // Standard PCM wave formats

* SAFT8kHz8BitMono = 4

* SAFT8kHz8BitStereo = 5

* SAFT8kHz16BitMono = 6

* SAFT8kHz16BitStereo = 7

* SAFT11kHz8BitMono = 8

* SAFT11kHz8BitStereo = 9

* SAFT11kHz16BitMono = 10

* SAFT11kHz16BitStereo = 11

* SAFT12kHz8BitMono = 12

* SAFT12kHz8BitStereo = 13

* SAFT12kHz16BitMono = 14

* SAFT12kHz16BitStereo = 15

* SAFT16kHz8BitMono = 16

* SAFT16kHz8BitStereo = 17

* SAFT16kHz16BitMono = 18

* SAFT16kHz16BitStereo = 19

* SAFT22kHz8BitMono = 20

* SAFT22kHz8BitStereo = 21

* SAFT22kHz16BitMono = 22

* SAFT22kHz16BitStereo = 23

* SAFT24kHz8BitMono = 24

* SAFT24kHz8BitStereo = 25

* SAFT24kHz16BitMono = 26

* SAFT24kHz16BitStereo = 27

* SAFT32kHz8BitMono = 28

* SAFT32kHz8BitStereo = 29

* SAFT32kHz16BitMono = 30

* SAFT32kHz16BitStereo = 31

* SAFT44kHz8BitMono = 32

* SAFT44kHz8BitStereo = 33

* SAFT44kHz16BitMono = 34

* SAFT44kHz16BitStereo = 35

* SAFT48kHz8BitMono = 36

* SAFT48kHz8BitStereo = 37

* SAFT48kHz16BitMono = 38

* SAFT48kHz16BitStereo = 39

*

* // TrueSpeech format

* SAFTTrueSpeech_8kHz1BitMono = 40

* // A-Law formats

* SAFTCCITT_ALaw_8kHzMono = 41

* SAFTCCITT_ALaw_8kHzStereo = 42

* SAFTCCITT_ALaw_11kHzMono = 43

* SAFTCCITT_ALaw_11kHzStereo = 4

* SAFTCCITT_ALaw_22kHzMono = 44

* SAFTCCITT_ALaw_22kHzStereo = 45

* SAFTCCITT_ALaw_44kHzMono = 46

* SAFTCCITT_ALaw_44kHzStereo = 47

*

* // u-Law formats

* SAFTCCITT_uLaw_8kHzMono = 48

* SAFTCCITT_uLaw_8kHzStereo = 49

* SAFTCCITT_uLaw_11kHzMono = 50

* SAFTCCITT_uLaw_11kHzStereo = 51

* SAFTCCITT_uLaw_22kHzMono = 52

* SAFTCCITT_uLaw_22kHzStereo = 53

* SAFTCCITT_uLaw_44kHzMono = 54

* SAFTCCITT_uLaw_44kHzStereo = 55

* SAFTADPCM_8kHzMono = 56

* SAFTADPCM_8kHzStereo = 57

* SAFTADPCM_11kHzMono = 58

* SAFTADPCM_11kHzStereo = 59

* SAFTADPCM_22kHzMono = 60

* SAFTADPCM_22kHzStereo = 61

* SAFTADPCM_44kHzMono = 62

* SAFTADPCM_44kHzStereo = 63

*

* // GSM 6.10 formats

* SAFTGSM610_8kHzMono = 64

* SAFTGSM610_11kHzMono = 65

* SAFTGSM610_22kHzMono = 66

* SAFTGSM610_44kHzMono = 67

* // Other formats

* SAFTNUM_FORMATS = 68

*

* @param formatType

* 音頻輸出格式類型

*/

public void setFormatType(int formatType)

{

this.formatType=formatType;

}

public static void main(String[] args)

{

MSTTSSpeech speech=new MSTTSSpeech();

String text="這是我的測試,物理內(nèi)存至少需要512MB,建議2GB以上,虛擬內(nèi)存是主機(jī)物理內(nèi)存的兩倍,不要設(shè)到系統(tǒng)盤,硬盤空閑空間大于4.77GB.";

speech.setFormatType(6);

// speech.setRate(-1);

speech.saveToWav(text,"E://test.wav");

//speech.speak(text);

SoundUtil.wavToPcm("E://test.wav");

}

}

4.SoundUtil代碼

把wav語音文件轉(zhuǎn)換為pcm,其中用的Jar包為sound.jar,該jar包自帶于jdk里,不用到處找了。

package com.thinkgem.jeesite.common.utils;

import java.io.File;

import java.io.IOException;

import javax.sound.sampled.AudioFileFormat;

import javax.sound.sampled.AudioFormat;

import javax.sound.sampled.AudioInputStream;

import javax.sound.sampled.AudioSystem;

import javax.sound.sampled.UnsupportedAudioFileException;

/**

* 與聲音有關(guān)的工具類

* @author suyunlong

*

*/

public class SoundUtil

{

/**

* 將WAV格式的音頻文件轉(zhuǎn)換為PCM格式的文件

* @param wavFilePath WAV文件路徑

* @throws UnsupportedAudioFileException

* @throws IOException

*/

public static void wavToPcm(String wavFilePath)

{

try

{

File wavFile=new File(wavFilePath);

AudioInputStream sourceAudioInputStream=AudioSystem.getAudioInputStream(wavFile);

// 此處的轉(zhuǎn)換必需是16bit的音頻文件

AudioInputStream targetAudioInputStream=AudioSystem.getAudioInputStream(AudioFormat.Encoding.ULAW,

sourceAudioInputStream);

String newFilePath=wavFilePath.substring(0,wavFilePath.lastIndexOf(".")+1)+"pcm";

AudioSystem.write(targetAudioInputStream,AudioFileFormat.Type.WAVE,new File(newFilePath));

}

catch(UnsupportedAudioFileException e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

catch(IOException e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

}

/**

* 獲取音頻文件的編碼格式

* @param wavFilePath 音頻文件格式

* @return String

*/

public static String getWavFormat(String wavFilePath)

{

File wavFile=new File(wavFilePath);

AudioInputStream ais;

String result="";

try

{

ais=AudioSystem.getAudioInputStream(wavFile);

AudioFormat af=ais.getFormat();

result=af.toString();

}

catch(UnsupportedAudioFileException e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

catch(IOException e)

{

System.out.println(e.getMessage());

e.printStackTrace();

}

return result;

}

public static void main(String[] args)

{

System.out.println(SoundUtil.getWavFormat("E://syl//C//test.wav"));

SoundUtil.wavToPcm("E://syl//C//test.wav");

}

}

5.測試報錯問題

問題:java.lang.UnsatisfiedLinkError: no jacob in java.library.path

解決:x86或x64的dll文件放入c:\windows\system32或syswow64目錄下;同時也放入jdk和jre的bin、lib目錄里;

問題:Could not initialize class com.jacob.com.ComThread

解決:更換JDK版本,我在本機(jī)上測試1.7會報錯,1.8通過,請自行嘗試;

6.參考

http://blog.csdn.net/asuyunlong/article/details/50083421

http://www.iteye.com/topic/338223

總結(jié)

以上是生活随笔為你收集整理的java jacob语音合成_Java使用Jacob调用SAPI合成语音的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。