1. 下载资源jacob

将.dll文件添加到jre下的bin文件夹下

64位操作系统选择jacob-1.18-x64.dll文件

32位操作系统选择jacob-1.18-x86.dll

链接:https://pan.baidu.com/s/1bppqj07 密码:hdcv

MSTTSSpeech.java

import com.jacob.activeX.ActiveXComponent;

import com.jacob.com.ComThread;

import com.jacob.com.Dispatch;

import com.jacob.com.Variant;

/**

* 调用MSTTS将字符串转换成语音信息

* 调用windows speech API(SAPI)

* @author suyunlong

*

*/

public class MSTTSSpeech

{

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

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

private int voice=0;// 语音库序号

private int audio=0;// 输出设备序号

private ActiveXComponent ax=null;

private Dispatch spVoice=null;// 声音对象

private Dispatch spFileStream=null;// 音频文件输出流对象,在读取或保存音频文件时使用

private Dispatch spAudioFormat=null;// 音频格式对象

private Dispatch spMMAudioOut=null;// 音频输出对象

private int formatType=22;// 音频的输出格式,默认为: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();

}

}

/**

* 改变音频输出设备

* @param audio 音频设备序号

*/

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 要转换成语音的文本

*/

public void speak(String text)

{

this.speak(text,0);

}

/**

* 停止播放语音

*/

public void stop()

{

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

Dispatch.call(spVoice,"Pause");

}

/**

* 播放语音

* @param text 要转换成语音的文本

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

*/

private void speak(String text,int type)

