From 6fd0f2618c54d9300cd633c954b69f1d3d6e4197 Mon Sep 17 00:00:00 2001 From: Nicolas Dufresne Date: Mon, 11 Jul 2011 17:01:45 -0400 Subject: Reset clock after changing video resolution This workaround issue with videotestsrc when the test src does not have a a clock after going to NULL state while changing resolution. --- src/empathy-video-src.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/empathy-video-src.c b/src/empathy-video-src.c index bfff30d18..1e362547a 100644 --- a/src/empathy-video-src.c +++ b/src/empathy-video-src.c @@ -426,6 +426,7 @@ empathy_video_src_set_resolution (GstElement *src, { EmpathyGstVideoSrcPrivate *priv = EMPATHY_GST_VIDEO_SRC_GET_PRIVATE (src); GstCaps *caps; + GstClock *gst_clock; g_return_if_fail (priv->capsfilter != NULL); @@ -442,6 +443,13 @@ empathy_video_src_set_resolution (GstElement *src, g_object_set (priv->capsfilter, "caps", caps, NULL); + /* Reset clock an base time, this is require for videotestsrc and hopefully + * has no side effect */ + gst_clock = gst_element_get_clock (src); + gst_element_set_clock (priv->src, gst_clock); + gst_element_set_base_time (priv->src, gst_element_get_base_time (src)); + gst_object_unref (gst_clock); + gst_element_set_locked_state (priv->src, FALSE); gst_element_sync_state_with_parent (priv->src); } -- cgit v1.2.3