FFMPEG 特效

FFMPEG 特效,第1张

//渐入

i in.mp4 -vf fade=in:0:90 out.mp4

//黑白

i in.mp4 -vf lutyuv="u=128:v=128" out.mp4

//锐化

i in.mp4 -vf unsharp=luma_msize_x=7:luma_msize_y=7:luma_amount=2.5 out.mp4

//反锐化

i in.mp4 -vf unsharp=7:7:-2:7:7:-2 out.mp4

//渐晕

i in.mp4 -vf vignette=PI/4 out.mp4

//闪烁渐晕

i in.mp4 -vf vignette='PI/4+random(1) PI/50':eval=frame out.mp4

//视频颤抖

i in.mp4 -vf crop="in_w/2:in_h/2:(in_w-out_w)/2+((in_w-out_w)/2) sin(n/10):(in_h-out_h)/2+((in_h-out_h)/2) sin(n/7)" out.mp4

//色彩变幻

i in.mp4 -vf hue="H=2 PI t:s=sin(2 PI t)+1" out.mp4

//模糊处理

i in.mp4 -vf boxblur=5:1:cr=0:ar=0 out.mp4

//镜像翻转

i in.mp4 -vf crop=iw/2:ih:0:0,split[left][tmp][tmp]hflip[right][left]pad=iw 2[a][a][right]overlay=w out.mp4

//水平翻转

i in.mp4 -vf geq=p(W-X\,Y) out.mp4

//垂直翻转

i in.mp4 -vf vflip out.mp4

//浮雕效果

i in.mp4 -vf format=gray,geq=lum_expr='(p(X,Y)+(256-p(X-4,Y-4)))/2' out.mp4

//均匀噪声

i in.mp4 -vf noise=alls=20:allf=t+u out.mp4

FFmpeg的主体框架

编译会生成4个可执行文件,和8个静态库。

一、可执行文件

ffmpeg : 转码、推流、Dump媒体文件

ffplay : 播放媒体文件,拉流

ffprobe :获取媒体文件信息

ffserver :简单流媒体服务器(一般用的比较少)

二、静态库

8个静态库实际是FFmpeg的8模块,包括如下:

libavutil :核心工具库,该模块是最基本的模块之一,其它这么多模块会依赖此模块做一些音视频处理 *** 作。

libavformat : 文件格式和协议库,该模块是最重要的模块之一,封装了Protocol层、Demuxer层、muxer层,使用协议和格式对于开发者是透明的。

libavcodec: 编解码库,该模块也是最重要模块之一,封装了Codec层,但是有一些Codec是具备自己的License的,FFmpeg是不会默认添加,例如libx264,FDK-AAC, lame等库,但FFmpeg就像一个平台一样,可以将其它的第三方的Codec以插件的方式添加进来,然后为开发者提供统一的接口。

libswrsample: 音频重采样库,可以对数字音频进行声道数、数据格式、采样率等多种基本信息的转换。

libswscale: 视频压缩和格式转换库,可以进行视频分辨率修改、YUV格式数据与RGB格式数据互换。

libavdevice: 输入输出设备库,编译ffplay就需要确保该模块是打开的,时时也需要libSDL预先编译,因为该设备播放声音和播放视频使用的都是libSDL库。

libavfilter :音视频滤镜库,该模块包含了音频特效和视频特效的处理,在使用FFmpeg的API进行编解码的过程中,直接使用该模块为音视频数据做特效物理非常方便同时也非常高效的一种方式。

libpostproc: 音视频后期处理库,当使用libavfilter的时候需要打开该模块开关,因为Filter中会使用该库中的一些基础函数。

写了一大堆,最后用一张思维导图来总结体现吧,简单明了,方便大脑记忆存储:

最近有一个需求,需要将多个音频文件延时插入到一段视频中,经过学习,得到以下命令:

-y -i videoSource.mp4 -i test1.mp3 -i test2.mp3 -i test3.mp3 -filter_complex [1]adelay=5000|5000=[s1][2]adelay=15000|15000=[s2][3]adelay=25000|25000=[s3][0:a][s1][s2][s3]amix=4[a] -map 0:v -map [a] -c:v copy result.mp4

如果不需要视频原声,则修改命令为:

-y -i videoSource.mp4 -i test1.mp3 -i test2.mp3 -i test3.mp3 -filter_complex [1]adelay=5000|5000=[s1][2]adelay=15000|15000=[s2][3]adelay=25000|25000=[s3][s1][s2][s3]amix=3[a] -map 0:v -map [a] -c:v copy result.mp4

以上命令为Android使用,如果需要在windows使用,则需要修改为:

-y -i videoSource.mp4 -i test1.mp3 -i test2.mp3 -i test3.mp3 -filter_complex "[1]adelay=5000|5000=[s1][2]adelay=15000|15000=[s2][3]adelay=25000|25000=[s3][s1][s2][s3]amix=3[a]" -map 0:v -map "[a]" -c:v copy result.mp4

其中

[1]adelay=5000|5000=[s1]的意思为:取第二个输入文件的音轨(下标从0开始)并延时5000毫秒

[0:a]的意思为:第一个输入文件的音频资源


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11479561.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存