package com.bytx.ai.service.base.controller.util;
import it.sauronsoftware.jave.Encoder;
import it.sauronsoftware.jave.MultimediaInfo; 
 
import java.io.File; 
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream; 
import java.io.IOException;
import java.io.RandomAccessFile;
import java.io.SequenceInputStream;
import java.nio.ByteBuffer;
import java.text.ParseException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Enumeration;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.bytx.ai.service.utility.common.CodeConstans;
 
@RestController
@RequestMapping(value = "/cut", method = RequestMethod.POST, produces = CodeConstans.JSON_UTF_8)
public class WavCut { 
   
    /**
     * 截取wav音频文件
     * @param sourcepath  源文件地址
     * @param targetpath  目标文件地址
     * @param start  截取开始时间(秒)
     * @param end  截取结束时间(秒)
     *  这个方法是截取选中某段音频开始之前的音频分割
     * return  截取成功返回true,否则返回false
     */ 
 
 @RequestMapping(value = "/cutUtil")
    public static boolean cut(String sourcefile, String targetfile, double start, double end) { 
        try{ 
            if(!sourcefile.toLowerCase().endsWith(".mp3") || !targetfile.toLowerCase().endsWith(".mp3")){ 
                return false; 
            } 
            File wav = new File(sourcefile); 
            if(!wav.exists()){ 
                return false; 
            } 
            double t1 = getTimeLen(wav);  //总时长(秒) 
            if(start<0 || end<=0 || start>=t1 || end>t1 || start>=end){ 
                return false; 
            } 
            cut1(sourcefile, targetfile, start, end);
           
            FileInputStream fis = new FileInputStream(wav); 
            long wavSize = wav.length()-44;  //音频数据大小(44为128kbps比特率wav文件头长度) 
            long splitSize = (long)((wavSize/t1)*start);  //截取的音频数据大小 
             
            long skipSize = (long)((wavSize/t1)*0);  //截取时跳过的音频数据大小 
         //   long skipSize = (long)((wavSize/t1)*(t1-start));  //截取时跳过的音频数据大小 
            int splitSizeInt = Integer.parseInt(String.valueOf(splitSize)); 
            int skipSizeInt = Integer.parseInt(String.valueOf(skipSize)); 
             
            ByteBuffer buf1 = ByteBuffer.allocate(4);  //存放文件大小,4代表一个int占用字节数 
            buf1.putInt(splitSizeInt+36);  //放入文件长度信息 
            byte[] flen = buf1.array();  //代表文件长度 
            ByteBuffer buf2 = ByteBuffer.allocate(4);  //存放音频数据大小,4代表一个int占用字节数 
            buf2.putInt(splitSizeInt);  //放入数据长度信息 
            byte[] dlen = buf2.array();  //代表数据长度 
            flen = reverse(flen);  //数组反转 
            dlen = reverse(dlen); 
            byte[] head = new byte[44];  //定义wav头部信息数组 
            fis.read(head, 0, head.length);  //读取源wav文件头部信息 
            for(int i=0; i<4; i++){  //4代表一个int占用字节数 
                head[i+4] = flen[i];  //替换原头部信息里的文件长度 
                head[i+40] = dlen[i];  //替换原头部信息里的数据长度 
            } 
            byte[] fbyte = new byte[splitSizeInt+head.length];  //存放截取的音频数据 
            for(int i=0; i<head.length; i++){  //放入修改后的头部信息 
                fbyte[i] = head[i]; 
            } 
            byte[] skipBytes = new byte[skipSizeInt];  //存放截取时跳过的音频数据 
            fis.read(skipBytes, 0, skipBytes.length);  //跳过不需要截取的数据 
            fis.read(fbyte, head.length, fbyte.length-head.length);  //读取要截取的数据到目标数组 
            fis.close(); 
             
            File target = new File(targetfile); 
            if(target.exists()){  //如果目标文件已存在,则删除目标文件 
                target.delete(); 
            } 
            FileOutputStream fos = new FileOutputStream(target); 
           
            fos.write(fbyte); 
            fos.flush(); 
            fos.close(); 
            hebin();
        }catch(IOException e){ 
            e.printStackTrace(); 
            return false; 
        } 
     
        return true; 
      
    } 
  /**
   
     * 截取音频结束end后的音频部分
     */ 
    public static boolean cut1(String sourcefile, String targetfile, double start, double end) { 
        try{ 
           /* if(!sourcefile.toLowerCase().endsWith(".mp3") || !targetfile.toLowerCase().endsWith(".mp3")){ 
                return false; 
            } 
*/
         StringBuffer targetfile1 = new StringBuffer(targetfile);
         StringBuffer replace = targetfile1.replace(3, 4, "a");
         String replace11 = replace.toString();
         System.out.println(replace);
            File wav = new File(sourcefile); 
            if(!wav.exists()){ 
                return false; 
            } 
            double t1 = getTimeLen(wav);  //总时长(秒) 
            if(start<0 || end<=0 || start>=t1 || end>t1 || start>=end){ 
                return false; 
            } 
            FileInputStream fis = new FileInputStream(wav); 
            long wavSize = wav.length()-44;  //音频数据大小(44为128kbps比特率wav文件头长度) 
            long splitSize = (long)((wavSize/t1)*(t1-end));  //截取的音频数据大小 
             
         //   long skipSize = (long)((wavSize/t1)*0);  //截取时跳过的音频数据大小 
            long skipSize = (long)((wavSize/t1)*end);  //截取时跳过的音频数据大小 
            int splitSizeInt = Integer.parseInt(String.valueOf(splitSize)); 
            int skipSizeInt = Integer.parseInt(String.valueOf(skipSize)); 
             
            ByteBuffer buf1 = ByteBuffer.allocate(4);  //存放文件大小,4代表一个int占用字节数 
            buf1.putInt(splitSizeInt+36);  //放入文件长度信息 
            byte[] flen = buf1.array();  //代表文件长度 
            ByteBuffer buf2 = ByteBuffer.allocate(4);  //存放音频数据大小,4代表一个int占用字节数 
            buf2.putInt(splitSizeInt);  //放入数据长度信息 
            byte[] dlen = buf2.array();  //代表数据长度 
            flen = reverse(flen);  //数组反转 
            dlen = reverse(dlen); 
            byte[] head = new byte[44];  //定义wav头部信息数组 
            fis.read(head, 0, head.length);  //读取源wav文件头部信息 
            for(int i=0; i<4; i++){  //4代表一个int占用字节数 
                head[i+4] = flen[i];  //替换原头部信息里的文件长度 
                head[i+40] = dlen[i];  //替换原头部信息里的数据长度 
            } 
            byte[] fbyte = new byte[splitSizeInt+head.length];  //存放截取的音频数据 
            for(int i=0; i<head.length; i++){  //放入修改后的头部信息 
                fbyte[i] = head[i]; 
            } 
            byte[] skipBytes = new byte[skipSizeInt];  //存放截取时跳过的音频数据 
            fis.read(skipBytes, 0, skipBytes.length);  //跳过不需要截取的数据 
            fis.read(fbyte, head.length, fbyte.length-head.length);  //读取要截取的数据到目标数组 
            fis.close(); 
             
            File target = new File(replace11); 
            if(target.exists()){  //如果目标文件已存在,则删除目标文件 
                target.delete(); 
            } 
            FileOutputStream fos = new FileOutputStream(target); 
           
            fos.write(fbyte); 
            fos.flush(); 
            fos.close(); 
           
        }catch(IOException e){ 
            e.printStackTrace(); 
            return false; 
        } 
        return true; 
      
    } 
   
/**
   
     * 合成音频方法
     */ 
    public static void hebin() throws IOException {
     FileInputStream fis1 = new FileInputStream("F:\\Rec00010.mp3");
  FileInputStream fis2 = new FileInputStream("F:\\6.mp3");//你需要添加音频的中间部分
  FileInputStream fis3 = new FileInputStream("F:\\1.mp3");//你需要添加音频的中间部分
  FileInputStream fis4 = new FileInputStream("F:\\8.mp3");//你需要添加音频的中间部分
  FileInputStream fis5 = new FileInputStream("F:\\6.mp3");//你需要添加音频的中间部分
  FileInputStream fis6 = new FileInputStream("F:\\aec00010.mp3");
 
  ArrayList<FileInputStream> c = new ArrayList<FileInputStream>();
  c.add(fis1);
  c.add(fis2);
  c.add(fis3);
  c.add(fis4);
  c.add(fis5);
  c.add(fis6);
  Enumeration<FileInputStream> e = Collections.enumeration(c);
  SequenceInputStream sis = new SequenceInputStream(e);
  
  //创建输出流---要把前三个文件的内容读出来并且合并到seq4.txt;
  FileOutputStream fos=new FileOutputStream("F:\\d5.mp3");
  int len=0;
  byte buf[] = new byte[10];
  while((len=sis.read(buf))!=-1){
   fos.write(buf, 0, len);
  }
  fos.close();
  sis.close();
    }
     
