Java实现在windows系统下文字转语音并播报

一、准备工作

1、因为调用的是windows64的自带的语音系统,所以我们需要下载语音驱动,一个以dll结尾的文件,
文件放到网盘里了
链接:https://pan.baidu.com/s/1KCNSjRwXvP3jkPTj07UkUQ
提取码:81bh

文件放置位置可以有两个地方:
地方一:计算机上的安装的jdk下的bin目录下
Java实现在windows系统下文字转语音并播报_第1张图片

地方二:c盘下的windows下的system
Java实现在windows系统下文字转语音并播报_第2张图片
在这里我推荐是放到地方二,放到地方一的话,当你打一个war包的时候,通过tomcat启动,可能本地的tomcat用的并不是你配置的jdk,就要再次重新配置这个dll文件,放到地方二则不用再次配置

2、导入所需的依赖

		<dependency>
			<groupId>com.hynnet</groupId>
			<artifactId>jacob</artifactId>
			<version>1.18</version>
		</dependency>

二、具体代码实现

package com.huayun.common.utils;

import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.ComFailException;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
import org.apache.log4j.Logger;

/**
 * @Author: lh
 * @Date: 2022-04-16 10:55
 */
public class VoicePlayUtil {

    private static Logger logger = Logger.getLogger(VoicePlayUtil.class);

    /**
     * 语音转文字并播放
     *
     * @param text 要播放的文字
     * @throws Exception 异常捕捉
     */
    public static void textToSpeech(String text) {
        ActiveXComponent ax = null;
        try {
            ax = new ActiveXComponent("Sapi.SpVoice");

            // 运行时输出语音内容
            Dispatch spVoice = ax.getObject();
            // 音量 0-100
            ax.setProperty("Volume", new Variant(100));
            // 语音朗读速度 -10 到 +10(-10语速最慢,10语速最快)
            ax.setProperty("Rate", new Variant(1));
            /*  执行朗读,默认调用系统中的TTS语音播放引擎,若本机没有语音设备
            可能会抛出异常(com.jacob.com.ComFailException: Invoke of: Speak) */
            logger.info("开始语音播报");
            Dispatch.call(spVoice, "Speak", new Variant(text));
            logger.info("语音播报完成");

            // 下面是构建文件流生成语音文件
            ax = new ActiveXComponent("Sapi.SpFileStream");
            Dispatch spFileStream = ax.getObject();

            ax = new ActiveXComponent("Sapi.SpAudioFormat");
            Dispatch spAudioFormat = ax.getObject();

            // 设置音频流格式
            Dispatch.put(spAudioFormat, "Type", new Variant(22));
            // 设置文件输出流格式
            Dispatch.putRef(spFileStream, "Format", spAudioFormat);
            // 调用输出 文件流打开方法,创建一个.wav文件
            Dispatch.call(spFileStream, "Open", new Variant("./warn.wav"),
                    new Variant(3), new Variant(true));
            // 设置声音对象的音频输出流为输出文件对象
            Dispatch.putRef(spVoice, "AudioOutputStream", spFileStream);
            // 设置音量 0到100
            Dispatch.put(spVoice, "Volume", new Variant(100));
            // 设置朗读速度
            Dispatch.put(spVoice, "Rate", new Variant(-2));
            // 开始朗读
            Dispatch.call(spVoice, "Speak", new Variant(text));

            // 关闭输出文件
            Dispatch.call(spFileStream, "Close");
            Dispatch.putRef(spVoice, "AudioOutputStream", null);

            spAudioFormat.safeRelease();
            spFileStream.safeRelease();
            spVoice.safeRelease();
            ax.safeRelease();
        } catch (ComFailException e) {
            e.printStackTrace();
            logger.error("没有可用的音频,请连接外接设备(耳机或音箱播放)");
        } catch (Exception e) {
            e.printStackTrace();
            logger.error("语音播放错误:" + e.getMessage());
        }
    }


}

你可能感兴趣的:(java,windows,开发语言)