java实现wav的重采样

原因是之前写的TTS文件,需要指定采样率和单声道

但是TTS是用的Jacob调用COM+sapi实现的

java+WNI10+JACOB方式

SAPI底层支持的是C,C#【官方文档】

SpAudioFormat SetWaveFormatEx method (SAPI 5.4) | Microsoft Learn

用C实现的方式【可指定输出的WAV格式】

【基于微软 SAPI 的 TTS 程序实现_sapi.h配置-CSDN博客】

懒得看C,直接写个重采样接口好了,参考如下方法

java实现wav的重采样_java wav采样转换-CSDN博客

代码如下:

java 复制代码
package com.qf.tdboot02.service;

import org.springframework.stereotype.Service;

import javax.sound.sampled.*;
import java.io.File;
import java.io.IOException;
@Service
public class WavMonoConverter {
    public static void main(String[] args) {
        File inputFile = new File("path_to_input.wav");
        File outputFile = new File("path_to_output.wav");
        convertStereoToMono(inputFile, outputFile);
    }

    public static void convertStereoToMono(File inputFile, File outputFile) {
        try {
            AudioInputStream audioInputStream = AudioSystem.getAudioInputStream(inputFile);
            AudioFormat format = audioInputStream.getFormat();
            int channels = format.getChannels();

            AudioFormat newFormat = new AudioFormat(
                    format.getEncoding(),
                    8000,// 采样率为8000 Hz
                    format.getSampleSizeInBits(),// 采样点
                    1, // 单声道
                    format.getFrameSize(), // 帧大小,对于单声道16位PCM,每帧大小是采样率 * 声道数 * 采样点位数/8 = 8000 * 1 * 2 = 16000,但这里通常设置为采样率,因为每帧通常包含一个采样点
                    8000, // 帧率,通常与采样率相同
                    format.isBigEndian() // 使用小端字节序,这是Java音频系统通常使用的
            );


            // 转换音频流为单声道
            AudioInputStream monoAudioInputStream = AudioSystem.getAudioInputStream(newFormat, audioInputStream);

            // 写入新的WAV文件
            AudioSystem.write(monoAudioInputStream, AudioFileFormat.Type.WAVE, outputFile);

            // 关闭流
            monoAudioInputStream.close();
            audioInputStream.close();
        } catch (UnsupportedAudioFileException | IOException e) {
            e.printStackTrace();
        }
    }
}
java 复制代码
package com.qf.tdboot02.controller;

import com.qf.tdboot02.constant.WavConstant;
import com.qf.tdboot02.service.WavMonoConverter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;

import java.io.File;

/**
 * @author: 作者
 * @create: 2024-04-17 10:03
 * @Description:
 */
@Component
@RequestMapping("/wav")
public class WavConvertController {

    private final WavMonoConverter wavMonoConverter;

    @Autowired
    public WavConvertController(WavMonoConverter wavMonoConverter) {
        this.wavMonoConverter = wavMonoConverter;
    }

    @GetMapping("/convert")
    public void convert(String in,String out) {
        File inputFile = new File(in);
        File outputFile = new File(out);
        wavMonoConverter.convertStereoToMono(inputFile, outputFile);
    }

}

接口调用:

http://localhost:8090/wav/convert?in=D://in.wav&out=D://out.wav

生成文件:

相关推荐
我星期八休息19 小时前
IT疑难杂症诊疗室:AI时代工程师Superpowers进化论
linux·开发语言·数据结构·人工智能·python·散列表
热心网友俣先生19 小时前
2026年第二十三届五一数学建模竞赛C题超详细解题思路+各问题可用模型推荐+部分模型结果展示
c语言·开发语言·数学建模
01漫游者19 小时前
JavaScript函数与对象增强知识
开发语言·javascript·ecmascript
GottdesKrieges19 小时前
OceanBase恢复常见问题
java·数据库·oceanbase
IGAn CTOU19 小时前
Java高级开发进阶教程之系列
java·开发语言
leo825...19 小时前
Claude Code Skills 清单(本地)
java·python·ai编程
csbysj202019 小时前
SQL NULL 函数详解
开发语言
其实防守也摸鱼19 小时前
CTF密码学综合教学指南--第三章
开发语言·网络·python·安全·网络安全·密码学
NGSI vimp19 小时前
Java进阶——如何查看Java字节码
java·开发语言
We་ct20 小时前
深度剖析浏览器跨域问题
开发语言·前端·浏览器·跨域·cors·同源·浏览器跨域