FFmpeg + SoundTouch实现音频的变调变速
本文使用FFmpeg + SoundTouch实现将音频解码后,进行变调变速处理,并将处理后的结果保存为WAV文件。
主要有以下内容:
- 实现一个FFmpeg的工具类,保存多媒体文件所需的解码信息
- 将解码后的音频保存为WAV文件
- SoundTouch的使用指南
1.从视频文件中提取音频保存为WAV文件
本小节实现从视频文件中提取音频,解码并保存为WAV文件。
在使用FFmpeg解码时,一般的流程是:
- 打开一个多媒体文件流
- 得到媒体流信息
- 查找视频、音频流的index
- 根据流的index查找相应的的CODEC,打开AVCodecContext
进行完以上操作后,就得到解码所需的各种信息:AVFormateContext、AVCodecContext以及对应流的index。也就说,这些数据是解码多媒体流的必须信息,所以这里对上述操作做一个封装,提供一个单一接口来获取解码所需的信息。
1.1 MediaInfo工具类
在使用FFmpeg进行解码的时候,所需要的信息如下:
- AVFormatContext
- AVCodecContext
- 流的index
MediaInfo的声明如下:
class CMediaInfo { public:
CMediaInfo();
CMediaInfo(MEDIA_TYPE media);
~CMediaInfo(); public: ERROR_TYPE open(const char *filename); void close();
延伸阅读
- ssh框架
2016-09-30
- 阿里移动安全 [无线安全]玩转无线电——不安全的蓝牙锁
2017-07-26
- 消息队列NetMQ 原理分析4-Socket、Session、Option和Pipe
2024-03-26
- Selective Search for Object Recognition 论文笔记【图片目标分割】
2017-07-26
- 词向量-LRWE模型-更好地识别反义词同义词
2017-07-26
- 从栈不平衡问题 理解 calling convention
2017-07-26
- php imagemagick 处理 图片剪切、压缩、合并、插入文本、背景色透明
2017-07-26
- Swift实现JSON转Model - HandyJSON使用讲解
2017-07-26
- 阿里移动安全 Android端恶意锁屏勒索应用分析
2017-07-26
- 集合结合数据结构来看看(二)
2017-07-26
学习是年轻人改变自己的最好方式