summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian@centricular.com>2015-12-25 10:36:44 +0100
committerSebastian Dröge <sebastian@centricular.com>2015-12-28 12:37:58 +0200
commit6b06666065bb6ec624aaea8589b4458488973b85 (patch)
tree0dd7fd6ce2532428abb57d019acb87984906ff3b
parent010057e0a49ffb1d6bc1524055eb15ee98186877 (diff)
downloadgstreamer-plugins-base-6b06666065bb6ec624aaea8589b4458488973b85.tar.gz
playsink: Allow reuse of audio/video filters by unparenting them from their bins
And also recreate the chains if the filter is changing.
-rw-r--r--gst/playback/gstplaysink.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/gst/playback/gstplaysink.c b/gst/playback/gstplaysink.c
index eb81c0558..3b5de5543 100644
--- a/gst/playback/gstplaysink.c
+++ b/gst/playback/gstplaysink.c
@@ -3253,6 +3253,8 @@ gst_play_sink_do_reconfigure (GstPlaySink * playsink)
/* try to reactivate the chain */
if ((playsink->video_sink
&& playsink->video_sink != playsink->videochain->sink)
+ || (playsink->video_filter
+ && playsink->video_filter != playsink->videochain->filter)
|| !setup_video_chain (playsink, raw, async)) {
if (playsink->video_sinkpad_stream_synchronizer) {
gst_element_release_request_pad (GST_ELEMENT_CAST
@@ -3275,6 +3277,16 @@ gst_play_sink_do_reconfigure (GstPlaySink * playsink)
playsink->videochain->sink);
}
+ /* Remove the filter from the bin to keep its state
+ * and unparent it to allow reuse */
+ if (playsink->videochain->filter) {
+ if (playsink->videochain->filter != playsink->video_filter)
+ gst_element_set_state (playsink->videochain->filter,
+ GST_STATE_NULL);
+ gst_bin_remove (GST_BIN_CAST (playsink->videochain->chain.bin),
+ playsink->videochain->filter);
+ }
+
activate_chain (GST_PLAY_CHAIN (playsink->videochain), FALSE);
free_chain ((GstPlayChain *) playsink->videochain);
playsink->videochain = NULL;
@@ -3430,6 +3442,8 @@ gst_play_sink_do_reconfigure (GstPlaySink * playsink)
if (playsink->video_sink)
gst_element_set_state (playsink->video_sink, GST_STATE_NULL);
+ if (playsink->video_filter)
+ gst_element_set_state (playsink->video_filter, GST_STATE_NULL);
}
if (need_audio) {
@@ -3444,6 +3458,8 @@ gst_play_sink_do_reconfigure (GstPlaySink * playsink)
/* try to reactivate the chain */
if ((playsink->audio_sink
&& playsink->audio_sink != playsink->audiochain->sink)
+ || (playsink->audio_filter
+ && playsink->audio_filter != playsink->audiochain->filter)
|| !setup_audio_chain (playsink, raw)) {
GST_DEBUG_OBJECT (playsink, "removing current audio chain");
if (playsink->audio_tee_asrc) {
@@ -3476,6 +3492,16 @@ gst_play_sink_do_reconfigure (GstPlaySink * playsink)
playsink->audiochain->sink);
}
+ /* Remove the filter from the bin to keep its state
+ * and unparent it to allow reuse */
+ if (playsink->audiochain->filter) {
+ if (playsink->audiochain->filter != playsink->audio_filter)
+ gst_element_set_state (playsink->audiochain->filter,
+ GST_STATE_NULL);
+ gst_bin_remove (GST_BIN_CAST (playsink->audiochain->chain.bin),
+ playsink->audiochain->filter);
+ }
+
activate_chain (GST_PLAY_CHAIN (playsink->audiochain), FALSE);
disconnect_audio_chain (playsink->audiochain, playsink);
if (playsink->audiochain->volume)
@@ -3601,6 +3627,8 @@ gst_play_sink_do_reconfigure (GstPlaySink * playsink)
if (playsink->audio_sink)
gst_element_set_state (playsink->audio_sink, GST_STATE_NULL);
+ if (playsink->audio_filter)
+ gst_element_set_state (playsink->audio_filter, GST_STATE_NULL);
}
if (need_vis) {
@@ -4946,6 +4974,19 @@ gst_play_sink_change_state (GstElement * element, GstStateChange transition)
gst_element_set_state (playsink->visualisation, GST_STATE_NULL);
if (playsink->text_sink != NULL)
gst_element_set_state (playsink->text_sink, GST_STATE_NULL);
+
+ /* Unparent the filters to allow reuse */
+ if (playsink->videochain && playsink->videochain->filter)
+ gst_bin_remove (GST_BIN_CAST (playsink->videochain->chain.bin),
+ playsink->videochain->filter);
+ if (playsink->audiochain && playsink->audiochain->filter)
+ gst_bin_remove (GST_BIN_CAST (playsink->audiochain->chain.bin),
+ playsink->audiochain->filter);
+ if (playsink->audio_filter != NULL)
+ gst_element_set_state (playsink->audio_filter, GST_STATE_NULL);
+ if (playsink->video_filter != NULL)
+ gst_element_set_state (playsink->video_filter, GST_STATE_NULL);
+
free_chain ((GstPlayChain *) playsink->videodeinterlacechain);
playsink->videodeinterlacechain = NULL;
free_chain ((GstPlayChain *) playsink->videochain);