springBoot中实现语音朗读

2 篇文章 0 订阅
1 篇文章 0 订阅

语音播报的方式有很多中。通过jacob实现语音朗读,则是其中最简单的一种实现方式。

实现步骤:

1、下载Jacob文件。

官网下载:https://sourceforge.net/projects/jacob-project/

2、把下载解压之后里面的“jacob-1.19-x64.dll”文件复制到jdk安装的bin目录中(切记:.dll文件根据自己电脑位数选择不同的文件)。

3、通过build Path把文件里的“jacob.jar”jar包添加到项目中。

4、语音播报实现代码

public void speak(String args) {
		ActiveXComponent sap = new ActiveXComponent("Sapi.SpVoice");
		Dispatch sapo = sap.getObject();
		try {
			// 音量 0-100
			sap.setProperty("Volume", new Variant(100));
			// 语音朗读速度 -10 到 +10
			sap.setProperty("Rate", new Variant(2));
			Scanner scan = new Scanner(args);
			String str = scan.next();
			// 执行朗读
			Dispatch.call(sapo, "Speak", new Variant(str));
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			sapo.safeRelease();
			sap.safeRelease();
		}
	}

通过传入不同的args的值,则播报不同的语音。至此,简单的语音播报就完成了。

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
实现Java文转语音实时朗读,可以使用Java Speech API(JSAPI)和FreeTTS库。 以下是一个简单的示例代码,可以实现文实时转换成语音朗读出来: ```java import java.util.Locale; import javax.speech.Central; import javax.speech.synthesis.Synthesizer; import javax.speech.synthesis.SynthesizerModeDesc; import com.sun.speech.freetts.Voice; import com.sun.speech.freetts.VoiceManager; public class TextToSpeech { public static void main(String[] args) { try { // 初始化JSAPI System.setProperty("freetts.voices", "com.sun.speech.freetts.en.us.cmu_us_kal.KevinVoiceDirectory"); Central.registerEngineCentral("com.sun.speech.freetts.jsapi.FreeTTSEngineCentral"); Synthesizer synthesizer = Central.createSynthesizer(new SynthesizerModeDesc(Locale.US)); synthesizer.allocate(); synthesizer.resume(); // 初始化FreeTTS Voice voice = VoiceManager.getInstance().getVoice("kevin16"); voice.allocate(); // 文转语音朗读 String text = "你好,欢迎使用Java语音合成技术。"; synthesizer.speakPlainText(text, null); synthesizer.waitEngineState(Synthesizer.QUEUE_EMPTY); voice.speak(text); // 释放资源 voice.deallocate(); synthesizer.deallocate(); } catch (Exception e) { e.printStackTrace(); } } } ``` 在上述代码,我们首先通过JSAPI初始化了语音合成器synthesizer,并通过FreeTTS库获取了语音合成的Voice对象voice。然后,我们可以使用synthesizer.speakPlainText()方法将文转换成语音朗读出来,也可以使用voice.speak()方法实现文转换成语音朗读出来。 需要注意的是,上述代码需要引入jsapi.jar和freetts.jar两个库文件,可以在FreeTTS官网(http://freetts.sourceforge.net/)下载。另外,由于FreeTTS是基于英语的语音合成库,因此需要将voices属性设置为英语。如果要使用语音合成,可以考虑使用其他的语音合成库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值