diff options
author | Gernot Ziegler <gz@lysator.liu.se> | 2003-04-29 18:22:07 +0000 |
---|---|---|
committer | Gernot Ziegler <gz@lysator.liu.se> | 2003-04-29 18:22:07 +0000 |
commit | 06eb9f47626a6f0abdab20c29c90428e2f541133 (patch) | |
tree | 2ead320eebaf49f1083470ef5b10d8f4a24c3d8a /examples | |
parent | 746b23ae615b171937338d436f1a45b3d0244024 (diff) | |
download | gst-plugins-bad-06eb9f47626a6f0abdab20c29c90428e2f541133.tar.gz gst-plugins-bad-06eb9f47626a6f0abdab20c29c90428e2f541133.tar.bz2 gst-plugins-bad-06eb9f47626a6f0abdab20c29c90428e2f541133.zip |
Fixed element seeking, and put in some comments
Original commit message from CVS:
Fixed element seeking, and put in some comments
Diffstat (limited to 'examples')
-rw-r--r-- | examples/seeking/seek.c | 59 |
1 files changed, 54 insertions, 5 deletions
diff --git a/examples/seeking/seek.c b/examples/seeking/seek.c index f96f8494..16ee46da 100644 --- a/examples/seeking/seek.c +++ b/examples/seeking/seek.c @@ -21,7 +21,9 @@ static guint update_id; #define UPDATE_INTERVAL 500 #define THREAD -#define PAD_SEEK + +// now deprecated: +//#define PAD_SEEK typedef struct { @@ -59,6 +61,7 @@ setup_dynamic_link (GstElement *element, const gchar *padname, GstPad *target, G g_signal_connect (G_OBJECT (element), "new_pad", G_CALLBACK (dynamic_link), connect); } +/* A MOD Audio decoder pipe. */ static GstElement* make_mod_pipeline (const gchar *location) { @@ -87,9 +90,12 @@ make_mod_pipeline (const gchar *location) rate_pads = g_list_prepend (rate_pads, seekable); rate_pads = g_list_prepend (rate_pads, gst_element_get_pad (decoder, "sink")); + seekable_elements = g_list_prepend (seekable_elements, audiosink); + return pipeline; } +/* A DV A/V decoder pipe. */ static GstElement* make_dv_pipeline (const gchar *location) { @@ -124,9 +130,13 @@ make_dv_pipeline (const gchar *location) rate_pads = g_list_prepend (rate_pads, seekable); rate_pads = g_list_prepend (rate_pads, gst_element_get_pad (decoder, "sink")); + seekable_elements = g_list_prepend (seekable_elements, audiosink); + seekable_elements = g_list_prepend (seekable_elements, videosink); + return pipeline; } +/* A WAV audio decoder pipe. */ static GstElement* make_wav_pipeline (const gchar *location) { @@ -155,9 +165,12 @@ make_wav_pipeline (const gchar *location) rate_pads = g_list_prepend (rate_pads, seekable); rate_pads = g_list_prepend (rate_pads, gst_element_get_pad (decoder, "sink")); + seekable_elements = g_list_prepend (seekable_elements, audiosink); + return pipeline; } +/* A FLAC decoder pipe. */ static GstElement* make_flac_pipeline (const gchar *location) { @@ -186,9 +199,12 @@ make_flac_pipeline (const gchar *location) rate_pads = g_list_prepend (rate_pads, seekable); rate_pads = g_list_prepend (rate_pads, gst_element_get_pad (decoder, "sink")); + seekable_elements = g_list_prepend (seekable_elements, audiosink); + return pipeline; } +/* A SID audio decoder pipe. */ static GstElement* make_sid_pipeline (const gchar *location) { @@ -217,9 +233,12 @@ make_sid_pipeline (const gchar *location) rate_pads = g_list_prepend (rate_pads, seekable); rate_pads = g_list_prepend (rate_pads, gst_element_get_pad (decoder, "sink")); + seekable_elements = g_list_prepend (seekable_elements, audiosink); + return pipeline; } +/* An MPEG parser pipeline, to get info on an MPEG file. */ static GstElement* make_parse_pipeline (const gchar *location) { @@ -249,9 +268,12 @@ make_parse_pipeline (const gchar *location) rate_pads = g_list_prepend (rate_pads, seekable); rate_pads = g_list_prepend (rate_pads, gst_element_get_pad (parser, "sink")); + seekable_elements = g_list_prepend (seekable_elements, fakesink); + return pipeline; } +/* A Vorbis Audio decoder pipe. */ static GstElement* make_vorbis_pipeline (const gchar *location) { @@ -280,9 +302,12 @@ make_vorbis_pipeline (const gchar *location) rate_pads = g_list_prepend (rate_pads, seekable); rate_pads = g_list_prepend (rate_pads, gst_element_get_pad (decoder, "sink")); + seekable_elements = g_list_prepend (seekable_elements, audiosink); + return pipeline; } +/* An MP3 Audio decoder pipe. */ static GstElement* make_mp3_pipeline (const gchar *location) { @@ -322,6 +347,7 @@ make_mp3_pipeline (const gchar *location) return pipeline; } +/* An AVI A/V decoder pipe. */ static GstElement* make_avi_pipeline (const gchar *location) { @@ -392,6 +418,7 @@ make_avi_pipeline (const gchar *location) return pipeline; } +/* An MPEG A/V decoder pipe. */ static GstElement* make_mpeg_pipeline (const gchar *location) { @@ -409,8 +436,6 @@ make_mpeg_pipeline (const gchar *location) demux = gst_element_factory_make_or_warn ("mpegdemux", "demux"); g_object_set (G_OBJECT (demux), "sync", TRUE, NULL); - seekable_elements = g_list_prepend (seekable_elements, demux); - gst_bin_add (GST_BIN (pipeline), src); gst_bin_add (GST_BIN (pipeline), demux); gst_element_link (src, demux); @@ -450,6 +475,9 @@ make_mpeg_pipeline (const gchar *location) setup_dynamic_link (demux, "video_00", gst_element_get_pad (v_decoder, "sink"), video_bin); + seekable_elements = g_list_prepend (seekable_elements, videosink); + seekable_elements = g_list_prepend (seekable_elements, audiosink); + seekable = gst_element_get_pad (v_queue, "src"); seekable_pads = g_list_prepend (seekable_pads, seekable); rate_pads = g_list_prepend (rate_pads, seekable); @@ -458,6 +486,7 @@ make_mpeg_pipeline (const gchar *location) return pipeline; } +/* The new version of the MPEG A/V decoder pipe */ static GstElement* make_mpegnt_pipeline (const gchar *location) { @@ -475,8 +504,6 @@ make_mpegnt_pipeline (const gchar *location) demux = gst_element_factory_make_or_warn ("mpegdemux", "demux"); //g_object_set (G_OBJECT (demux), "sync", TRUE, NULL); - seekable_elements = g_list_prepend (seekable_elements, demux); - gst_bin_add (GST_BIN (pipeline), src); gst_bin_add (GST_BIN (pipeline), demux); gst_element_link (src, demux); @@ -517,6 +544,9 @@ make_mpegnt_pipeline (const gchar *location) rate_pads = g_list_prepend (rate_pads, seekable); rate_pads = g_list_prepend (rate_pads, gst_element_get_pad (v_decoder, "sink")); + seekable_elements = g_list_prepend (seekable_elements, audiosink); + seekable_elements = g_list_prepend (seekable_elements, videosink); + return pipeline; } @@ -618,6 +648,7 @@ query_durations () } } + G_GNUC_UNUSED static void query_positions () { @@ -649,6 +680,7 @@ query_positions () } } +/* Every 1 s = 1000 ms, update_scale reads the new media time */ static gboolean update_scale (gpointer data) { @@ -679,6 +711,7 @@ update_scale (gpointer data) return TRUE; } +/* Make the pipeline play through repeated iteration. */ static gboolean iterate (gpointer data) { @@ -692,6 +725,9 @@ iterate (gpointer data) return res; } +/* + As soon as the user starts moving the seeking scale, pause playback. +*/ static gboolean start_seek (GtkWidget *widget, GdkEventButton *event, gpointer user_data) { @@ -701,12 +737,18 @@ start_seek (GtkWidget *widget, GdkEventButton *event, gpointer user_data) return FALSE; } +/* + After the user has stopped moving the seeking scale, tell the pipeline to seek to the new position. +*/ static gboolean stop_seek (GtkWidget *widget, GdkEventButton *event, gpointer user_data) { gint64 real = gtk_range_get_value (GTK_RANGE (widget)) * duration / 100; gboolean res; GstEvent *s_event; + +/* Seeking on sink pads is possible, but deprecated. Use it only + if there are no sinks in your application or if element seeking is buggy */ #ifdef PAD_SEEK GList *walk = seekable_pads; @@ -722,7 +764,11 @@ stop_seek (GtkWidget *widget, GdkEventButton *event, gpointer user_data) walk = g_list_next (walk); } + #else +/* Element seeking is the preferred way of seeking. + Tell each sink element (in the A/V file, but videosink and audiosink) to seek. + */ GList *walk = seekable_elements; while (walk) { @@ -746,6 +792,7 @@ stop_seek (GtkWidget *widget, GdkEventButton *event, gpointer user_data) return FALSE; } +/* Play button handler */ static void play_cb (GtkButton * button, gpointer data) { @@ -756,6 +803,7 @@ play_cb (GtkButton * button, gpointer data) } } +/* Pause button handler */ static void pause_cb (GtkButton * button, gpointer data) { @@ -765,6 +813,7 @@ pause_cb (GtkButton * button, gpointer data) } } +/* Stop button handler */ static void stop_cb (GtkButton * button, gpointer data) { |