summaryrefslogtreecommitdiffstats
path: root/gst/playondemand
diff options
context:
space:
mode:
Diffstat (limited to 'gst/playondemand')
-rw-r--r--gst/playondemand/Makefile.am9
-rw-r--r--gst/playondemand/demo-mp3.c86
2 files changed, 94 insertions, 1 deletions
diff --git a/gst/playondemand/Makefile.am b/gst/playondemand/Makefile.am
index fc2b93b9..4a96570a 100644
--- a/gst/playondemand/Makefile.am
+++ b/gst/playondemand/Makefile.am
@@ -7,4 +7,11 @@ libgstplayondemand_la_CFLAGS = $(GST_CFLAGS)
noinst_HEADERS = gstplayondemand.h filter.func
-# EXTRA_DIST = README
+if HAVE_GTK
+noinst_PROGRAMS = demo-mp3
+endif
+
+demo_mp3_SOURCES = demo-mp3.c
+demo_mp3_CFLAGS = $(GST_CFLAGS) $(GTK_CFLAGS)
+demo_mp3_LDFLAGS = $(GST_LIBS) $(GTK_LIBS)
+
diff --git a/gst/playondemand/demo-mp3.c b/gst/playondemand/demo-mp3.c
new file mode 100644
index 00000000..0cfb3397
--- /dev/null
+++ b/gst/playondemand/demo-mp3.c
@@ -0,0 +1,86 @@
+#include <gtk/gtk.h>
+#include <gst/gst.h>
+
+void play (GtkButton *button, gpointer data)
+{
+ gtk_signal_emit_by_name(GTK_OBJECT(data), "play");
+}
+
+void reset (GtkButton *button, gpointer data)
+{
+ gtk_signal_emit_by_name(GTK_OBJECT(data), "reset");
+}
+
+int main(int argc, char **argv)
+{
+ guint channels;
+ GtkWidget *window, *vbox, *play_button, *reset_button, *quit_button;
+ GstElement *filesrc, *mad, *stereo2mono, *pod, *osssink, *pipeline;
+
+ gst_init (&argc, &argv);
+ gtk_init (&argc, &argv);
+
+ if (argc!=2) {
+ g_print("usage: %s <mp3-filename>\n", argv[0]);
+ exit(-1);
+ }
+
+ filesrc = gst_elementfactory_make("filesrc", "filesrc");
+ mad = gst_elementfactory_make("mad", "mad");
+ pod = gst_elementfactory_make("playondemand", "playondemand");
+ osssink = gst_elementfactory_make("osssink", "osssink");
+
+ gtk_object_set(GTK_OBJECT(filesrc), "location", argv[1], NULL);
+ gtk_object_set(GTK_OBJECT(osssink), "fragment", 0x00180008, NULL);
+ gtk_object_get(GTK_OBJECT(osssink), "channels", &channels, NULL);
+
+ pipeline = gst_pipeline_new("app");
+
+ gst_bin_add(GST_BIN(pipeline), filesrc);
+ gst_bin_add(GST_BIN(pipeline), mad);
+ gst_bin_add(GST_BIN(pipeline), pod);
+ gst_bin_add(GST_BIN(pipeline), osssink);
+
+ gst_element_connect(filesrc, "src", mad, "sink");
+ gst_element_connect(pod, "src", osssink, "sink");
+
+ if (channels != 2) {
+ gst_element_connect(mad, "src", pod, "sink");
+ } else {
+ stereo2mono = gst_elementfactory_make("stereo2mono", "stereo2mono");
+ gst_bin_add(GST_BIN(pipeline), stereo2mono);
+ gst_element_connect(mad, "src", stereo2mono, "sink");
+ gst_element_connect(stereo2mono, "src", pod, "sink");
+ }
+
+ gst_element_set_state(pipeline, GST_STATE_PLAYING);
+
+ /* initialize gui elements ... */
+ window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
+ vbox = gtk_vbox_new(FALSE, 0);
+ play_button = gtk_button_new_with_label("play");
+ reset_button = gtk_button_new_with_label("reset");
+ quit_button = gtk_button_new_with_label("quit");
+
+ /* do the packing stuff ... */
+ gtk_window_set_default_size(GTK_WINDOW(window), 96, 96);
+ gtk_container_add(GTK_CONTAINER(window), vbox);
+ gtk_box_pack_start(GTK_BOX(vbox), play_button, FALSE, FALSE, 2);
+ gtk_box_pack_start(GTK_BOX(vbox), reset_button, FALSE, FALSE, 2);
+ gtk_box_pack_start(GTK_BOX(vbox), quit_button, FALSE, FALSE, 2);
+
+ /* connect things ... */
+ gtk_signal_connect(GTK_OBJECT(play_button), "clicked", play, pod);
+ gtk_signal_connect(GTK_OBJECT(reset_button), "clicked", reset, pod);
+ gtk_signal_connect(GTK_OBJECT(quit_button), "clicked", gtk_main_quit, NULL);
+
+ /* show the gui. */
+ gtk_widget_show(play_button);
+ gtk_widget_show(reset_button);
+ gtk_widget_show(quit_button);
+ gtk_widget_show(vbox);
+ gtk_widget_show(window);
+ gtk_idle_add((GtkFunction)gst_bin_iterate, pipeline);
+
+ gtk_main();
+}