Skip to content

Latest commit

 

History

History
1360 lines (803 loc) · 22.1 KB

afilters.md

File metadata and controls

1360 lines (803 loc) · 22.1 KB

abitscope

https://ffmpeg.org/ffmpeg-filters.html#abitscope

参数

示例


对比

[视频对比链接]

adrawgraph

https://ffmpeg.org/ffmpeg-filters.html#adrawgraph

参数

示例


对比

[视频对比链接]

agraphmonitor

https://ffmpeg.org/ffmpeg-filters.html#agraphmonitor

参数

示例


对比

[视频对比链接]

ahistogram

https://ffmpeg.org/ffmpeg-filters.html#ahistogram

参数

示例


对比

[视频对比链接]

aphasemeter

https://ffmpeg.org/ffmpeg-filters.html#aphasemeter

参数

示例


对比

[视频对比链接]

avectorscope

https://ffmpeg.org/ffmpeg-filters.html#avectorscope

参数

示例


对比

[视频对比链接]

bench

https://ffmpeg.org/ffmpeg-filters.html#bench

参数

示例


对比

[视频对比链接]

abench

https://ffmpeg.org/ffmpeg-filters.html#abench

参数

示例


对比

[视频对比链接]

concat

https://ffmpeg.org/ffmpeg-filters.html#concat

连接音频和视频流,把加入的媒体一个接一个的在一起。这个滤镜用于按段同步视频和音频流。所有的段都必须有相同的流(类型和个数),输出也是相同流(类型和个数)。

参数

  • n 设置段的数量,默认为 2
  • v 设置输出中视频流数量,则每个段中必须有输入视频流的数量。默认为 1
  • a 设置输出中音频流数量,则每个段中必须有输入音频流的数量,默认为 0
  • unsafe 激活不安全模式,这时如果段中有不同格式不会失败

滤镜有 v+a 个输出:先是一个视频输出,然后是音频输出。

n x (v+a):有n段输出,每段都是 v+a

相关的流并不总是有相同的时间,由于各种原因还包括不同的编解码帧大小或创作草稿。因此相关同步流(视频和对应音频)要连接,concat 滤镜将选择持续最长的流(视频的)为基准(除最后段的流),在每个流播放时通过让音频流垫长(重复部分)或者静默(截断)来实现视频流连续。

为了让滤镜工作正常,所有段都必须以 0 为时间戳开始。

所有应用的流在所有共同的领域必须有相同的参数,滤镜会自动选择一个通用的像素格式(色彩标注、编码颜色的标准和位深等),以及音频采样率和通道布局。但其他设置如视频分辨率必须由用户显式转换。

不同的帧率是可以接受的,但会导致输出帧率的变化,一定要配置输出文件来处理。

示例

from ffmpeg import input
from tests import data

input_v1 = input(data.V1)
_ = input_v1.concat(input_v1).output(data.TEST_OUTPUTS_DIR / 'concat.mp4').run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i C:\Users\Admin\Videos\FFmpeg\InputsData\v1.mp4 -filter_complex "[0][0]concat=n=2[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\FFmpeg\OutputsData\concat.mp4 -y -hide_banner
[11.9433s]

ebur128

https://ffmpeg.org/ffmpeg-filters.html#ebur128

参数

示例


对比

[视频对比链接]

interleave

https://ffmpeg.org/ffmpeg-filters.html#interleave

参数

示例


对比

[视频对比链接]

ainterleave

https://ffmpeg.org/ffmpeg-filters.html#ainterleave

参数

示例


对比

[视频对比链接]

metadata

https://ffmpeg.org/ffmpeg-filters.html#metadata

参数

示例


对比

[视频对比链接]

ametadata

https://ffmpeg.org/ffmpeg-filters.html#ametadata

参数

示例


对比

[视频对比链接]

perms

https://ffmpeg.org/ffmpeg-filters.html#perms

参数

示例


对比

[视频对比链接]

aperms

https://ffmpeg.org/ffmpeg-filters.html#aperms

参数

示例


对比

[视频对比链接]

realtime

https://ffmpeg.org/ffmpeg-filters.html#realtime

参数

示例


对比

[视频对比链接]

arealtime

https://ffmpeg.org/ffmpeg-filters.html#arealtime

参数

