前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java 语言 jacob 实现文本转语音

Java 语言 jacob 实现文本转语音

作者头像
默存
发布2023-09-13 20:01:40
4820
发布2023-09-13 20:01:40
举报
文章被收录于专栏:默存默存

Java 语言 jacob 实现文本转语音

下载依赖包:

https://sourceforge.net/projects/jacob-project/

代码语言:javascript
复制
jacob.jar
jacob-1.18-x64.dll
jacob-1.18-x86.dll

注:需要将两个 .dll 文件放到 JDK 的 bin 目录下

添加依赖

代码语言:javascript
复制
<dependency>
    <groupId>com.hynnet</groupId>
    <artifactId>jacob</artifactId>
    <version>1.18</version>
</dependency>

编码

代码语言:javascript
复制
package com.demo.utils;

import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
import lombok.extern.slf4j.Slf4j;

/**
 * @ClassName:JacobUtils.java
 * @ClassPath:com.demo.utils.JacobUtils.java
 * @Description: 文字转语音
 * @Author:tanyp
 * @Date:2023/9/3 16:10
 **/
@Slf4j
public class JacobUtils {
  
    /**
     * @MonthName:textToSpeech
     * @Description: 语音转文字并播放
     * @Author:tanyp
     * @Date:2023/9/3 16:21
     * @Param: [text]
     * @return:void
     **/
    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
            ax.setProperty("Rate", new Variant(-2));
            // 执行朗读
            Dispatch.call(spVoice, "Speak", new Variant(text));

            // 构建文件流把生成语音文件
            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("./text.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 (Exception e) {
            e.printStackTrace();
        }
    }
    
}

测试

代码语言:javascript
复制
public static void main(String args[]) {
    // 在请字后面停顿,经多次尝试后顿号可实现需求
    JacobUtils.textToSpeech("请、66号客户到5号窗口办理业务");
}

注:断句停顿使用“、”可实现。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-09-04 09:16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 全栈客 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 添加依赖
  • 编码
  • 测试
相关产品与服务
语音识别
腾讯云语音识别(Automatic Speech Recognition,ASR)是将语音转化成文字的PaaS产品,为企业提供精准而极具性价比的识别服务。被微信、王者荣耀、腾讯视频等大量业务使用,适用于录音质检、会议实时转写、语音输入法等多个场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档