{

switch(type)

{

case 0:

try

{

// 调整音量和读的速度

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

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

// 设置音频格式类型

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;

}

}

/**

* 获取系统中所有的语音库名称数组

* @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;

}

/**

* 获取音频输出设备名称数组

* @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;

}

/**

* 将文字转换成音频信号,然后输出到.WAV文件

* @param text 文本字符串

* @param filePath 输出文件路径

*/

public void saveToWav(String text,String filePath)

{

// 创建输出文件流对象

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

spFileStream=ax.getObject();

// 创建音频流格式对象

if(spAudioFormat==null)

{

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

spAudioFormat=ax.getObject();

}

// 设置音频流格式类型

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

// 设置文件输出流的格式

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

// 调用输出文件流对象的打开方法,创建一个.wav文件

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

// 设置声音对象的音频输出流为输出文件流对象

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

// 调整音量和读的速度

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

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

// 开始朗读

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

// 关闭输出文件流对象,释放资源

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;

}

/**

* 设置音频输出格式类型

* 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="这是我的测试,物理内存至少需要512MB,建议2GB以上,虚拟内存是主机物理内存的两倍,不要设到系统盘,硬盘空闲空间大于4.77GB.";

speech.setFormatType(6);

// speech.setRate(-1);

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

//speech.speak(text);

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

}

}

SoundUtil.java

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;

/**

* 与声音有关的工具类

* @author suyunlong

*

*/

public class SoundUtil

{

/**

* 将WAV格式的音频文件转换为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);

// 此处的转换必需是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("D:/test.wav"));

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

}

}

java 文字转语音_java 实现文字转语音 -仅限windows系统相关推荐

  1. java渐变色字体生成器_java阴影文字效果怎么做?渐变的怎么做?

    随着时代的不断发展,新兴技术的使用也促使人们不断地在学习进步.今天主要为大家介绍一下,java的阴影和渐变的文字效果怎么做. 首先为大家介绍的是阴影效果文字的做法.第一步:使用Graphics类的se ...

  2. flask实现后台java实现前端页面_java实现telnet功能,待实现windows下远程多机自动化发布软件后台代码...

    java实现telnet功能,待实现windows下远程多机自动化发布软件后台代码 package com.org.softwore.util; import java.io.IOException; ...

  3. java面向对象银行案例_Java程序设计-面向对象分析案例:银行储蓄系统.ppt

    面向对象分析 1 基本过程 2 需求陈述 3 建立对象模型 4 建立动态模型 5 建立功能模型 6 定义服务 1 面向对象分析的基本过程 在面向对象建模的过程中,系统分析员必须认真向领域专家学习. 在 ...

  4. 使用百度AI将语音转换成文字(JAVA)

    使用百度AI将语音转换成文字--JAVA 1.安装ffmpeg 2.使用百度AI翻译语音 1.引入dependency 2.将音频转换成文字并写入到文件中. **遇到的问题:** 4.因为需要切割长语 ...

  5. java tif格式图片_java给tif格式图片加文字水印?

    展开全部 package com.coderli.image; import java.awt.Color; import java.awt.Font; import java.awt.Graphic ...

  6. 微信 语音转文字 java,在微信——怎么将语音转化为文字,你需要学习了

    有时候和好友在聊天,这时好友在微信上发来语音信息,可是你这个时候不方便听语音,那怎么办呢?这个是我们就可以运用微信的语音转文字的功能,那么如何使用这个功能呢?跟着小编看看吧! 操作方法 01 小编在自 ...

  7. java文字水印换行_Java实现图片水印文字换行、平铺、旋转效果-Go语言中文社区...

    import java.awt.Color; import java.awt.Font; import java.awt.Graphics2D; import java.awt.Image; impo ...

  8. java 实现文字转语音功能并同时生成语音文件 demo

    文字转语音功能并同时生成语音文件 这个demo实现的是 你传输一个字符串对象 程序把你传输的对象里的字符串 转成一个可读的语音文件 并且会在你本机读出来 !!!如果没有读出来请首先检查你电脑的声音是否 ...

  9. java drawstring 模糊_Java绘制文字质量太低的解决方案?

    使用 Graphics2D 绘图结果如下: 文字周边非常模糊.想要效果是: 请问如何使用java实现这种清晰的绘制文字的效果呢? 更新 代码如下: public static void pressTe ...

最新文章

  1. 榜单出炉!2018中国AI英雄风云榜揭晓十位AI领军人
  2. 【计算机网络】 DNS学习笔记 (>﹏<)
  3. SDWebImage内部实现过程
  4. Altair FluxMotor 2020中文版
  5. Linux CENTOS6.5 图形命令互转
  6. PostgreSQL11.7逻辑复制压测
  7. php调用mysql加密函数_PHP MySQL应用中使用XOR运算加密算法分享
  8. java线程day-01
  9. python定时器 是线程吗_定时器中断线程python
  10. 常用的Java开发工具
  11. CentOS 6.5 CentOS 7 rpm安装ftp服务端与ftp客户端
  12. 元宇宙之XR(02)VR概念解读 分类说明
  13. 有道云笔记蒋炜航:敏捷开发的实战经验
  14. Redis3.0.0集群一键脚本 -by古斌
  15. 创业者尽职调查之一:用户增长核算[英文版]
  16. 使用 Neo4j 图数据库可视化(网络安全)知识图谱
  17. @lisp 函数库 - CAD应用云
  18. vscode提示:“An SSH installation couldn‘t be found”
  19. Baked Light Light Maps and Probes——srp中使用lightprobe和light probe proxy volume(简称LPPV)
  20. HT合泰 单片机的仿真调试

热门文章

  1. 推荐六款Mac上的思维导图软件,自己留着用~
  2. 替天行资源网同款人脉社群小程序V6.1.0源码
  3. mapbox 添加geoserver发布的wms服务及wms服务属性查询
  4. 初入android驱动开发之网络设备以太网(二)
  5. python迭代器, torchtext
  6. 统计计算第五节课,Mante Calor方法(二)——减小估计量的方差
  7. Python读取 xlsb 文件格式
  8. CMMI的5个成熟度等级
  9. 你应该知道的产品设计14招
  10. 怎么安装自己的维基百科(How to mirror Wikipedia)