我有三个视频:
- 用摄像机拍摄的讲座
- 讲座中使用的计算机的桌面捕获视频
- 和白板的视频
我想创建一个最终视频,其中这三个组件占据屏幕的特定区域。
是否有开源软件可以让我做到这一点(mencoder、ffmpeg、virtualdub..)?你推荐哪一个?
或者是否有一个 C/C++ API 可以让我以编程方式创建类似的东西?
Edit
未来还会有多次录音讲座。这意味着我需要一个通用/自动化的解决方案。
我目前正在检查是否可以使用 GStreamer 编写一个应用程序来完成这项工作。对此有何评论?
Solved!
我使用 GStreamer 的视频混合器元素成功地做到了这一点。我使用 gst-launch 语法创建管道,然后使用 gst_parse_launch 加载它。这是实现复杂管道的一种非常高效的方法。
这是一个管道,它接受两个传入视频流和一个徽标图像,将它们混合成一个流并复制它,以便它同时显示并保存到磁盘。
desktop. ! queue
! ffmpegcolorspace
! videoscale
! video/x-raw-yuv,width=640,height=480
! videobox right=-320
! ffmpegcolorspace
! vmix.sink_0
webcam. ! queue
! ffmpegcolorspace
! videoscale
! video/x-raw-yuv,width=320,height=240
! vmix.sink_1
logo. ! queue
! jpegdec
! ffmpegcolorspace
! videoscale
! video/x-raw-yuv,width=320,height=240
! vmix.sink_2
vmix. ! t.
t. ! queue
! ffmpegcolorspace
! ffenc_mpeg2video
! filesink location="recording.mpg"
t. ! queue
! ffmpegcolorspace
! dshowvideosink
videotestsrc name="desktop"
videotestsrc name="webcam"
multifilesrc name="logo" location="logo.jpg"
videomixer name=vmix
sink_0::xpos=0 sink_0::ypos=0 sink_0::zorder=0
sink_1::xpos=640 sink_1::ypos=0 sink_1::zorder=1
sink_2::xpos=640 sink_2::ypos=240 sink_2::zorder=2
tee name="t"