尝试使用gstreamer和playbin元素编写播放器。我正在创建一个管道,添加一个总线监视并等待总线上的消息。然后我在管道上设置uri并等待它进入播放状态。代码是这样的(删除检查和清理):
//when user select a resource
m_pipeline = gst_element_factory_make("playbin", "playbin0");
g_object_set(G_OBJECT (m_pipeline), "uri", m_uri.c_str(), NULL);
gst_element_set_state(m_pipeline, GST_STATE_PAUSED);
//when user presses 'play'
gst_element_set_state(m_pipeline, GST_STATE_PLAYING);
在我的总线回调中,我会查找GST_MESSAGE_STATE_CHANGED以了解管道何时开始播放。 有时这会按预期工作,我得到:NULL-> READY,READY-> PAUSED,PAUSED-> PLAYING。
有时我只获得第一名:NULL-> READY。视频无论如何都开始播放,所以有些东西正在运行,但我的应用程序根本不知道播放已经开始。
这只是在应用程序启动时,因此所有运行的前置条件应该相同。我猜测有什么比赛,我是否需要在设置状态或添加总线回调之前等待一些事情?
我在windows btw上使用gstreamer 1.8.1。
这些是通过将GST_DEBUG设置为4获得的日志。
当我得到状态改变时:
0:00:02.918974302 7028 0DF19EC0 INFO GST_STATES gstelement.c:2277:_priv_gst_element_state_changed: notifying about state-changed PAUSED to PLAYING (VOID_PENDING pending) 0:00:02.919185366 7028 06452D20 FIXME bin gstbin.c:4144:gst_bin_query: implement duration caching in GstBin again 0:00:02.919405213 7028 06452D20 FIXME bin gstbin.c:4144:gst_bin_query: implement duration caching in GstBin again 0:00:02.919624475 7028 06452D20 FIXME bin gstbin.c:4144:gst_bin_query: implement duration caching in GstBin again 0:00:02.919882670 7028 06452D20 FIXME bin gstbin.c:4144:gst_bin_query: implement duration caching in GstBin again [Media] IPlayer.cpp:555 gst_element_query_duration 85542000000ns [Media] IPlayer.cpp:152 Pipeline playbin0 changed state from PAUSED to PLAYING pending VOID_PENDING. Duration 85542ms 0:00:02.926384105 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.927016128 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.927645809 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.929138777 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.929487722 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.929740355 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.931064998 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.931415992 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.932754686 7028 06452D20 INFO GST_STATES gstbin.c:1915:gst_bin_get_state_func: getting state 0:00:02.933954622 7028 06452D20 INFO default gstdebugutils.c:811:gst_debug_bin_to_dot_file: wrote bin graph to : 'dot\IPlayer-PLAYING.dot' 0:00:02.950122584 7028 0DEB5920 INFO videodecoder gstvideodecoder.c:1432:gst_video_decoder_sink_event_default: upstream tags: taglist, video-codec=(string)"H.264\ \(Main\ Profile\)", bitrate=(uint)2981313, minimum-bitrate=(uint)281200, maximum-bitrate=(uint)1461000;
当我没有得到状态改变时:
0:00:02.947089811 11792 0D369EC0 INFO GST_STATES gstelement.c:2277:_priv_gst_element_state_changed: notifying about state-changed PAUSED to PLAYING (VOID_PENDING pending) 0:00:02.981495398 11792 0D307920 INFO videodecoder gstvideodecoder.c:1432:gst_video_decoder_sink_event_default: upstream tags: taglist, video-codec=(string)"H.264\ \(Main\ Profile\)", bitrate=(uint)2981313, minimum-bitrate=(uint)281200, maximum-bitrate=(uint)1461000; 0:00:03.020488493 11792 0D307920 INFO videodecoder gstvideodecoder.c:1432:gst_video_decoder_sink_event_default: upstream tags: taglist, video-codec=(string)"H.264\ \(Main\ Profile\)", bitrate=(uint)2981313, minimum-bitrate=(uint)281200, maximum-bitrate=(uint)3918800;
当然日志要长很多,但我假设这是相关的地方。 IPlayer.cpp的东西是我的应用程序,所以这只是在我得到回调时。当我添加/删除某些printf时,我无法再重现这个问题,所以对我来说这似乎是某种竞争条件。
编辑添加日志以及反映在哪些用户操作上执行的代码。