示例


对比

[视频对比链接]

select/aselect

https://ffmpeg.org/ffmpeg-filters.html#select

选择要输出的帧,过滤掉一部分帧。

参数

  • expr 设置表达式,对每个输入帧进行评估,如果表达式的计算结果为零,则丢弃该帧。如果评估结果为负或 NaN,则将帧发送到第一个输出;否则,假设输入索引从 0 开始,它将发送到以 ceil(val)-1 为索引的输出。例如,值 1.2 对应于索引为 ceil(val)-1 = 2-1 = 1 的输出,即第二个输出。
  • outputs, n 设置输出数量。 将所选帧发送到的输出基于评估结果。 预设值为 1。

表达式常量:

  • n 顺序化的滤镜帧,从 0 开始
  • selected_n 被选择的(顺序化)帧,从 0 开始计数
  • prev_selected_n 前一选择(顺序)帧,如果未定义则为 NAN.
  • TB 输入时间戳的时间基准
  • pts PTS,滤镜后视频帧(表示时间戳)分,采用 TB 为单位,如果未定义则为 NAN
  • t PTS 按秒为单位,滤镜后视频帧(时间戳),如果未定义则为 NAN
  • prev_pts 前一滤镜后视频帧 PTS,如果未定义则为 NAN
  • prev_selected_pts 前面最后的滤镜视频帧的 PTS,如果未定义则为 NAN
  • prev_selected_t 前面最后被选择的滤镜后视频帧的 PTS,如果未定义则为 NAN
  • start_pts 视频中第一个视频帧的 PTS,如果未定义则为 NAN
  • start_t 视频的开始时间. 如果未定义则为 NAN
  • pict_type (video only) 滤镜帧的类型, 它可以是下面的值:
    • I
    • P
    • B
    • S
    • SI
    • SP
    • BI
  • interlace_type (video only) 帧交错类型,可以是下面的值:
    • PROGRESSIVE 逐行 ( 非交错 ).
    • TOPFIRST top-field-first 类型帧
    • BOTTOMFIRST bottom-field-first 类型帧
  • consumed_sample_n (audio only) 当前帧之前选定的样本的数量
  • samples_n (audio only) 样品在当前帧的数量
  • sample_rate (audio only) 输入样本率
  • key 为 1 则滤镜框架是一个帧,否则为 0
  • pos 滤镜帧在文件中的偏移位置,-1 为不可用(如合成视频)
  • scene (video only) 值在 0-1 间,表面一个新场景。较低的值反映当前帧的低概率引入一个新场景,更高的值意味着更可能是同一个(场景,见下面的例子)

示例

只选取单一帧类型

_ = input(data.SHORT1).select('eq(pict_type, I)').\
    output(data.TEST_OUTPUTS_DIR / 'select_pict_type_I.mp4').run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i C:\Users\Admin\Videos\FFmpeg\InputsData\1.mp4 -filter_complex ""[0]select=eq(pict_type\, I)[tag0]"" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\FFmpeg\OutputsData\select_pict_type_I.mp4 -y -hide_banner
[0.4651s]

每 10 帧选取 1 帧

_ = input(data.SHORT1).select('not(mod(n,10))').\
    output(data.TEST_OUTPUTS_DIR / 'select_mod_10.mp4').run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i C:\Users\Admin\Videos\FFmpeg\InputsData\1.mp4 -filter_complex "[0]select=not(mod(n\,10))[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\FFmpeg\OutputsData\select_mod_10.mp4 -y -hide_banner
[0.4770s]

选取某时段的帧

_ = input(data.V1).select('between(t, 10, 20)').\
    output(data.TEST_OUTPUTS_DIR / 'select_between.mp4').run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i C:\Users\Admin\Videos\FFmpeg\InputsData\v1.mp4 -filter_complex ""[0]select=between(t\, 10\, 20)[tag0]"" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\FFmpeg\OutputsData\select_between.mp4 -y -hide_banner
[6.4947s]

某时段的单一帧类型

_ = input(data.V1).select('between(t, 10, 20)*eq(pict_type, I)'). \
    output(data.TEST_OUTPUTS_DIR / 'select_between.mp4').run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i C:\Users\Admin\Videos\FFmpeg\InputsData\v1.mp4 -filter_complex ""[0]select=between(t\, 10\, 20)*eq(pict_type\, I)[tag0]"" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\FFmpeg\OutputsData\select_between.mp4 -y -hide_banner
