cairooverlay: The example always requires gtk-x11

Check for gtk-x11 and only build the example if it's available.
This commit is contained in:
Sebastian Dröge 2011-03-02 23:21:15 +01:00
parent fdbdbfefd2
commit 08232b470e
4 changed files with 14 additions and 10 deletions

View file

@ -258,10 +258,13 @@ if test "x$BUILD_EXAMPLES" = "xyes"; then
GTK_REQ=$GTK2_REQ]) GTK_REQ=$GTK2_REQ])
AC_MSG_RESULT([$with_gtk (>= $GTK_REQ)]) AC_MSG_RESULT([$with_gtk (>= $GTK_REQ)])
PKG_CHECK_MODULES(GTK, gtk+-$with_gtk >= $GTK_REQ, HAVE_GTK=yes, HAVE_GTK=no) PKG_CHECK_MODULES(GTK, gtk+-$with_gtk >= $GTK_REQ, HAVE_GTK=yes, HAVE_GTK=no)
dnl some examples need gtk+-x11
PKG_CHECK_MODULES(GTK_X11, gtk+-x11-$with_gtk >= $GTK_REQ, HAVE_GTK_X11=yes, HAVE_GTK_X11=no)
AC_SUBST(GTK_LIBS) AC_SUBST(GTK_LIBS)
AC_SUBST(GTK_CFLAGS) AC_SUBST(GTK_CFLAGS)
fi fi
AM_CONDITIONAL(HAVE_GTK, test "x$HAVE_GTK" = "xyes") AM_CONDITIONAL(HAVE_GTK, test "x$HAVE_GTK" = "xyes")
AM_CONDITIONAL(HAVE_GTK_X11, test "x$HAVE_GTK_X11" = "xyes")
dnl should we install schemas ? dnl should we install schemas ?
translit(dnm, m, l) AM_CONDITIONAL(USE_GCONFTOOL, true) translit(dnm, m, l) AM_CONDITIONAL(USE_GCONFTOOL, true)

View file

@ -4,11 +4,15 @@ else
JACK_DIR= JACK_DIR=
endif endif
if USE_CAIRO if USE_CAIRO_GOBJECT
if HAVE_GTK_X11
CAIRO_DIR=cairo CAIRO_DIR=cairo
else else
CAIRO_DIR= CAIRO_DIR=
endif endif
else
CAIRO_DIR=
endif
SUBDIRS = audiofx equalizer $(JACK_DIR) level pulse \ SUBDIRS = audiofx equalizer $(JACK_DIR) level pulse \
rtp shapewipe spectrum v4l2 $(CAIRO_DIR) rtp shapewipe spectrum v4l2 $(CAIRO_DIR)

View file

@ -1,11 +1,12 @@
if USE_CAIRO_GOBJECT if USE_CAIRO_GOBJECT
if HAVE_GTK if HAVE_GTK_X11
noinst_PROGRAMS = cairo_overlay noinst_PROGRAMS = cairo_overlay
endif endif
endif endif
cairo_overlay_SOURCES = cairo_overlay.c cairo_overlay_SOURCES = cairo_overlay.c
cairo_overlay_CFLAGS = $(GST_CFLAGS) $(GTK_CFLAGS) $(CAIRO_CFLAGS) cairo_overlay_CFLAGS = $(GST_PLUGINS_BASE_CFLAGS) $(GST_CFLAGS) \
$(GTK_CFLAGS) $(CAIRO_CFLAGS)
cairo_overlay_LDFLAGS = \ cairo_overlay_LDFLAGS = \
$(GST_LIBS) -lgstinterfaces-0.10 -lgstvideo-$(GST_MAJORMINOR) \ $(GST_LIBS) -lgstinterfaces-0.10 -lgstvideo-$(GST_MAJORMINOR) \
$(GTK_LIBS) $(CAIRO_LIBS) $(GTK_LIBS) $(CAIRO_LIBS)

View file

@ -25,18 +25,16 @@
* roughly based on gst_x_overlay documentation. * roughly based on gst_x_overlay documentation.
*/ */
#include <gst/gst.h> #include <gst/gst.h>
#include <gst/video/video.h> #include <gst/video/video.h>
#include <gst/interfaces/xoverlay.h> #include <gst/interfaces/xoverlay.h>
#include <gtk/gtk.h>
#include <cairo.h> #include <cairo.h>
#include <cairo-gobject.h> #include <cairo-gobject.h>
#ifdef GDK_WINDOWING_X11
#include <gdk/gdkx.h> #include <gdk/gdkx.h>
#endif
#include <gtk/gtk.h>
static gulong video_window_xid = 0; static gulong video_window_xid = 0;
@ -64,9 +62,7 @@ bus_sync_handler (GstBus * bus, GstMessage * message, gpointer user_data)
static void static void
video_widget_realize_cb (GtkWidget * widget, gpointer data) video_widget_realize_cb (GtkWidget * widget, gpointer data)
{ {
#ifdef GDK_WINDOWING_X11
video_window_xid = GDK_WINDOW_XID (widget->window); video_window_xid = GDK_WINDOW_XID (widget->window);
#endif
} }
static GtkWidget * static GtkWidget *
@ -187,7 +183,7 @@ main (int argc, char **argv)
gst_init (&argc, &argv); gst_init (&argc, &argv);
window = setup_gtk_window (); window = setup_gtk_window ();
overlay_state = g_new (CairoOverlayState, 1); overlay_state = g_new0 (CairoOverlayState, 1);
pipeline = setup_gst_pipeline (overlay_state); pipeline = setup_gst_pipeline (overlay_state);
gst_element_set_state (pipeline, GST_STATE_PLAYING); gst_element_set_state (pipeline, GST_STATE_PLAYING);