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