[5.5827s]

纠正时间戳

_ = input(data.V1).select('not(mod(n,10))').setpts('N/(25*TB)'). \
    output(data.TEST_OUTPUTS_DIR / 'select.mp4').run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i C:\Users\Admin\Videos\FFmpeg\InputsData\v1.mp4 -filter_complex "[0]select=not(mod(n\,10))[tag0];[tag0]setpts=N/(25*TB)[tag1]" -vcodec h264_nvenc -map [tag1] C:\Users\Admin\Videos\FFmpeg\OutputsData\select.mp4 -y -hide_banner
[5.6311s]

sendcmd

https://ffmpeg.org/ffmpeg-filters.html#sendcmd

参数

示例


对比

[视频对比链接]

asendcmd

https://ffmpeg.org/ffmpeg-filters.html#asendcmd

参数

示例


对比

[视频对比链接]

setpts, asetpts

https://ffmpeg.org/ffmpeg-filters.html#setpts

修改输入帧显示时间戳(PTS-presentation timestamp)。其中 setpts 对于视频帧,asetpts 对于音频帧。

参数

  • expr 指定用于计算时间戳的表达式

表达式常量:

  • FRAME_RATE 帧率,仅对于指定了帧率的视频
  • PTS 输入的 PTS
  • N 对输入视频帧计数或已经消耗的样本计数,不包括音频的当前帧,从 0 开始
  • NB_CONSUMED_SAMPLES 采样数(因为音频是按固定频率采样,则一个采样其实就是自然的计时单位——类似帧率),不包括当前帧(仅对音频)
  • NB_SAMPLES, S 当前帧中的采样数 ( 仅音频 )
  • SAMPLE_RATE, SR 音频采样率
  • STARTPTS 第一帧的 PTS
  • STARTT 第一帧的按秒时间
  • INTERLACED 指示当前帧是否交错
  • T 当前帧的按秒时间
  • POS 初始位置在文件中的偏移,为当前帧,如果未定义则本值也未定义
  • PREV_INPTS 前一个帧的 PTS
  • PREV_INT 前一帧按秒时间
  • PREV_OUTPTS 前一帧的输出 PTS
  • PREV_OUTT 前一帧按秒输出时间
  • RTCTIME 时间单位为微秒 -microseconds. 现在被弃用,使用 time(0) 时
  • RTCSTART 影片开始时间以微秒为单位
  • TB 输入时间戳时基

示例

从 0 开始计数 PTS

# Start counting PTS from zero
_ = input(v1).setpts("PTS-STARTPTS").output(testdata_transform / "setpts1.mp4").run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i testdata\v1.mp4 -filter_complex "[0]setpts=PTS-STARTPTS[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\transform\setpts1.mp4 -y -hide_banner
[4.1000s]

对比

[视频对比链接]

加速播放效果

# Apply fast motion effect
_ = input(v1).setpts("0.5*PTS").output(testdata_transform / "setpts2.mp4").run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i testdata\v1.mp4 -filter_complex "[0]setpts=0.5*PTS[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\transform\setpts2.mp4 -y -hide_banner
[3.8456s]

对比

[视频对比链接]

减速播放效果

# Apply slow motion effect
_ = input(v1).setpts("2.0*PTS").output(testdata_transform / "setpts3.mp4").run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i testdata\v1.mp4 -filter_complex "[0]setpts=2.0*PTS[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\transform\setpts3.mp4 -y -hide_banner
[7.6312s]

对比

[视频对比链接]

强制为 25 的帧率

# Set fixed rate of 25 frames per second
_ = input(v1).setpts("N/(25*TB)").output(testdata_transform / "setpts4.mp4").run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i testdata\v1.mp4 -filter_complex "[0]setpts=N/(25*TB)[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\transform\setpts4.mp4 -y -hide_banner
[4.6901s]

对比

[视频对比链接]

设置有抖动的 25 帧率

