我一直在一个项目中使用 pygst,并且运行良好。我正在尝试将其迁移到新的内省(introspection)系统 (GI),但我得到了不同的行为。
在旧的 pygst 中我有这样的东西:
... # other imports
import pygst
pygst.require('0.10')
import gst
... # other imports
gobjects.threads_init()
...
def my_handler(bus, message):
# handle the message
...
player = gst.element_factory_make('playbin2', 'my_player')
bus = player.get_bus()
bus.connect('message', my_handler)
bus.add_signal_watch()
...
player.set_state(gst.STATE_PLAYING)
# start the main Glib loop
message参数有一个属性.type,可用于选择性处理(我只对流结束(EOS)和错误感兴趣)。使用我的新系统:
... # other imports
from gi.repository import Gst
import glib
import gobject
.... # other imports
gobject.threads_init()
loop = glib.MainLoop(None, False)
def bus_handler(bus, message):
print message
# handle the message
...
Gst.init_check(None)
player = Gst.ElementFactory.make('playbin2', 'my_player')
player.set_property('uri', 'file:///home/kenji/button.ogg')
bus = player.get_bus()
bus.connect('message', bus_handler)
bus.add_signal_watch()
player.set_state(Gst.State.PLAYING)
# start the main loop
但是,处理程序接收的参数message始终为None。我已尝试过滤掉这些内容,但仍然一无所获(即所有消息均无)。
我已经阅读了很多 GStreamer 文档(特别是关于 GstBus、add_signal_watch() 和 playbin2),但我没有找到与此行为相关的任何内容。我检查了 Gst gir 文件,发现 add_watch() 无法内省(introspection),所以这是一个死胡同。上面示例中的 glib 主循环只是为了让事情变得更短,而没有完整的 GTK 示例,但实际情况使用 Gtk.main() (给出完全相同的行为)。
我在 Arch Linux 64 上使用 GStreamer 0.10.35.0(由 Gst.version() 通知),但我在 Ubuntu 11.04 32 位上的 GStreamer 0.10.32.0 上测试了相同的行为。
有没有bus.connect()的替代方案?我是否以错误的方式使用它?我花了相当多的时间来寻找这个错误,我真的很感激对此的任何见解。谢谢! =)
最佳答案
我很确定接受的答案是不正确的。 add_signal_watch_full
和 add_signal_watch
之间的唯一区别是前者允许您设置事件源的优先级,而后者仅使用 G_PRIORITY_DEFAULT
调用前者>。您可以在 C source code 中验证这一点,第 940 行。优先级仅影响事件触发的顺序,不应该影响事件是否触发,当然也不影响信号消息的内容,这是这里的问题。我什至用各种优先级值对其进行了测试,如果有一种可行的方法,我会吃掉我的帽子。 :-)
真正的答案是它不起作用。 PyGObject 和 GStreamer 0.10 不能很好地协同工作。请参阅:
后者说:“请注意,虽然您可以某种将 GStreamer0.10 与 PyGI 一起使用,但关键功能从根本上被破坏,并且永远不会在 GStreamer0.10 中修复(因为它需要 API破损)。”
那么,您的选择是:
- 需要 GStreamer 1.0。
- 使用旧的 PyGST 绑定(bind)。
- 将 PyGObject 与 GStreamer 0.10 结合使用,但无法检查 EOS 等消息。只有非常基本的东西才能工作。
关于python - GStreamer 总线发送 None 消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7005058/