JAVA语音播报
提示:难点,常规语音播放只是播放一段音乐,这个比较简单。本文介绍将文字语音播放出来,并且可以兼容windows、linux
语音播报在编码过程中,我们主要需从以下几个核心层面进行深入考量。
1.使用JACOB开源库
请注意,JACOB是一个针对Windows平台的库,因此它只能在Windows上运行。注意:项目如果打包到linux运行,语音播报就无效了
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
/**
语音播报,仅适用windows
*/
public class SpeakTools {
public static boolean speakingText(String readText) {
boolean isFinish = true;
ActiveXComponent sap = new ActiveXComponent("Sapi.SpVoice");
try {
sap.setProperty("Volume", new Variant(100)); // 音量 0-100
sap.setProperty("Rate", new Variant(1)); // 语音朗读速度 -10 到 +10
Dispatch sapo = sap.getObject(); // 获取执行对象
Dispatch.call(sapo, "Speak", new Variant(readText)); // 执行朗读
sapo.safeRelease(); // 关闭执行对象
} catch (Exception e) {
isFinish = false;
e.printStackTrace();
} finally {
sap.safeRelease(); // 关闭执行对象
}
return isFinish;
}
public static void main(String[] args) {
SpeakTools.speakingText("你是猪吗");
}
}
2.使用第三方插件
使用Java Speech API(FreeTTS)
FreeTTS是一个开源的Java TTS引擎。你可以使用它将文本转换为语音。首先,你需要下载并安装FreeTTS库,然后在你的Java项目中使用它。随着 Java 的发展,JSAPI 已被弃用并从 Java 标准库中移除。因此,直接使用 FreeTTS 和 JSAPI 可能会遇到兼容性问题,特别是如果你使用的是较新版本的 Java。
首先,我们需要在项目中引入FreeTTS库的jar文件。可以从FreeTTS官方网站下载最新版本的jar文件,然后将其添加到项目的依赖中。
提示:我这里下载的库只能读英文,如果想中英文找到合适的包即可
import com.sun.speech.freetts.Voice;
import com.sun.speech.freetts.VoiceManager;
public class FreeTTS {
public static boolean speakTTs(String speakText) {
boolean isFinish = true;
try {
VoiceManager vm = VoiceManager.getInstance();
Voice voice = vm.getVoice("kevin16");
voice.allocate();
voice.speak(speakText);
voice.deallocate();
} catch (Exception e) {
e.printStackTrace();
}
return isFinish;
}
public static void main(String[] args) {
speakTTs("hellow");
}
}
3.使用在线TTS API
前端浏览器在处理文本朗读功能时,普遍集成了speakText功能。然而,不同浏览器对speakText的兼容性存在差异。通常而言,像谷歌浏览器(Chrome)、火狐浏览器(Firefox)以及Microsoft Edge等主流浏览器的兼容性较好。使用这种方式进行文本朗读的主要优势在于,开发者只需要关注浏览器是否支持speakText功能,而无需过多考虑系统层面的兼容性问题,这种方式简化了开发流程,提高了开发效率,使得跨平台朗读文本变得更加便捷,稳定性略差。
代码如下(示例):
<a href="#" onclick="alert();" title="紧急情况使用,请听到警报后及时疏散和撤离员工">报警</a>
function alert() {
speakTextAndMusic('紧急撤离警报,紧急撤离警报,请立即前往最近的紧急出口,保持冷静,快速有序撤离,不要使用电梯,到达安全区域后,立即报告给各自负责人!');
}
function speakTextAndMusic(text) {
const speech = new SpeechSynthesisUtterance()
// 设置播放内容
speech.text = text
// 设置话语的音调(0-2 默认1,值越大越尖锐,越低越低沉)
speech.pitch = 0.8
// 设置说话的速度(0.1-10 默认1,值越大语速越快,越小语速越慢)
speech.rate = 1
// 设置说话的音量
speech.volume = 10
// 设置播放语言
speech.lang = 'zh-CN'
// 播放结束后调用
speech.onend = (event) =>{
playMusic();
}
window.speechSynthesis.speak(speech)
}
function playMusic() {
var url = '/tools/alert.mp3'; //自定义语音
const audio = new Audio(url);
audio.play();
}
4.其他框架或者库
包括收费和不收费的都有,这里不做介绍。
总结
在Java语言中实现播报功能,通常涉及到文本到语音(Text-to-Speech,简称TTS)的转换。Java自身并不直接提供这样的功能,但你可以使用第三方库或API来实现。