我正在使用FFmpeg
通过此命令在视频上叠加图像/表情符号 -
"-i "+inputfilePath+" -filter_complex "+"[0][1]overlay=enable='between(t,"+startTime+","+endTime+")'[v1]"+" -map [v0] -map 0:a "+OutputfilePath;
但是上面的命令只会覆盖视频上的图像并保持静止。
在 Instagram 和 Snapchat 中,有新的pin功能。我想要完全相同,例如移动面上的blur
或下面的视频 -
是否可以通过FFmpeg
?
我认为拥有 OPENCV 或 Argumented Reality 知识的人可以为此提供帮助。它与 AR 类似,因为我们需要在视频/实时摄像头上准确移动/缩放表情符号。
答案 0 :(得分:6)
基于叠加规范: https://ffmpeg.org/ffmpeg-filters.html#overlay-1
当您指定时间间隔时,它将仅在该时间间隔发生:
例如,要启用模糊过滤器(smartblur)10秒到3分钟:
smartblur = enable='between(t,10,3*60)'
您需要做的是在特定坐标处叠加图像,例如以下固定的x和y:
ffmpeg -i rtsp://[host]:[port] -i x.png -filter_complex 'overlay=10:main_h-overlay_h-10' http://[host]:[post]/output.ogg
现在的想法是根据视频的当前帧计算这些坐标,并强制过滤器在每一帧上使用更改的坐标。 例如,基于时间: FFmpeg move overlay from one pixel coordinate to another
ffmpeg -i bg.mp4 -i fg.mkv -filter_complex \
"[0:v][1:v]overlay=enable='between=(t,10,20)':x=720+t*28:y=t*10[out]" \
-map "[out]" output.mkv
或使用其他一些表达方式: http://ffmpeg.org/ffmpeg-utils.html#Expression-Evaluation
不幸的是,这需要在使用猫移动头部或画笔用于x和y的那些有限表达式之前找到公式。它可以是线性,三角函数或其他依赖性:
x=sin(t)
随着自由行动,并非总是可行。
为了更精确地找到一个对象坐标以覆盖某些东西,应该可以提供类似于overlay的自己的过滤器(ffmpeg是开源的): https://github.com/FFmpeg/FFmpeg/blob/master/libavfilter/vf_overlay.c
根据外部文件计算x和y(如果它是静态视频,您可以将所有x和y全部转储)或者进行一些图像处理以查找特定区域。
希望它会给你一个想法和方向。 这是非常有趣的功能。