我一直在尝试将2个视频与gstreamer结合使用 使用gstreamer& amp;的短暂过渡(如smpte) gnonlin在python中。但是我无法使gnloperation / smpte转换工作。
以下是一个程序。我希望它播放一个文件的前4秒,并在2秒内开始执行smpte过渡(持续2秒)到另一个文件。 (所以第二个文件将在整个过程中开始播放2秒但在2秒过渡过程中被“显示”),并且在过渡完成后,应该显示第二个文件自身的2秒。
这基于another gstreamer/gnonlin script in python。我在the gstreamer-devel list(和again)上提出了这个问题,我在这里尝试。
过渡未完成。转换运行约0.5秒,然后视频1播放约1.5秒然后视频2切入。我已尝试更改控制器的结束位置(例如更改为controller.set("position", 0.5 * gst.SECOND, 0.0)
),并且
转换在0.5秒内完成,但转换完成后,视频1再次开始播放一段时间,然后视频2开始播放。
认为可能视频转换限制为0.5秒,我将gnloperation更改为0.5秒,但同样的非完成问题仍然存在,除了转换仅播放约0.3秒,并且部分通过视频1开始一点点,然后视频2播放。
#! /usr/bin/python
import gst, gobject
gobject.threads_init()
comp = gst.element_factory_make("gnlcomposition", "composition")
gsrc1 = gst.element_factory_make("gnlfilesource")
gsrc1.props.location = "file:///home/rory/helmetcam/dingle-tom/vshort01.mov"
gsrc1.props.start = 0
gsrc1.props.duration = 4 * gst.SECOND
gsrc1.props.media_start = 0
gsrc1.props.media_duration = 4 * gst.SECOND
gsrc1.props.priority = 3
comp.add(gsrc1)
gsrc2 = gst.element_factory_make("gnlfilesource")
gsrc2.props.location = "file:///home/rory/helmetcam/dingle-tom/vshort02.mov"
gsrc2.props.start = 2 * gst.SECOND
gsrc2.props.duration = 6 * gst.SECOND
gsrc2.props.media_start = 0
gsrc2.props.media_duration = 2 * gst.SECOND
gsrc2.props.priority = 2
comp.add(gsrc2)
bin = gst.Bin()
alpha1 = gst.element_factory_make("alpha")
queue = gst.element_factory_make("queue")
smpte = gst.element_factory_make("smptealpha")
smpte.props.type = 21
mixer = gst.element_factory_make("videomixer")
bin.add(alpha1, queue, smpte, mixer)
alpha1.link(mixer)
queue.link(smpte)
smpte.link(mixer)
controller = gst.Controller(smpte, "position")
controller.set_interpolation_mode("position", gst.INTERPOLATE_LINEAR)
controller.set("position", 0, 1.0)
controller.set("position", 2.0 * gst.SECOND, 0.0)
bin.add_pad(gst.GhostPad("sink1", alpha1.get_pad("sink")))
bin.add_pad(gst.GhostPad("sink2", queue.get_pad("sink")))
bin.add_pad(gst.GhostPad("src", mixer.get_pad("src")))
op = gst.element_factory_make("gnloperation")
op.add(bin)
op.props.start = 2 * gst.SECOND
op.props.duration = 2 * gst.SECOND
op.props.media_start = 0
op.props.media_duration = 2 * gst.SECOND
op.props.priority = 1
comp.add(op)
# create the backend
color= gst.element_factory_make("ffmpegcolorspace")
enc = gst.element_factory_make("theoraenc")
mux = gst.element_factory_make("oggmux")
sink = gst.element_factory_make("filesink")
sink.props.location = "./transitions-between-two.ogv"
pipeline = gst.Pipeline()
pipeline.add(comp, color, enc, mux, sink)
color.link(enc)
enc.link(mux)
mux.link(sink)
def on_pad(comp, pad, elements):
convpad = elements.get_compatible_pad(pad, pad.get_caps())
pad.link(convpad)
comp.connect("pad-added", on_pad, color)
# now run the pipeline
loop = gobject.MainLoop(is_running=True)
bus = pipeline.get_bus()
bus.add_signal_watch()
def on_message(bus, message, loop):
if message.type == gst.MESSAGE_EOS:
loop.quit()
elif message.type == gst.MESSAGE_ERROR:
print message
loop.quit()
bus.connect("message", on_message, loop)
pipeline.set_state(gst.STATE_PLAYING)
loop.run()
pipeline.set_state(gst.STATE_NULL)
答案 0 :(得分:2)
看起来问题出在第二个源文件的属性中。
代替:
gsrc2.props.start = 2 * gst.SECOND
gsrc2.props.duration = 6 * gst.SECOND
gsrc2.props.media_start = 0
gsrc2.props.media_duration = 2 * gst.SECOND
gsrc2.props.priority = 2
尝试:
gsrc2.props.start = 2 * gst.SECOND
gsrc2.props.duration = 4 * gst.SECOND
gsrc2.props.media_start = 0
gsrc2.props.media_duration = 4 * gst.SECOND
gsrc2.props.priority = 2
这似乎对我有用。