    /**
     * 获取音频文件总时长
     * @param filePath  文件路径
     * @return
     */ 
    public static double getTimeLen(File file){ 
        double tlen = 0; 
        if(file!=null && file.exists()){ 
            Encoder encoder = new Encoder(); 
            try { 
                 MultimediaInfo m = encoder.getInfo(file); 
                 double ls = m.getDuration(); 
                 tlen = ls/1000; 
            } catch (Exception e) { 
                e.printStackTrace(); 
            } 
        } 
        return tlen; 
    } 
     
    /**
    * 数组反转
    * @param array
    */ 
    public static byte[] reverse(byte[] array){ 
        byte temp; 
        int len=array.length; 
        for(int i=0;i<len/2;i++){ 
            temp=array[i]; 
            array[i]=array[len-1-i]; 
            array[len-1-i]=temp; 
        } 
        return array; 
    } 
     
    public static void main(String[] args) throws ParseException, IOException{ 
     long startTime = System.currentTimeMillis(); //获取开始时间
      //he();
        System.out.println(cut("C:\\Users\\13671\\Desktop\\yin\\宽带新增开场白2.mp3","F:\\Rec00010.mp3",8.8,9.5)); 
     long endTime = System.currentTimeMillis(); //获取结束时间
     System.out.println("程序运行时间:" + (endTime - startTime) + "ms"); //输出程序运行时间
       // System.out.println(cut("f:\\111.wav","f:\\111-cut_10_20.wav",10,20)); 
       // System.out.println(cut("f:\\111.wav","f:\\111-cut_20_28.wav",20,28)); 
    /* String aString= "1.013";
     double a=Double.parseDouble(aString);
     System.out.println(a);
     double b=1000;
     double  c=(a*b);
     System.out.println(c);
     int i= (int)c;
        System.out.println(i);*/
       
    
    }
    } 
   

