summaryrefslogtreecommitdiffstats
path: root/gst-libs
diff options
context:
space:
mode:
Diffstat (limited to 'gst-libs')
-rw-r--r--gst-libs/gst/play/gstplay.c93
-rw-r--r--gst-libs/gst/play/play.c93
2 files changed, 126 insertions, 60 deletions
diff --git a/gst-libs/gst/play/gstplay.c b/gst-libs/gst/play/gstplay.c
index 69f6f187..be165ddc 100644
--- a/gst-libs/gst/play/gstplay.c
+++ b/gst-libs/gst/play/gstplay.c
@@ -59,11 +59,11 @@ static GstPipelineClass *parent_class = NULL;
static gboolean
gst_play_pipeline_setup (GstPlay *play)
{
- GstElement *work_thread, *video_thread;
- GstElement *source, *autoplugger, *video_switch;
- GstElement *video_queue, *video_colorspace, *video_scaler, *video_sink;
+ GstElement *work_thread, *video_thread, *source;
+ GstElement *autoplugger, *switch_colorspace, *video_switch, *video_queue;
+ GstElement *video_balance, *video_colorspace, *video_scaler, *video_sink;
GstElement *audio_thread, *audio_queue, *audio_volume, *audio_sink;
- GstElement *audio_tee, *vis_thread, *vis_queue, *vis_element;
+ GstElement *audio_tee, *vis_thread, *vis_queue, *vis_element, *end_vis_queue;
GstPad *audio_tee_pad1, *audio_tee_pad2, *vis_thread_pad, *audio_sink_pad;
g_return_val_if_fail (play != NULL, FALSE);
@@ -76,7 +76,7 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "work_thread", work_thread);
gst_bin_add (GST_BIN (play), work_thread);
- /* Placeholder for the source and autoplugger { fakesrc ! spider } */
+ /* Placeholder for the source and autoplugger { fakesrc ! spider } */
source = gst_element_factory_make ("fakesrc", "source");
if (!GST_IS_ELEMENT (source))
return FALSE;
@@ -93,7 +93,7 @@ gst_play_pipeline_setup (GstPlay *play)
gst_element_link (source, autoplugger);
/* Creating our video output bin
- { queue ! colorspace ! videoscale ! fakesink } */
+ { queue ! videobalance ! colorspace ! videoscale ! fakesink } */
video_thread = gst_element_factory_make ("thread", "video_thread");
if (!GST_IS_ELEMENT (video_thread))
return FALSE;
@@ -108,6 +108,14 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "video_queue", video_queue);
+ video_balance = gst_element_factory_make ("videobalance",
+ "video_balance");
+ if (!GST_IS_ELEMENT (video_balance))
+ return FALSE;
+
+ g_hash_table_insert (play->priv->elements, "video_balance",
+ video_balance);
+
/* Colorspace conversion */
video_colorspace = gst_element_factory_make ("ffcolorspace",
"video_colorspace");
@@ -136,13 +144,27 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "video_sink", video_sink);
/* Linking, Adding, Ghosting */
- gst_element_link_many (video_queue, video_colorspace,
+ gst_element_link_many (video_queue, video_balance, video_colorspace,
video_scaler, video_sink, NULL);
- gst_bin_add_many (GST_BIN (video_thread), video_queue, video_colorspace,
- video_scaler, video_sink, NULL);
+ gst_bin_add_many (GST_BIN (video_thread), video_queue, video_balance,
+ video_colorspace, video_scaler, video_sink, NULL);
gst_element_add_ghost_pad (video_thread,
gst_element_get_pad (video_queue, "sink"),
- "sink");
+ "sink");
+
+ /* autoplugger ! ffcolorspace ! switch */
+ switch_colorspace = NULL;
+ switch_colorspace = gst_element_factory_make ("ffcolorspace",
+ "switch_colorspace");
+ if (!GST_IS_ELEMENT (switch_colorspace)) {
+ switch_colorspace = gst_element_factory_make ("colorspace",
+ "switch_colorspace");
+ if (!GST_IS_ELEMENT (switch_colorspace))
+ return FALSE;
+ }
+
+ g_hash_table_insert (play->priv->elements, "switch_colorspace",
+ switch_colorspace);
video_switch = gst_element_factory_make ("switch",
"video_switch");
@@ -151,12 +173,13 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "video_switch", video_switch);
- /*gst_bin_add (GST_BIN (work_thread), video_switch);*/
+ gst_bin_add_many (GST_BIN (work_thread), switch_colorspace,
+ /*video_switch,*/ NULL);
- /* Connecting autoplugger to video switch and video switch to video output
- gst_element_link (autoplugger, video_switch);
- gst_element_link (video_switch, video_thread);*/
- gst_element_link (autoplugger, video_thread);
+ /* Connecting autoplugger to video switch and video switch to video output */
+ gst_element_link_many (autoplugger, switch_colorspace,
+ /*video_switch,*/ video_thread, NULL);
+ /* gst_element_link (autoplugger, video_thread); */
/* Creating our audio output bin
{ queue ! volume ! tee ! { queue ! goom } ! fakesink } */
@@ -224,12 +247,20 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "vis_element", vis_element);
+ end_vis_queue = gst_element_factory_make ("queue", "end_vis_queue");
+ if (!GST_IS_ELEMENT (end_vis_queue))
+ return FALSE;
+
+ g_hash_table_insert (play->priv->elements, "end_vis_queue",
+ end_vis_queue);
+
/* Adding, Linking, Ghosting in visualization */
- gst_bin_add_many (GST_BIN (vis_thread), vis_queue, vis_element, NULL);
- gst_element_link (vis_queue, vis_element);
+ gst_bin_add_many (GST_BIN (vis_thread), vis_queue, vis_element,
+ end_vis_queue, NULL);
+ gst_element_link_many (vis_queue, vis_element, end_vis_queue, NULL);
vis_thread_pad = gst_element_add_ghost_pad (vis_thread,
gst_element_get_pad (vis_queue, "sink"),
- "sink");
+ "sink");
g_hash_table_insert (play->priv->elements, "vis_thread_pad",
vis_thread_pad);
@@ -241,7 +272,7 @@ gst_play_pipeline_setup (GstPlay *play)
audio_tee, vis_thread, audio_sink, NULL);
gst_element_add_ghost_pad (audio_thread,
gst_element_get_pad (audio_queue, "sink"),
- "sink");
+ "sink");
/* Connecting audio output to autoplugger */
gst_element_link (autoplugger, audio_thread);
@@ -473,7 +504,8 @@ gst_play_class_init (GstPlayClass *klass)
gboolean
gst_play_set_location (GstPlay *play, const char *location)
{
- GstElement *work_thread, *source, *autoplugger, *video_thread, *audio_thread;
+ GstElement *work_thread, *source, *autoplugger;
+ GstElement *switch_colorspace, *audio_thread;
g_return_val_if_fail (play != NULL, FALSE);
g_return_val_if_fail (GST_IS_PLAY (play), FALSE);
@@ -489,8 +521,9 @@ gst_play_set_location (GstPlay *play, const char *location)
work_thread = g_hash_table_lookup (play->priv->elements, "work_thread");
if (!GST_IS_ELEMENT (work_thread))
return FALSE;
- video_thread = g_hash_table_lookup (play->priv->elements, "video_thread");
- if (!GST_IS_ELEMENT (video_thread))
+ switch_colorspace = g_hash_table_lookup (play->priv->elements,
+ "switch_colorspace");
+ if (!GST_IS_ELEMENT (switch_colorspace))
return FALSE;
audio_thread = g_hash_table_lookup (play->priv->elements, "audio_thread");
if (!GST_IS_ELEMENT (audio_thread))
@@ -505,7 +538,7 @@ gst_play_set_location (GstPlay *play, const char *location)
/* Spider can autoplugg only once. We remove the actual one and put a new
autoplugger */
gst_element_unlink (source, autoplugger);
- gst_element_unlink (autoplugger, video_thread);
+ gst_element_unlink (autoplugger, switch_colorspace);
gst_element_unlink (autoplugger, audio_thread);
gst_bin_remove (GST_BIN (work_thread), autoplugger);
@@ -515,7 +548,7 @@ gst_play_set_location (GstPlay *play, const char *location)
gst_bin_add (GST_BIN (work_thread), autoplugger);
gst_element_link (source, autoplugger);
- gst_element_link (autoplugger, video_thread);
+ gst_element_link (autoplugger, switch_colorspace);
gst_element_link (autoplugger, audio_thread);
g_hash_table_replace (play->priv->elements, "autoplugger", autoplugger);
@@ -778,7 +811,7 @@ gst_play_set_audio_sink (GstPlay *play, GstElement *audio_sink)
gboolean
gst_play_set_visualization (GstPlay *play, GstElement *vis_element)
{
- GstElement *old_vis_element, *vis_thread, *vis_queue/*, *video_switch*/;
+ GstElement *old_vis_element, *vis_thread, *vis_queue, *end_vis_queue;
gboolean was_playing = FALSE;
g_return_val_if_fail (play != NULL, FALSE);
@@ -803,17 +836,17 @@ gst_play_set_visualization (GstPlay *play, GstElement *vis_element)
vis_queue = g_hash_table_lookup (play->priv->elements, "vis_queue");
if (!GST_IS_ELEMENT (vis_queue))
return FALSE;
- /*video_switch = g_hash_table_lookup (play->priv->elements, "video_switch");
- if (!GST_IS_ELEMENT (video_switch))
- return FALSE;*/
+ end_vis_queue = g_hash_table_lookup (play->priv->elements, "end_vis_queue");
+ if (!GST_IS_ELEMENT (end_vis_queue))
+ return FALSE;
/* Unlinking, removing the old element then adding and linking the new one */
gst_element_unlink (vis_queue, old_vis_element);
- /*gst_element_unlink (old_vis_element, video_switch);*/
+ gst_element_unlink (old_vis_element, end_vis_queue);
gst_bin_remove (GST_BIN (vis_thread), old_vis_element);
gst_bin_add (GST_BIN (vis_thread), vis_element);
gst_element_link (vis_queue, vis_element);
- /*gst_element_link (vis_element, video_switch);*/
+ gst_element_link (vis_element, end_vis_queue);
if (was_playing)
gst_element_set_state (GST_ELEMENT (play), GST_STATE_PLAYING);
diff --git a/gst-libs/gst/play/play.c b/gst-libs/gst/play/play.c
index 69f6f187..be165ddc 100644
--- a/gst-libs/gst/play/play.c
+++ b/gst-libs/gst/play/play.c
@@ -59,11 +59,11 @@ static GstPipelineClass *parent_class = NULL;
static gboolean
gst_play_pipeline_setup (GstPlay *play)
{
- GstElement *work_thread, *video_thread;
- GstElement *source, *autoplugger, *video_switch;
- GstElement *video_queue, *video_colorspace, *video_scaler, *video_sink;
+ GstElement *work_thread, *video_thread, *source;
+ GstElement *autoplugger, *switch_colorspace, *video_switch, *video_queue;
+ GstElement *video_balance, *video_colorspace, *video_scaler, *video_sink;
GstElement *audio_thread, *audio_queue, *audio_volume, *audio_sink;
- GstElement *audio_tee, *vis_thread, *vis_queue, *vis_element;
+ GstElement *audio_tee, *vis_thread, *vis_queue, *vis_element, *end_vis_queue;
GstPad *audio_tee_pad1, *audio_tee_pad2, *vis_thread_pad, *audio_sink_pad;
g_return_val_if_fail (play != NULL, FALSE);
@@ -76,7 +76,7 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "work_thread", work_thread);
gst_bin_add (GST_BIN (play), work_thread);
- /* Placeholder for the source and autoplugger { fakesrc ! spider } */
+ /* Placeholder for the source and autoplugger { fakesrc ! spider } */
source = gst_element_factory_make ("fakesrc", "source");
if (!GST_IS_ELEMENT (source))
return FALSE;
@@ -93,7 +93,7 @@ gst_play_pipeline_setup (GstPlay *play)
gst_element_link (source, autoplugger);
/* Creating our video output bin
- { queue ! colorspace ! videoscale ! fakesink } */
+ { queue ! videobalance ! colorspace ! videoscale ! fakesink } */
video_thread = gst_element_factory_make ("thread", "video_thread");
if (!GST_IS_ELEMENT (video_thread))
return FALSE;
@@ -108,6 +108,14 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "video_queue", video_queue);
+ video_balance = gst_element_factory_make ("videobalance",
+ "video_balance");
+ if (!GST_IS_ELEMENT (video_balance))
+ return FALSE;
+
+ g_hash_table_insert (play->priv->elements, "video_balance",
+ video_balance);
+
/* Colorspace conversion */
video_colorspace = gst_element_factory_make ("ffcolorspace",
"video_colorspace");
@@ -136,13 +144,27 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "video_sink", video_sink);
/* Linking, Adding, Ghosting */
- gst_element_link_many (video_queue, video_colorspace,
+ gst_element_link_many (video_queue, video_balance, video_colorspace,
video_scaler, video_sink, NULL);
- gst_bin_add_many (GST_BIN (video_thread), video_queue, video_colorspace,
- video_scaler, video_sink, NULL);
+ gst_bin_add_many (GST_BIN (video_thread), video_queue, video_balance,
+ video_colorspace, video_scaler, video_sink, NULL);
gst_element_add_ghost_pad (video_thread,
gst_element_get_pad (video_queue, "sink"),
- "sink");
+ "sink");
+
+ /* autoplugger ! ffcolorspace ! switch */
+ switch_colorspace = NULL;
+ switch_colorspace = gst_element_factory_make ("ffcolorspace",
+ "switch_colorspace");
+ if (!GST_IS_ELEMENT (switch_colorspace)) {
+ switch_colorspace = gst_element_factory_make ("colorspace",
+ "switch_colorspace");
+ if (!GST_IS_ELEMENT (switch_colorspace))
+ return FALSE;
+ }
+
+ g_hash_table_insert (play->priv->elements, "switch_colorspace",
+ switch_colorspace);
video_switch = gst_element_factory_make ("switch",
"video_switch");
@@ -151,12 +173,13 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "video_switch", video_switch);
- /*gst_bin_add (GST_BIN (work_thread), video_switch);*/
+ gst_bin_add_many (GST_BIN (work_thread), switch_colorspace,
+ /*video_switch,*/ NULL);
- /* Connecting autoplugger to video switch and video switch to video output
- gst_element_link (autoplugger, video_switch);
- gst_element_link (video_switch, video_thread);*/
- gst_element_link (autoplugger, video_thread);
+ /* Connecting autoplugger to video switch and video switch to video output */
+ gst_element_link_many (autoplugger, switch_colorspace,
+ /*video_switch,*/ video_thread, NULL);
+ /* gst_element_link (autoplugger, video_thread); */
/* Creating our audio output bin
{ queue ! volume ! tee ! { queue ! goom } ! fakesink } */
@@ -224,12 +247,20 @@ gst_play_pipeline_setup (GstPlay *play)
g_hash_table_insert (play->priv->elements, "vis_element", vis_element);
+ end_vis_queue = gst_element_factory_make ("queue", "end_vis_queue");
+ if (!GST_IS_ELEMENT (end_vis_queue))
+ return FALSE;
+
+ g_hash_table_insert (play->priv->elements, "end_vis_queue",
+ end_vis_queue);
+
/* Adding, Linking, Ghosting in visualization */
- gst_bin_add_many (GST_BIN (vis_thread), vis_queue, vis_element, NULL);
- gst_element_link (vis_queue, vis_element);
+ gst_bin_add_many (GST_BIN (vis_thread), vis_queue, vis_element,
+ end_vis_queue, NULL);
+ gst_element_link_many (vis_queue, vis_element, end_vis_queue, NULL);
vis_thread_pad = gst_element_add_ghost_pad (vis_thread,
gst_element_get_pad (vis_queue, "sink"),
- "sink");
+ "sink");
g_hash_table_insert (play->priv->elements, "vis_thread_pad",
vis_thread_pad);
@@ -241,7 +272,7 @@ gst_play_pipeline_setup (GstPlay *play)
audio_tee, vis_thread, audio_sink, NULL);
gst_element_add_ghost_pad (audio_thread,
gst_element_get_pad (audio_queue, "sink"),
- "sink");
+ "sink");
/* Connecting audio output to autoplugger */
gst_element_link (autoplugger, audio_thread);
@@ -473,7 +504,8 @@ gst_play_class_init (GstPlayClass *klass)
gboolean
gst_play_set_location (GstPlay *play, const char *location)
{
- GstElement *work_thread, *source, *autoplugger, *video_thread, *audio_thread;
+ GstElement *work_thread, *source, *autoplugger;
+ GstElement *switch_colorspace, *audio_thread;
g_return_val_if_fail (play != NULL, FALSE);
g_return_val_if_fail (GST_IS_PLAY (play), FALSE);
@@ -489,8 +521,9 @@ gst_play_set_location (GstPlay *play, const char *location)
work_thread = g_hash_table_lookup (play->priv->elements, "work_thread");
if (!GST_IS_ELEMENT (work_thread))
return FALSE;
- video_thread = g_hash_table_lookup (play->priv->elements, "video_thread");
- if (!GST_IS_ELEMENT (video_thread))
+ switch_colorspace = g_hash_table_lookup (play->priv->elements,
+ "switch_colorspace");
+ if (!GST_IS_ELEMENT (switch_colorspace))
return FALSE;
audio_thread = g_hash_table_lookup (play->priv->elements, "audio_thread");
if (!GST_IS_ELEMENT (audio_thread))
@@ -505,7 +538,7 @@ gst_play_set_location (GstPlay *play, const char *location)
/* Spider can autoplugg only once. We remove the actual one and put a new
autoplugger */
gst_element_unlink (source, autoplugger);
- gst_element_unlink (autoplugger, video_thread);
+ gst_element_unlink (autoplugger, switch_colorspace);
gst_element_unlink (autoplugger, audio_thread);
gst_bin_remove (GST_BIN (work_thread), autoplugger);
@@ -515,7 +548,7 @@ gst_play_set_location (GstPlay *play, const char *location)
gst_bin_add (GST_BIN (work_thread), autoplugger);
gst_element_link (source, autoplugger);
- gst_element_link (autoplugger, video_thread);
+ gst_element_link (autoplugger, switch_colorspace);
gst_element_link (autoplugger, audio_thread);
g_hash_table_replace (play->priv->elements, "autoplugger", autoplugger);
@@ -778,7 +811,7 @@ gst_play_set_audio_sink (GstPlay *play, GstElement *audio_sink)
gboolean
gst_play_set_visualization (GstPlay *play, GstElement *vis_element)
{
- GstElement *old_vis_element, *vis_thread, *vis_queue/*, *video_switch*/;
+ GstElement *old_vis_element, *vis_thread, *vis_queue, *end_vis_queue;
gboolean was_playing = FALSE;
g_return_val_if_fail (play != NULL, FALSE);
@@ -803,17 +836,17 @@ gst_play_set_visualization (GstPlay *play, GstElement *vis_element)
vis_queue = g_hash_table_lookup (play->priv->elements, "vis_queue");
if (!GST_IS_ELEMENT (vis_queue))
return FALSE;
- /*video_switch = g_hash_table_lookup (play->priv->elements, "video_switch");
- if (!GST_IS_ELEMENT (video_switch))
- return FALSE;*/
+ end_vis_queue = g_hash_table_lookup (play->priv->elements, "end_vis_queue");
+ if (!GST_IS_ELEMENT (end_vis_queue))
+ return FALSE;
/* Unlinking, removing the old element then adding and linking the new one */
gst_element_unlink (vis_queue, old_vis_element);
- /*gst_element_unlink (old_vis_element, video_switch);*/
+ gst_element_unlink (old_vis_element, end_vis_queue);
gst_bin_remove (GST_BIN (vis_thread), old_vis_element);
gst_bin_add (GST_BIN (vis_thread), vis_element);
gst_element_link (vis_queue, vis_element);
- /*gst_element_link (vis_element, video_switch);*/
+ gst_element_link (vis_element, end_vis_queue);
if (was_playing)
gst_element_set_state (GST_ELEMENT (play), GST_STATE_PLAYING);