当前位置: 首页 > article >正文

java 实现文本转音频

文章目录

  • 一、前言
  • 二、实现流程
    • 2.1 下载jacob-1.18.zip
    • 2.2 拷贝jacob-1.18-x64.dll
    • 2.3 pom 添加依赖
    • 2.4 代码实现


一、前言

本文基于Windows自带的SAPI.SpVoice,通过java代码实现文本转语音的功能。

二、实现流程

2.1 下载jacob-1.18.zip

链接:https://pan.baidu.com/s/1-zYB9I4VF5cPuj3ok1WLyg
提取码:7t1g

2.2 拷贝jacob-1.18-x64.dll

将 jacob-1.18-x64.dll拷贝到jdk的bin目录或windows/SysWOW64目录中

2.3 pom 添加依赖

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

2.4 代码实现

文章目录

  • 一、前言
  • 二、实现流程
    • 2.1 下载jacob-1.18.zip
    • 2.2 拷贝jacob-1.18-x64.dll
    • 2.3 pom 添加依赖
    • 2.4 代码实现

    ---
    # 一、前言
    本文基于Windows自带的SAPI.SpVoice,通过java代码实现文本转语音的功能。
    # 二、实现流程
    ## 2.1下载jacob-1.18.zip
    链接:https://pan.baidu.com/s/1-zYB9I4VF5cPuj3ok1WLyg
    提取码:7t1g
    ## 2.2拷贝jacob-1.18-x64.dll
    将 jacob-1.18-x64.dll拷贝到jdk的bin目录或windows/SysWOW64目录中
    ## 2.3pom 添加依赖

    ```yaml
com.hynnet jacob 1.18 ``` ## 2.4代码实现

package gisshare.demo.audio;

import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.Objects;
import java.util.UUID;

/**
 * 离线 本地 TXT文件 语音朗读,生成mp3文件
 */
public class VoiceReading {
    public static void main(String[] args) {
        //本地TXT文件位置
        String text = textToStr("D:\\myWork/1111.txt");
        textToSpeechIO(text);
    }


    /**
     * 字符串文本转 wav格式 语音文件
     *
     * @param text 要读的文字字符串
     */
    public static void textToSpeechIO(String text) {
        String path = "D:\\myWork\\test/";

        ActiveXComponent ax = null;
        Dispatch spFileStream = null;
        Dispatch spAudioFormat = null;
        Dispatch spVoice = null;
        try {
            ax = new ActiveXComponent("Sapi.SpFileStream");
            spFileStream = ax.getObject();

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

            spVoice = new ActiveXComponent("Sapi.SpVoice").getObject();
            // 设置音频流格式
            Dispatch.put(spAudioFormat, "Type", new Variant(22));
            // 设置文件输出流格式
            Dispatch.putRef(spFileStream, "Format", spAudioFormat);
            //随机uuid
            String uuid = UUID.randomUUID().toString().trim().replaceAll("-", "");
//                String filePath = path + uuid + ".wav";
            String filePath = path + uuid + ".mp3";

            // 调用输出 文件流打开方法,创建一个.wav文件
//                Dispatch.call(spFileStream, "Open", new Variant("D:\\workspace3\\test/test.mp3"), new Variant(3), new Variant(true));
            Dispatch.call(spFileStream, "Open", new Variant(filePath), new Variant(3), new Variant(true));
            // 设置声音对象的音频输出流为输出文件对象
            Dispatch.putRef(spVoice, "AudioOutputStream", spFileStream);
            // 设置音量  0 ~ 100
            Dispatch.put(spVoice, "Volume", new Variant(100));
            // 设置朗读速度  -10 ~ +10
            Dispatch.put(spVoice, "Rate", new Variant(1));

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

            System.out.println("输出语音文件成功!");
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            // 关闭输出文件
            Dispatch.call(Objects.requireNonNull(spFileStream), "Close");
            Dispatch.putRef(Objects.requireNonNull(spVoice), "AudioOutputStream", null);

            Objects.requireNonNull(spAudioFormat).safeRelease();
            spFileStream.safeRelease();
            spVoice.safeRelease();
            ax.safeRelease();
        }
    }

    /**
     * txt文件转字符串
     *
     * @param fileName txt文件所在位置
     * @return txt文件中的字符串
     */
    public static String textToStr(String fileName) {
        BufferedReader reader = null;
        try {
            reader = new BufferedReader(new FileReader(fileName));
            StringBuilder sb = new StringBuilder();
            String line;
            while ((line = reader.readLine()) != null) {
                sb.append(line);
            }
            return sb.toString();
        } catch (IOException e) {
            e.printStackTrace();
            return "";
        } finally {
            try {
                Objects.requireNonNull(reader).close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    /**
     * 字符串文本阅读
     *
     * @param str 要读的文字字符串
     */
    public static void readStr(String str) {
        ActiveXComponent ax = new ActiveXComponent("Sapi.SpVoice");
        //运行时输出语音内容
        Dispatch spVoice = ax.getObject();
        //设置音量 0 ~ 100
        ax.setProperty("Volume", new Variant(100));
        //设置朗读速度 -10 ~ +10
        ax.setProperty("Rate", new Variant(1));
        //执行朗读
        Dispatch.call(spVoice, "Speak", new Variant(str));
    }
}

在这里插入图片描述


http://www.kler.cn/a/281690.html

相关文章:

  • mysql8.4+mysql router读写分离
  • CSS遮罩:mask
  • 如何创建一个项目用于研究element-plus的原理
  • Leetcode 3355 Zero Array Transformation
  • 散户持股增厚工具:智能T0算法交易
  • C 语言Day 01 学习总结
  • 线性代数 第三讲 线性相关无关 线性表示
  • vue之递归组件
  • 单例模式在实现webserver这个项目中起到了什么作用
  • 回调函数基本实现
  • 什么是跨域问题?出现的原因和解决方法是什么?
  • 自动化常用元素定位
  • pymysql 与 MySQL数据库交互
  • 程序员的自我修炼:如何拒绝快餐式学习,深耕技能20240829
  • windows消息机制之HMIsMarkDestroy宏定义的理解
  • c语言——数组
  • 基于my Batis优化图书管理系统(一)
  • FastAdmin 和 Dcat Admin从使用场景、适合人群、使用成本、资源完善程度、bug 解决、安全性全方位解析
  • go 系列实现websocket
  • 【数据结构-前缀异或和】力扣1371. 每个元音包含偶数次的最长子字符串
  • C#过 SemaphoreSlim 实现高效的数据库并发控制和资源管理(多线程)
  • 鸿蒙HSP,HAP,HAR
  • 基于matlab的深度学习案例及基础知识专栏前言
  • 基于imx6ull平台opencv的图像采集和显示屏LCD显示功能(不带Qt界面)
  • Android JNI开发:System.loadLibrary加载机制
  • Kubernetes:解决命名空间无法正常删除问题 —— 清空 Finalizers 字段的方法步骤