MP3音频文件的剪切合并方法的更多相关文章

  1. C# 使用NAudio合并mp3、wav音频文件

    1.什么是wav格式    WAV为微软公司(Microsoft)开发的一种声音文件格式,它符合RIFF(Resource Interchange File Format)文件规范,用于保存Windo ...

  2. VC++中MCI播放音频文件 【转】

    MCI播放mp3音频文件例程 源文件中需要包含头文件 Mmsystem.h,在Project->Settings->Link->Object/libray module中加入库 Wi ...

  3. HTML5 audio 如何实现播放多个MP3音频

    <audio>标签是HTML5中的新标签,定义声音用于嵌入音频内容,比如音乐或其他音频流.用的比较多音频格式是.mp3. <audio>标签常用属性如下表 属性 值 描述 au ...

  4. 吴裕雄--天生自然python学习笔记:python 用pygame模块处理音频文件

    除了对图片. Word 等普通格式的文件进行处理外, Python 还有强大的多媒体文件操作能力,如对音频.视频 文件的操作 . 如果要播放音乐,我们可以用 pygame 包中的 mixer 对 象. ...

  5. 获取google翻译的音频文件_合并音频文件的方法

    1. 把引文输入google 翻译,然后点击"朗读"

  6. .net amr格式文件转换成mp3格式文件的方法

    前言:winform端对于音频文件的格式多有限制,大多数不支持amr格式的文件的播放.但是,手机端传过来的音频文件大多数是amr格式的文件,所以,要想在winform客户端支持音频文件的播放,可以通过 ...

  7. PHP 将amr音频文件转换为mp3格式

    说下整体思路 1.服务器安装ffmpeg 2.使用ffmpeg -i 指令来转换amr为mp3格式(这个到时候写在PHP代码中,使用exec函数执行即可) 3.在网页端使用HTML5的audio标签来 ...

  8. CEF3 HTML5 audio标签为什么不能播放mp3格式的音频文件

    CEF3 HTML5 audio标签 为什么不能播放mp3格式的音频文件   原因略.   解决方法: 找一个最新版的chrome ,我用的是24版本.路径 C:\Documents and Sett ...

  9. 合并BIN文件的两种方法(转)

    源:http://blog.chinaunix.net/uid-20745340-id-1878803.html 合并BIN文件的两种方法 在单片机的开发过程中,经常需要将两个单独的BIN文件合并成一 ...

