Python GStreamer和Theora

Python GStreamer和Theora,python,gstreamer,Python,Gstreamer,我想和GStreamer一起工作。我正在学习一个教程(),该教程提供了以下代码: #!/usr/bin/env python import sys, os import pygtk, gtk, gobject import pygst pygst.require("0.10") import gst class GTK_Main: def __init__(self): window = gtk.Window(gtk.WINDOW_TOPLEVEL)

我想和GStreamer一起工作。我正在学习一个教程(),该教程提供了以下代码:

#!/usr/bin/env python

import sys, os
import pygtk, gtk, gobject
import pygst
pygst.require("0.10")
import gst

class GTK_Main:

    def __init__(self):
        window = gtk.Window(gtk.WINDOW_TOPLEVEL)
        window.set_title("Mpeg2-Player")
        window.set_default_size(500, 400)
        window.connect("destroy", gtk.main_quit, "WM destroy")
        vbox = gtk.VBox()
        window.add(vbox)
        hbox = gtk.HBox()
        vbox.pack_start(hbox, False)
        self.entry = gtk.Entry()
        hbox.add(self.entry)
        self.button = gtk.Button("Start")
        hbox.pack_start(self.button, False)
        self.button.connect("clicked", self.start_stop)
        self.movie_window = gtk.DrawingArea()
        vbox.add(self.movie_window)
        window.show_all()

        self.player = gst.Pipeline("player")
        source = gst.element_factory_make("filesrc", "file-source")
        demuxer = gst.element_factory_make("oggdemux", "demuxer")
        demuxer.connect("pad-added", self.demuxer_callback)
        self.video_decoder = gst.element_factory_make("theoradec", "video-decoder")
        self.audio_decoder = gst.element_factory_make("mad", "audio-decoder")
        audioconv = gst.element_factory_make("audioconvert", "converter")
        audiosink = gst.element_factory_make("autoaudiosink", "audio-output")
        videosink = gst.element_factory_make("autovideosink", "video-output")
        self.queuea = gst.element_factory_make("queue", "queuea")
        self.queuev = gst.element_factory_make("queue", "queuev")
        colorspace = gst.element_factory_make("ffmpegcolorspace", "colorspace")

        self.player.add(source, demuxer, self.video_decoder, self.audio_decoder, audioconv,
            audiosink, videosink, self.queuea, self.queuev, colorspace)
        gst.element_link_many(source, demuxer)
        gst.element_link_many(self.queuev, self.video_decoder, colorspace, videosink)
        gst.element_link_many(self.queuea, self.audio_decoder, audioconv, audiosink)

        bus = self.player.get_bus()
        bus.add_signal_watch()
        bus.enable_sync_message_emission()
        bus.connect("message", self.on_message)
        bus.connect("sync-message::element", self.on_sync_message)

    def start_stop(self, w):
        if self.button.get_label() == "Start":
            filepath = self.entry.get_text()
            if os.path.isfile(filepath):
                self.button.set_label("Stop")
                self.player.get_by_name("file-source").set_property("location", filepath)
                self.player.set_state(gst.STATE_PLAYING)
        else:
            self.player.set_state(gst.STATE_NULL)
            self.button.set_label("Start")

    def on_message(self, bus, message):
        t = message.type
        if t == gst.MESSAGE_EOS:
            self.player.set_state(gst.STATE_NULL)
            self.button.set_label("Start")
        elif t == gst.MESSAGE_ERROR:
            err, debug = message.parse_error()
            print "Error: %s" % err, debug
            self.player.set_state(gst.STATE_NULL)
            self.button.set_label("Start")

    def on_sync_message(self, bus, message):
        if message.structure is None:
            return
        message_name = message.structure.get_name()
        if message_name == "prepare-xwindow-id":
            imagesink = message.src
            imagesink.set_property("force-aspect-ratio", True)
            gtk.gdk.threads_enter()
            imagesink.set_xwindow_id(self.movie_window.window.xid)
            gtk.gdk.threads_leave()

    def demuxer_callback(self, demuxer, pad):
        if pad.get_property("template").name_template == "video_%02d":
            qv_pad = self.queuev.get_pad("sink")
            pad.link(qv_pad)
        elif pad.get_property("template").name_template == "audio_%02d":
            qa_pad = self.queuea.get_pad("sink")
            pad.link(qa_pad)

GTK_Main()
gtk.gdk.threads_init()
gtk.main()
当我尝试播放.ogv文件时,出现以下错误

videotest.py:88:警告:g_对象\u集\u数据:断言'g_是\u对象 如果pad.get_属性(“模板”).name_模板,则“对象”失败== “video_uu%02d”:回溯(最近一次呼叫最后一次):文件 “videotest.py”,第88行,在demuxer_回调中 如果pad.get_属性(“模板”).name_template==“video_uu%02d”: AttributeError:“非类型”对象没有属性“名称\模板” 回溯(最近一次调用last):文件“videotest.py”,第88行,在 解复用器 如果pad.get_属性(“模板”).name_template==“video_uu%02d”: AttributeError:“非类型”对象没有属性“名称\模板”


我真的需要能够播放视频。如何修复此问题?

通过模板名称确定焊盘类型是不可靠的,因为它并不总是具有此属性

最好检查功能。这里是diff:

@@ -85,10 +85,11 @@
             gtk.gdk.threads_leave()

     def demuxer_callback(self, demuxer, pad):
-        if pad.get_property("template").name_template == "video_%02d":
+        typ = pad.get_caps()[0].get_name()
+        if typ.startswith("video"):
             qv_pad = self.queuev.get_pad("sink")
             pad.link(qv_pad)
-        elif pad.get_property("template").name_template == "audio_%02d":
+        elif typ.startswith("audio"):
             qa_pad = self.queuea.get_pad("sink")
             pad.link(qa_pad)

你能给教程添加一个链接吗?我想理解为什么demuxer_回调函数看起来像这样。我修改了我的代码,使这个问题与我的项目无关,但我接受你的答案,并结束了这个问题。非常感谢。