GStreamer State Changes

时间:2016-06-10 11:21:04

标签: c++ gstreamer

尝试使用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时,我无法再重现这个问题,所以对我来说这似乎是某种竞争条件。

编辑添加日志以及反映在哪些用户操作上执行的代码。

0 个答案:

没有答案