summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthias Vogelgesang <matthias.vogelgesang@kit.edu>2015-07-20 15:02:39 +0200
committerMatthias Vogelgesang <matthias.vogelgesang@kit.edu>2015-07-20 15:02:39 +0200
commit44d3b1dbc6e7b7d957029802563e8c6f86076ad8 (patch)
treeb87f9e06eef5fa91b7ae13ae0d7c7b810c50aa2b
parentfee073b676044d454220616fb99bca6586a21f19 (diff)
downloaduca-44d3b1dbc6e7b7d957029802563e8c6f86076ad8.tar.gz
uca-44d3b1dbc6e7b7d957029802563e8c6f86076ad8.tar.bz2
uca-44d3b1dbc6e7b7d957029802563e8c6f86076ad8.tar.xz
uca-44d3b1dbc6e7b7d957029802563e8c6f86076ad8.zip
Refactor position display
Use single function to determine position and value. Also we now avoid string allocation and use a static string for the printing.
-rw-r--r--bin/gui/control.c122
1 files changed, 48 insertions, 74 deletions
diff --git a/bin/gui/control.c b/bin/gui/control.c
index 0b13ac1..1e67265 100644
--- a/bin/gui/control.c
+++ b/bin/gui/control.c
@@ -356,6 +356,33 @@ get_statistics (ThreadData *data, gdouble *mean, gdouble *sigma, guint *_max, gu
}
static void
+update_sidebar (ThreadData *data, gpointer buffer)
+{
+ gchar string[32];
+
+ gint i = (data->display_y / data->zoom_factor) * data->width + data->display_x / data->zoom_factor;
+
+ if (data->pixel_size == 1) {
+ guint8 *input = (guint8 *) buffer;
+ guint8 val = input[i];
+ g_snprintf (string, 32, "val = %i", val);
+ gtk_label_set_text (data->val_label, string);
+ }
+ else if (data->pixel_size == 2) {
+ guint16 *input = (guint16 *) buffer;
+ guint16 val = input[i];
+ g_snprintf (string, 32, "val = %i", val);
+ gtk_label_set_text (data->val_label, string);
+ }
+
+ g_snprintf (string, 32, "x = %i", data->display_x);
+ gtk_label_set_text (data->x_label, string);
+
+ g_snprintf (string, 32, "y = %i", data->display_y);
+ gtk_label_set_text (data->y_label, string);
+}
+
+static void
on_motion_notify (GtkWidget *event_box, GdkEventMotion *event, ThreadData *data)
{
gint page_width = gtk_adjustment_get_page_size(GTK_ADJUSTMENT(data->hadjustment));
@@ -405,34 +432,9 @@ on_motion_notify (GtkWidget *event_box, GdkEventMotion *event, ThreadData *data)
}
if ((data->state != RUNNING) || ((data->ev_x >= 0 && data->ev_y >= 0) && (data->ev_y <= data->display_height && data->ev_x <= data->display_width))) {
- gpointer *buffer;
- GString *string;
-
- buffer = uca_ring_buffer_peek_pointer (data->buffer);
- string = g_string_new_len (NULL, 32);
- gint i = (data->display_y / data->zoom_factor) * data->width + data->display_x / data->zoom_factor;
-
- if (data->pixel_size == 1) {
- guint8 *input = (guint8 *) buffer;
- guint8 val = input[i];
- g_string_printf (string, "val = %i", val);
- gtk_label_set_text (data->val_label, string->str);
- }
- else if (data->pixel_size == 2) {
- guint16 *input = (guint16 *) buffer;
- guint16 val = input[i];
- g_string_printf (string, "val = %i", val);
- gtk_label_set_text (data->val_label, string->str);
- }
-
- g_string_printf (string, "x = %i", data->display_x);
- gtk_label_set_text (data->x_label, string->str);
-
- g_string_printf (string, "y = %i", data->display_y);
- gtk_label_set_text (data->y_label, string->str);
-
- g_string_free (string, TRUE);
+ update_sidebar (data, uca_ring_buffer_peek_pointer (data->buffer));
}
+
if (data->cr != NULL) {
gdouble dash = 5.0;
cairo_set_source_rgb (data->cr, data->red, data->green, data->blue);
@@ -539,7 +541,7 @@ on_expose (GtkWidget *event_box, GdkEventExpose *event, ThreadData *data)
static void
update_pixbuf (ThreadData *data)
{
- GString *string;
+ gchar string[32];
gdouble mean;
gdouble sigma;
guint min;
@@ -573,33 +575,30 @@ update_pixbuf (ThreadData *data)
}
get_statistics (data, &mean, &sigma, &max, &min);
- string = g_string_new_len (NULL, 32);
- g_string_printf (string, "\u03bc = %3.2f", mean);
- gtk_label_set_text (data->mean_label, string->str);
+ g_snprintf (string, 32, "\u03bc = %3.2f", mean);
+ gtk_label_set_text (data->mean_label, string);
- g_string_printf (string, "\u03c3 = %3.2f", sigma);
- gtk_label_set_text (data->sigma_label, string->str);
+ g_snprintf (string, 32, "\u03c3 = %3.2f", sigma);
+ gtk_label_set_text (data->sigma_label, string);
- g_string_printf (string, "min = %i", min);
- gtk_label_set_text (data->min_label, string->str);
+ g_snprintf (string, 32, "min = %i", min);
+ gtk_label_set_text (data->min_label, string);
- g_string_printf (string, "max = %i", max);
- gtk_label_set_text (data->max_label, string->str);
+ g_snprintf (string, 32, "max = %i", max);
+ gtk_label_set_text (data->max_label, string);
- g_string_printf (string, "x = %i", x);
- gtk_label_set_text (data->roix_label, string->str);
+ g_snprintf (string, 32, "x = %i", x);
+ gtk_label_set_text (data->roix_label, string);
- g_string_printf (string, "y = %i", y);
- gtk_label_set_text (data->roiy_label, string->str);
+ g_snprintf (string, 32, "y = %i", y);
+ gtk_label_set_text (data->roiy_label, string);
- g_string_printf (string, "width = %i", width);
- gtk_label_set_text (data->roiw_label, string->str);
+ g_snprintf (string, 32, "width = %i", width);
+ gtk_label_set_text (data->roiw_label, string);
- g_string_printf (string, "height = %i", height);
- gtk_label_set_text (data->roih_label, string->str);
-
- g_string_free (string, TRUE);
+ g_snprintf (string, 32, "height = %i", height);
+ gtk_label_set_text (data->roih_label, string);
if (gtk_toggle_button_get_active (data->histogram_button))
gtk_widget_queue_draw (data->histogram_view);
@@ -712,36 +711,11 @@ preview_frames (void *args)
update_pixbuf (data);
egg_histogram_view_update (EGG_HISTOGRAM_VIEW (data->histogram_view), data->shadow);
- if ((data->ev_x >= 0) && (data->ev_y >= 0) &&
- (data->ev_y <= data->display_height) && (data->ev_x <= data->display_width)) {
- GString *string;
- string = g_string_new_len (NULL, 32);
- gint i = (data->display_y / data->zoom_factor) * data->width + data->display_x / data->zoom_factor;
-
- if (data->pixel_size == 1) {
- guint8 *input = (guint8 *) data->shadow;
- guint8 val = input[i];
- g_string_printf (string, "val = %i", val);
- gtk_label_set_text (data->val_label, string->str);
- }
- else if (data->pixel_size == 2) {
- guint16 *input = (guint16 *) data->shadow;
- guint16 val = input[i];
- g_string_printf (string, "val = %i", val);
- gtk_label_set_text (data->val_label, string->str);
- }
-
- g_string_printf (string, "x = %i", data->display_x);
- gtk_label_set_text (data->x_label, string->str);
-
- g_string_printf (string, "y = %i", data->display_y);
- gtk_label_set_text (data->y_label, string->str);
-
- g_string_free (string, TRUE);
+ if ((data->ev_x >= 0) && (data->ev_y >= 0) && (data->ev_y <= data->display_height) && (data->ev_x <= data->display_width)) {
+ update_sidebar (data, data->shadow);
}
gdk_threads_leave ();
-
counter++;
}