diff options
Diffstat (limited to 'gst/spectrum/demo-osssrc.c')
-rw-r--r-- | gst/spectrum/demo-osssrc.c | 43 |
1 files changed, 30 insertions, 13 deletions
diff --git a/gst/spectrum/demo-osssrc.c b/gst/spectrum/demo-osssrc.c index 6c106b26..d0b07f33 100644 --- a/gst/spectrum/demo-osssrc.c +++ b/gst/spectrum/demo-osssrc.c @@ -28,9 +28,9 @@ #include <gtk/gtk.h> #define DEFAULT_AUDIOSRC "alsasrc" -#define SPECT_BANDS 256 -#define SPECT_WIDTH (SPECT_BANDS) -#define SPECT_HEIGHT 64 +static guint spect_height = 64; +static guint spect_bands = 256; +static gfloat height_scale = 1.0; static GtkWidget *drawingarea = NULL; @@ -41,22 +41,37 @@ on_window_destroy (GtkObject * object, gpointer user_data) gtk_main_quit (); } +gboolean +on_configure_event (GtkWidget * widget, GdkEventConfigure * event, + gpointer user_data) +{ + GstElement *spectrum = GST_ELEMENT (user_data); + + /*GST_INFO ("%d x %d", event->width, event->height); */ + spect_height = event->height; + height_scale = event->height / 64.0; + spect_bands = event->width; + + g_object_set (G_OBJECT (spectrum), "bands", spect_bands, NULL); + return FALSE; +} + /* draw frequency spectrum as a bunch of bars */ static void draw_spectrum (gfloat * data) { gint i; - GdkRectangle rect = { 0, 0, SPECT_WIDTH, SPECT_HEIGHT }; + GdkRectangle rect = { 0, 0, spect_bands, spect_height }; if (!drawingarea) return; gdk_window_begin_paint_rect (drawingarea->window, &rect); gdk_draw_rectangle (drawingarea->window, drawingarea->style->black_gc, - TRUE, 0, 0, SPECT_BANDS, SPECT_HEIGHT); - for (i = 0; i < SPECT_BANDS; i++) { + TRUE, 0, 0, spect_bands, spect_height); + for (i = 0; i < spect_bands; i++) { gdk_draw_rectangle (drawingarea->window, drawingarea->style->white_gc, - TRUE, i, SPECT_HEIGHT - data[i], 1, data[i]); + TRUE, i, spect_height - data[i], 1, data[i]); } gdk_window_end_paint (drawingarea->window); } @@ -70,15 +85,15 @@ message_handler (GstBus * bus, GstMessage * message, gpointer data) const gchar *name = gst_structure_get_name (s); if (strcmp (name, "spectrum") == 0) { - gfloat spect[SPECT_BANDS]; + gfloat spect[spect_bands]; const GValue *list; const GValue *value; guint i; list = gst_structure_get_value (s, "magnitude"); - for (i = 0; i < SPECT_BANDS; ++i) { + for (i = 0; i < spect_bands; ++i) { value = gst_value_list_get_value (list, i); - spect[i] = g_value_get_float (value); + spect[i] = height_scale * g_value_get_float (value); } draw_spectrum (spect); } @@ -102,14 +117,14 @@ main (int argc, char *argv[]) src = gst_element_factory_make (DEFAULT_AUDIOSRC, "src"); spectrum = gst_element_factory_make ("spectrum", "spectrum"); - g_object_set (G_OBJECT (spectrum), "bands", SPECT_BANDS, "threshold", -80, + g_object_set (G_OBJECT (spectrum), "bands", spect_bands, "threshold", -80, "message", TRUE, NULL); sink = gst_element_factory_make ("fakesink", "sink"); gst_bin_add_many (GST_BIN (bin), src, spectrum, sink, NULL); if (!gst_element_link_many (src, spectrum, sink, NULL)) { - fprintf (stderr, "cant link elements\n"); + fprintf (stderr, "can't link elements\n"); exit (1); } @@ -122,7 +137,9 @@ main (int argc, char *argv[]) G_CALLBACK (on_window_destroy), NULL); drawingarea = gtk_drawing_area_new (); - gtk_widget_set_size_request (drawingarea, SPECT_WIDTH, SPECT_HEIGHT); + gtk_widget_set_size_request (drawingarea, spect_bands, spect_height); + g_signal_connect (G_OBJECT (drawingarea), "configure-event", + G_CALLBACK (on_configure_event), (gpointer) spectrum); gtk_container_add (GTK_CONTAINER (appwindow), drawingarea); gtk_widget_show_all (appwindow); |