diff options
author | Thomas White <taw@physics.org> | 2011-03-08 11:37:29 +0100 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2012-02-22 15:27:18 +0100 |
commit | d978bbf02ade72c8b46728d1492bf2956e9b9d95 (patch) | |
tree | 7aa8e1e98b9c0163543c7a18b3d76881b99b778c | |
parent | 2f7c2c76ad91162b753ba5e4bca2216bb16fd383 (diff) |
hdfsee: Multiple improvements
-rw-r--r-- | src/dw-hdfsee.c | 48 |
1 files changed, 36 insertions, 12 deletions
diff --git a/src/dw-hdfsee.c b/src/dw-hdfsee.c index 08e3996d..051f133d 100644 --- a/src/dw-hdfsee.c +++ b/src/dw-hdfsee.c @@ -263,16 +263,20 @@ static int draw_stuff(cairo_surface_t *surf, DisplayWindow *dw) static void redraw_window(DisplayWindow *dw) { + int width; + + width = dw->width; + if ( dw->show_col_scale ) width += 20; if ( dw->surf != NULL ) cairo_surface_destroy(dw->surf); dw->surf = cairo_image_surface_create(CAIRO_FORMAT_ARGB32, - dw->width, dw->height); + width, dw->height); draw_stuff(dw->surf, dw); gdk_window_invalidate_rect(dw->drawingarea->window, NULL, FALSE); } -static void displaywindow_update(DisplayWindow *dw) +static void set_window_size(DisplayWindow *dw) { gint width; GdkGeometry geom; @@ -316,6 +320,22 @@ static void displaywindow_update(DisplayWindow *dw) gtk_window_set_geometry_hints(GTK_WINDOW(dw->window), GTK_WIDGET(dw->drawingarea), &geom, GDK_HINT_MIN_SIZE | GDK_HINT_MAX_SIZE); +} + + +static void update_colscale(DisplayWindow *dw) +{ + if ( dw->col_scale != NULL ) { + gdk_pixbuf_unref(dw->col_scale); + } + dw->col_scale = render_get_colour_scale(20, dw->height, dw->scale); +} + + +static void displaywindow_update(DisplayWindow *dw) +{ + set_window_size(dw); + update_colscale(dw); /* Free old pixbufs */ if ( dw->pixbufs != NULL ) { @@ -325,9 +345,6 @@ static void displaywindow_update(DisplayWindow *dw) } free(dw->pixbufs); } - if ( dw->col_scale != NULL ) { - gdk_pixbuf_unref(dw->col_scale); - } if ( dw->image != NULL ) { dw->pixbufs = render_panels(dw->image, dw->binning, @@ -337,8 +354,6 @@ static void displaywindow_update(DisplayWindow *dw) dw->pixbufs = NULL; } - dw->col_scale = render_get_colour_scale(20, dw->height, dw->scale); - redraw_window(dw); } @@ -692,10 +707,10 @@ static gint displaywindow_peaklist_response(GtkWidget *d, gint response, load_features_from_file(dw->image, filename); dw->show_peaks = 1; w = gtk_ui_manager_get_widget(dw->ui, - "/ui/displaywindow/view/showpeaks"); + "/ui/displaywindow/view/showpeaks"); gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(w), TRUE); - displaywindow_update(dw); + redraw_window(dw); g_free(filename); @@ -973,7 +988,8 @@ static gint displaywindow_save(GtkWidget *widget, DisplayWindow *dw) static gint displaywindow_set_colscale(GtkWidget *widget, DisplayWindow *dw) { dw->show_col_scale = 1 - dw->show_col_scale; - displaywindow_update(dw); + set_window_size(dw); + redraw_window(dw); return 0; } @@ -1166,7 +1182,8 @@ static gint displaywindow_setscale(GtkWidget *widget, GtkRadioAction *action, case 1 : dw->scale = SCALE_MONO; break; case 2 : dw->scale = SCALE_INVMONO; break; } - displaywindow_update(dw); + update_colscale(dw); + redraw_window(dw); return 0; } @@ -1266,13 +1283,19 @@ static int geometry_fits(struct image *image, struct detector *geom) struct newhdf { DisplayWindow *dw; + GtkWidget *widget; char name[1024]; }; static gint displaywindow_newhdf(GtkMenuItem *item, struct newhdf *nh) { + gboolean a; + if ( nh->dw->not_ready_yet ) return 0; + a = gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(nh->widget)); + if ( !a ) return 0; + hdfile_set_image(nh->dw->hdfile, nh->name); hdf5_read(nh->dw->hdfile, nh->dw->image, 0); @@ -1362,7 +1385,8 @@ static GtkWidget *displaywindow_addhdfgroup(struct hdfile *hdfile, if ( nh != NULL ) { strncpy(nh->name, names[i], 1023); nh->dw = dw; - g_signal_connect(G_OBJECT(item), "activate", + nh->widget = item; + g_signal_connect(G_OBJECT(item), "toggled", G_CALLBACK(displaywindow_newhdf), nh); } |