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. 初学Qt——tableview操作

    先做简短记录改天有空再详细讲一些吧 使用QSqlQueryModel绑定了TableView,因为需要用到数据表中Id这一项,但又不想显示出来,找到方法是 在绑定之后对tableView 调用setC ...

  2. JAVA 中的反射(reflact)

    获取反射加载类(获取类的字节码)的3种方式: Class class1=Class.forName("lession_svc.lession_svc.reflact.Person" ...

  3. 一文看懂js中元素偏移量(offsetLeft,offsetTop,offsetWidth,offsetHeight)

    偏移量(offset dimension) 偏移量:包括元素在屏幕上占用的所有可见空间,元素的可见大小有其高度,宽度决定,包括所有内边距,滚动条和边框大小(注意,不包括外边距). 以下4个属性可以获取 ...

  4. AE脚本:把SubRip/SRT/TXT/VTT字幕导入到AE

    脚本介绍 如果您需要在视频中嵌入字幕以进行网络或磁带传送,那么这个脚本则非常有用.可以将SubRip/SRT/TXT/VTT字幕格式文件通过 pt_ImportSubtitles脚本直接加载到AE软件 ...

  5. #AcWing系列课程Level-2笔记——5.高精度“+”算法

    高精度"+"算法 编写高精度"+",记住下面的过程,代码也就游刃有余了! 1.首先我们要明白大整数是如何存储的? 2.其次存储完,如何运算? 高精度" ...

  6. 关于使用map存放数据乱序”问题“

    今天做项目中遇到了一个比较低级的错误,如果没注意将会变的更麻烦... 其实吧,也不难,要求就是将list中的值转为map后,再顺序输出map中的值,list的顺序怎样,加入到map的顺序也应怎样,不能 ...

  7. 复习笔记——1. C语言基础知识回顾

    1. 数据类型 1.1 基本数据类型 整型:int, long,unsigned int,unsigned long,long long-- 字符型:char 浮点型:float, double-- ...

  8. C++ const用法,看这一篇就够了!

    本文主要介绍const修饰符在C++中的主要用法,下面会从两个方面进行介绍:类定义中使用const.非类定义中使用const 1. 非类定义中使用const 非类定义中使用const是指:在除了类定义 ...

  9. 自定义FrameWork

    本项目是基于iOS-Universal-Framework-master框架制作的,故编译之前需要安装iOS-Universal-Framework-master框架, 步骤如下:1.跳转到iOS-U ...

  10. SpiningUP 强化学习 中文文档

    2020 OpenAI 全面拥抱PyTorch,  全新版强化学习教程已发布. 全网第一个中文译本新鲜出炉:http://studyai.com/course/detail/ba8e572a 个人认为 ...