随机推荐

  1. android framework 之JNI

    Java Native Interface ( JN I)是Java本地接口,所谓的本地(native) —般是指C/C++ ( 以下统称C)语言.当使用Java进行程序设计时,一般主要有三种情况需要 ...

  2. GRE阅读

    界面和托福差不多,就是反一反 GRE先读文章!因为出题顺序不一致.另外,不能跳读!!每一句都要读,即使不是观点. 考察能力: 1 三秒版本 边读边概括 解决前面的抗遗忘能力 2 句间关系 取同 取反 ...

  3. Vmware Workstation 15 Pro安装Arch Linux并配置Docker

    主机配置: CPU:Intel Core i7-7700HQ 2.8GHz 2.8GHz 内存:16GB 操作系统:Windows 10 Home 64bit 双显卡:Intel HD Graphic ...

  4. 【读书笔记】https://source.android.google.cn/compatibility/tests?hl=en

    AuthorBlog:秋城https://www.cnblogs.com/houser0323/ Android Platform Testing This content is geared tow ...

  5. 浅谈C# Dictionary实现原理

    使用C#已经有好多年头了,然后突然有一天被问到C#Dictionary的基本实现,这让我反思到我一直处于拿来主义,能用就好,根本没有去考虑和学习一些底层架构,想想令人头皮发麻.下面开始学习一些我平时用 ...

  6. 通过HTML及CSS模拟报纸排版总结

    任务目的 深入掌握CSS中的字体.背景.颜色等属性的设置 进一步练习CSS布局 任务描述 参考 PDS设计稿(点击下载),实现页面开发,要求实现效果与 样例(点击查看) 基本一致 页面中的各字体大小, ...

  7. Element-UI饿了么时间组件控件按月份周日期,开始时间结束时间范围限制参数

    在日常开发中,我们会遇到一些情况,在使用Element-UI 限制用户的日期时间范围的选择控制(例如:查询消息开始和结束时间,需要限制不能选择今天之后的时间). 看了网上的一些文档,零零散散.各式各样 ...

  8. ASP.NET Core身份认证服务框架IdentityServer4 介绍

    IdentityServer4是ASP.NET Core 2的OpenID Connect和OAuth 2.0框架.它可以在您的应用程序中提供以下功能: 它使你的应用程序具有如下特点: 认证即服务 适 ...

  9. go-admin基于Gin + Vue + Element UI的前后端分离权限管理系统

    ✨ 特性 遵循 RESTful API 设计规范 基于 GIN WEB API 框架,提供了丰富的中间件支持(用户认证.跨域.访问日志.追踪ID等) 基于Casbin的 RBAC 访问控制模型 JWT ...

  10. 序列化器:ModelSerializer

    ModelSerializer 类提供了一个快捷方式,可让你基于 Models 自动创建一个 Serializer 类,其中的字段与模型类字段对应. ModelSerializer 类与常规 Seri ...