Remove all references to xvideosink, fix examples (#140845).
authorRonald S. Bultje <rbultje@ronald.bitfreak.net>
Sun, 9 Jan 2005 14:53:58 +0000 (14:53 +0000)
committerRonald S. Bultje <rbultje@ronald.bitfreak.net>
Sun, 9 Jan 2005 14:53:58 +0000 (14:53 +0000)
Original commit message from CVS:
* configure.ac:
* examples/capsfilter/capsfilter1.c: (main):
* examples/seeking/spider_seek.c: (make_spider_pipeline):
* ext/dvdread/Makefile.am:
* ext/dvdread/demo-play:
* ext/dvdread/demo-play.c:
* gconf/gstreamer.schemas.in:
* gst-libs/gst/gconf/gconf.c:
* sys/v4l/TODO:
* testsuite/Makefile.am:
* testsuite/embed/Makefile.am:
* testsuite/embed/embed.c: (cb_expose), (main):
Remove all references to xvideosink, fix examples (#140845).
* gst/playback/gstplaybasebin.c: (group_destroy):
Apparently, disposal does not unlink - so do explicitely.
* ext/alsa/gstalsasink.c: (gst_alsa_sink_check_event):
Add debug.

ChangeLog
configure.ac
examples/capsfilter/capsfilter1.c
examples/seeking/spider_seek.c
ext/dvdread/Makefile.am
ext/dvdread/demo-play [new file with mode: 0755]
ext/dvdread/demo-play.c [deleted file]
gst-libs/gst/gconf/gconf.c

index 6aa1226..c19c877 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,23 @@
+2005-01-09  Ronald S. Bultje  <rbultje@ronald.bitfreak.net>
+
+       * configure.ac:
+       * examples/capsfilter/capsfilter1.c: (main):
+       * examples/seeking/spider_seek.c: (make_spider_pipeline):
+       * ext/dvdread/Makefile.am:
+       * ext/dvdread/demo-play:
+       * ext/dvdread/demo-play.c:
+       * gconf/gstreamer.schemas.in:
+       * gst-libs/gst/gconf/gconf.c:
+       * sys/v4l/TODO:
+       * testsuite/Makefile.am:
+       * testsuite/embed/Makefile.am:
+       * testsuite/embed/embed.c: (cb_expose), (main):
+         Remove all references to xvideosink, fix examples (#140845).
+       * gst/playback/gstplaybasebin.c: (group_destroy):
+         Apparently, disposal does not unlink - so do explicitely.
+       * ext/alsa/gstalsasink.c: (gst_alsa_sink_check_event):
+         Add debug.
+
 2005-01-09  Maciej Katafiasz <mathrick@freedesktop.org>
 
        * README: fix PKG_CONFIG_PATH instructions, what was there
index f712416..73333ff 100644 (file)
@@ -2104,6 +2104,7 @@ examples/indexing/Makefile
 examples/gstplay/Makefile
 examples/switch/Makefile
 examples/Makefile
+testsuite/embed/Makefile
 testsuite/spider/Makefile
 testsuite/alsa/Makefile
 testsuite/multifilesink/Makefile
index 5948d60..617b89d 100644 (file)
@@ -1,3 +1,4 @@
+#include <string.h>
 #include <gst/gst.h>
 
 /* This app uses a filter to connect colorspace and videosink
@@ -28,7 +29,7 @@ main (gint argc, gchar * argv[])
   GstElement *queue;
   GstElement *mpeg2dec;
   GstElement *colorspace;
-  GstElement *xvideosink;
+  GstElement *videosink;
   gboolean res;
 
   gst_init (&argc, &argv);
@@ -51,11 +52,10 @@ main (gint argc, gchar * argv[])
   queue = gst_element_factory_make ("queue", "queue");
   mpeg2dec = gst_element_factory_make ("mpeg2dec", "mpeg2dec");
   g_return_val_if_fail (mpeg2dec, -1);
-  colorspace = gst_element_factory_make ("colorspace", "colorspace");
+  colorspace = gst_element_factory_make ("ffmpegcolorspace", "colorspace");
   g_return_val_if_fail (colorspace, -1);
-  xvideosink = gst_element_factory_make ("xvideosink", "xvideosink");
-  g_return_val_if_fail (xvideosink, -1);
-  g_object_set (G_OBJECT (xvideosink), "toplevel", TRUE, NULL);
+  videosink = gst_element_factory_make ("ximagesink", "videosink");
+  g_return_val_if_fail (videosink, -1);
 
   gst_bin_add (GST_BIN (pipeline), filesrc);
   gst_bin_add (GST_BIN (pipeline), demux);
@@ -63,19 +63,17 @@ main (gint argc, gchar * argv[])
   gst_bin_add (GST_BIN (thread), queue);
   gst_bin_add (GST_BIN (thread), mpeg2dec);
   gst_bin_add (GST_BIN (thread), colorspace);
-  gst_bin_add (GST_BIN (thread), xvideosink);
+  gst_bin_add (GST_BIN (thread), videosink);
   gst_bin_add (GST_BIN (pipeline), thread);
 
-  gst_element_link (filesrc, "src", demux, "sink");
-  gst_element_link (queue, "src", mpeg2dec, "sink");
-  gst_element_link (mpeg2dec, "src", colorspace, "sink");
-  /* force RGB data passing between colorspace and xvideosink */
-  res = gst_element_link_filtered (colorspace, "src", xvideosink, "sink",
-      GST_CAPS_NEW ("filtercaps",
-          "video/raw", "format", GST_PROPS_FOURCC (GST_STR_FOURCC ("RGB "))
-      ));
+  gst_element_link_pads (filesrc, "src", demux, "sink");
+  gst_element_link_pads (queue, "src", mpeg2dec, "sink");
+  gst_element_link_pads (mpeg2dec, "src", colorspace, "sink");
+  /* force RGB data passing between colorspace and videosink */
+  res = gst_element_link_pads_filtered (colorspace, "src", videosink, "sink",
+      gst_caps_new_simple ("video/x-raw-rgb", NULL));
   if (!res) {
-    g_print ("could not connect colorspace and xvideosink\n");
+    g_print ("could not connect colorspace and videosink\n");
     return -1;
   }
 
index 54c1089..46197c0 100644 (file)
@@ -42,7 +42,7 @@ make_spider_pipeline (const gchar * location, gboolean thread)
 
   v_thread = gst_thread_new ("v_thread");
   v_queue = gst_element_factory_make ("queue", "v_queue");
-  videosink = gst_element_factory_make ("xvideosink", "v_sink");
+  videosink = gst_element_factory_make ("xvimagesink", "v_sink");
   //g_object_set (G_OBJECT (audiosink), "sync", FALSE, NULL);
 
   g_object_set (G_OBJECT (src), "location", location, NULL);
index de0b926..5197231 100644 (file)
@@ -11,12 +11,6 @@ libgstdvdreadsrc_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS)
 
 noinst_HEADERS = dvdreadsrc.h
 
-# fix this
-
-#noinst_PROGRAMS = demo-play
-#
-#demo_play_SOURCES = demo-play.c
-#demo_play_CFLAGS  = $(GST_CFLAGS) $(GNOME_CFLAGS)
-#demo_play_LDFLAGS = $(GST_LIBS) $(GNOME_LIBS)
-
-EXTRA_DIST = demo-play.c README
+EXTRA_DIST = \
+       README \
+       demo-play
diff --git a/ext/dvdread/demo-play b/ext/dvdread/demo-play
new file mode 100755 (executable)
index 0000000..1def730
--- /dev/null
@@ -0,0 +1,6 @@
+#!/bin/sh
+AUDIOSINK=`gconftool-2 -g /system/gstreamer/0.8/default/audiosink`
+VIDEOSINK=`gconftool-2 -g /system/gstreamer/0.8/default/videosink`
+gst-launch dvdreadsrc ! dvddemux name=demux .video_00 ! \
+       { queue ! mpeg2dec ! ffmpegcolorspace ! videoscale ! $VIDEOSINK } \
+       { demux.audio_00 ! queue ! a52dec ! audioconvert ! audioscale ! $AUDIOSINK }
diff --git a/ext/dvdread/demo-play.c b/ext/dvdread/demo-play.c
deleted file mode 100644 (file)
index 2822255..0000000
+++ /dev/null
@@ -1,158 +0,0 @@
-#include <gnome.h>
-#include <gst/gst.h>
-
-GstPipeline *pipeline;
-GstElement *v_queue, *a_queue, *v_thread, *a_thread;
-GtkWidget *appwindow;
-GtkWidget *gtk_socket;
-
-void
-eof (GstElement * src)
-{
-  g_print ("have eos, quitting\n");
-  exit (0);
-}
-
-gboolean
-idle_func (gpointer data)
-{
-  gst_bin_iterate (GST_BIN (data));
-  return TRUE;
-}
-
-void
-mpeg2parse_newpad (GstElement * parser, GstPad * pad, GstElement * pipeline)
-{
-
-  g_print ("***** a new pad %s was created\n", gst_pad_get_name (pad));
-
-  if (strncmp (gst_pad_get_name (pad), "video_", 6) == 0) {
-    gst_pad_link (pad, gst_element_get_pad (v_queue, "sink"));
-    gst_bin_add (GST_BIN (pipeline), v_thread);
-    gst_element_set_state (v_thread, GST_STATE_PLAYING);
-  } else if (strcmp (gst_pad_get_name (pad), "private_stream_1.0") == 0) {
-    gst_pad_link (pad, gst_element_get_pad (a_queue, "sink"));
-    gst_bin_add (GST_BIN (pipeline), a_thread);
-    gst_element_set_state (a_thread, GST_STATE_PLAYING);
-  }
-}
-
-void
-mpeg2parse_have_size (GstElement * videosink, gint width, gint height)
-{
-  gtk_widget_set_usize (gtk_socket, width, height);
-  gtk_widget_show_all (appwindow);
-}
-
-int
-main (int argc, char *argv[])
-{
-  GstElement *src, *parse;
-  GstElement *v_decode, *show, *color;
-  GstElement *a_decode, *osssink;
-
-  if (argc < 5) {
-    g_print ("usage: %s dvdlocation title chapter angle\n", argv[0]);
-    exit (1);
-  }
-
-  gst_init (&argc, &argv);
-  gnome_init ("MPEG2 Video player", "0.0.1", argc, argv);
-
-  /* ***** construct the main pipeline ***** */
-  pipeline = GST_PIPELINE (gst_pipeline_new ("pipeline"));
-  g_return_val_if_fail (pipeline != NULL, -1);
-
-  src = gst_element_factory_make ("dvdreadsrc", "src");
-  g_return_val_if_fail (src != NULL, -1);
-  gtk_object_set (GTK_OBJECT (src), "location", argv[1], NULL);
-  gtk_object_set (GTK_OBJECT (src), "title", atoi (argv[2]), NULL);
-  gtk_object_set (GTK_OBJECT (src), "chapter", atoi (argv[3]), NULL);
-  gtk_object_set (GTK_OBJECT (src), "angle", atoi (argv[4]), NULL);
-
-  parse = gst_element_factory_make ("mpeg2parse", "parse");
-  /*parse = gst_element_factory_make("mpeg1parse","parse"); */
-  g_return_val_if_fail (parse != NULL, -1);
-
-  gst_bin_add (GST_BIN (pipeline), GST_ELEMENT (src));
-  gst_bin_add (GST_BIN (pipeline), GST_ELEMENT (parse));
-
-  gst_element_link (src, "src", parse, "sink");
-
-
-  /* ***** pre-construct the video thread ***** */
-  v_thread = GST_ELEMENT (gst_thread_new ("v_thread"));
-  g_return_val_if_fail (v_thread != NULL, -1);
-
-  v_queue = gst_element_factory_make ("queue", "v_queue");
-  g_return_val_if_fail (v_queue != NULL, -1);
-
-  v_decode = gst_element_factory_make ("mpeg2dec", "decode_video");
-  g_return_val_if_fail (v_decode != NULL, -1);
-
-  color = gst_element_factory_make ("colorspace", "color");
-  g_return_val_if_fail (color != NULL, -1);
-
-  show = gst_element_factory_make ("xvideosink", "show");
-  g_return_val_if_fail (show != NULL, -1);
-
-  gst_bin_add (GST_BIN (v_thread), GST_ELEMENT (v_queue));
-  gst_bin_add (GST_BIN (v_thread), GST_ELEMENT (v_decode));
-  gst_bin_add (GST_BIN (v_thread), GST_ELEMENT (color));
-  gst_bin_add (GST_BIN (v_thread), GST_ELEMENT (show));
-
-  gst_element_link (v_queue, "src", v_decode, "sink");
-  gst_element_link (v_decode, "src", color, "sink");
-  gst_element_link (color, "src", show, "sink");
-
-
-  /* ***** pre-construct the audio thread ***** */
-  a_thread = GST_ELEMENT (gst_thread_new ("a_thread"));
-  g_return_val_if_fail (a_thread != NULL, -1);
-
-  a_queue = gst_element_factory_make ("queue", "a_queue");
-  g_return_val_if_fail (a_queue != NULL, -1);
-
-  a_decode = gst_element_factory_make ("a52dec", "decode_audio");
-  g_return_val_if_fail (a_decode != NULL, -1);
-
-  osssink = gst_element_factory_make ("osssink", "osssink");
-  g_return_val_if_fail (osssink != NULL, -1);
-
-  gst_bin_add (GST_BIN (a_thread), GST_ELEMENT (a_queue));
-  gst_bin_add (GST_BIN (a_thread), GST_ELEMENT (a_decode));
-  gst_bin_add (GST_BIN (a_thread), GST_ELEMENT (osssink));
-
-  gst_element_link (a_queue, "src", a_decode, "sink");
-  gst_element_link (a_decode, "src", osssink, "sink");
-
-
-  /* ***** construct the GUI ***** */
-  appwindow = gnome_app_new ("DVD Player", "DVD Player");
-
-  gtk_socket = gtk_socket_new ();
-  gtk_widget_show (gtk_socket);
-
-  gnome_app_set_contents (GNOME_APP (appwindow), GTK_WIDGET (gtk_socket));
-
-  gtk_widget_realize (gtk_socket);
-  gtk_socket_steal (GTK_SOCKET (gtk_socket),
-      gst_util_get_int_arg (GTK_OBJECT (show), "xid"));
-
-  gtk_signal_connect (GTK_OBJECT (parse), "new_pad", mpeg2parse_newpad,
-      pipeline);
-  gtk_signal_connect (GTK_OBJECT (src), "eos", GTK_SIGNAL_FUNC (eof), NULL);
-  gtk_signal_connect (GTK_OBJECT (show), "have_size", mpeg2parse_have_size,
-      pipeline);
-
-  g_print ("setting to PLAYING state\n");
-  gst_element_set_state (GST_ELEMENT (pipeline), GST_STATE_PLAYING);
-
-  gtk_idle_add (idle_func, pipeline);
-
-  gdk_threads_enter ();
-  gtk_main ();
-  gdk_threads_leave ();
-
-  return 0;
-}
index 00b35a2..e89dc3a 100644 (file)
@@ -217,7 +217,7 @@ gst_gconf_get_default_audio_sink (void)
  * gst_gconf_get_default_video_sink:
  *
  * Render video output bin from GStreamer GConf key : "default/videosink".
- * If key is invalid xvideosink is used as default output plugin.
+ * If key is invalid ximagesink is used as default output plugin.
  *
  * Returns: a #GstElement containing the video output bin, or NULL if
  * everything failed.