# Set fixed rate 25 fps with some jitter
_ = input(v1).setpts("1/(25*TB) * (N + 0.05 * sin(N*2*PI/25))").output(testdata_transform / "setpts5.mp4").run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i testdata\v1.mp4 -filter_complex "[0]setpts=1/(25*TB) * (N + 0.05 
* sin(N*2*PI/25))[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\transform\setpts5.mp4 -y -hide_banner
[4.8256s]

对比

[视频对比链接]

应用一个 10 秒的输入偏置

# Apply an offset of 10 seconds to the input PTS
_ = input(v1).setpts("PTS+10/TB").output(testdata_transform / "setpts6.mp4").run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i testdata\v1.mp4 -filter_complex "[0]setpts=PTS+10/TB[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\transform\setpts6.mp4 -y -hide_banner
[4.4644s]

对比

[视频对比链接]

直播源和变基生成时间戳转换到当前时基时间戳

# Generate timestamps from a "live source" and rebase onto the current timebase
_ = input(v1).setpts("(RTCTIME - RTCSTART) / (TB * 1000000)").output(testdata_transform / "setpts7.mp4").run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i testdata\v1.mp4 -filter_complex "[0]setpts=(RTCTIME - RTCSTART) / (TB * 1000000)[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\transform\setpts7.mp4 -y -hide_banner
[3.7406s]

对比

[视频对比链接]

按当前采样率生成时间戳

# Generate timestamps by counting samples
_ = input(v1).setpts("N/SR/TB").output(testdata_transform / "setpts8.mp4").run()
ffmpeg -hwaccel cuda -vcodec h264_cuvid -i testdata\v1.mp4 -filter_complex "[0]setpts=N/SR/TB[tag0]" -vcodec h264_nvenc -map [tag0] C:\Users\Admin\Videos\transform\setpts8.mp4 -y -hide_banner
[3.8506s]

对比

[视频对比链接]

setrange

https://ffmpeg.org/ffmpeg-filters.html#setrange

参数

示例


对比

[视频对比链接]

settb

https://ffmpeg.org/ffmpeg-filters.html#settb

参数

示例


对比

[视频对比链接]

asettb

https://ffmpeg.org/ffmpeg-filters.html#asettb

参数

示例


对比

[视频对比链接]

showcqt

https://ffmpeg.org/ffmpeg-filters.html#showcqt

参数

示例


对比

[视频对比链接]

showfreqs

https://ffmpeg.org/ffmpeg-filters.html#showfreqs

参数

示例


对比

[视频对比链接]

showspatial

https://ffmpeg.org/ffmpeg-filters.html#showspatial

参数

示例


对比

[视频对比链接]

showspectrum

https://ffmpeg.org/ffmpeg-filters.html#showspectrum

参数

示例


对比

[视频对比链接]

showspectrumpic

https://ffmpeg.org/ffmpeg-filters.html#showspectrumpic

参数

示例


对比

[视频对比链接]

showvolume

https://ffmpeg.org/ffmpeg-filters.html#showvolume

参数

示例


对比

[视频对比链接]

showwaves

https://ffmpeg.org/ffmpeg-filters.html#showwaves

参数

示例


对比

[视频对比链接]

showwavespic

https://ffmpeg.org/ffmpeg-filters.html#showwavespic

参数

示例


对比

[视频对比链接]

sidedata

https://ffmpeg.org/ffmpeg-filters.html#sidedata

参数

示例


对比

[视频对比链接]

asidedata

https://ffmpeg.org/ffmpeg-filters.html#asidedata

参数

示例


对比

[视频对比链接]

spectrumsynth

https://ffmpeg.org/ffmpeg-filters.html#spectrumsynth

参数

示例


对比

[视频对比链接]

split

https://ffmpeg.org/ffmpeg-filters.html#split

参数

示例


对比

[视频对比链接]

asplit

https://ffmpeg.org/ffmpeg-filters.html#asplit

参数

示例


对比

[视频对比链接]

zmq

https://ffmpeg.org/ffmpeg-filters.html#zmq

参数

示例


对比

[视频对比链接]

azmq

https://ffmpeg.org/ffmpeg-filters.html#azmq

参数

示例


对比

[视频对比链接]

amovie

https://ffmpeg.org/ffmpeg-filters.html#amovie

参数

示例


对比

[视频对比链接]

movie

https://ffmpeg.org/ffmpeg-filters.html#movie

参数

示例


对比

[视频对比链接]