diff options
-rw-r--r-- | src/dw-hdfsee.c | 362 | ||||
-rw-r--r-- | src/dw-hdfsee.h | 23 |
2 files changed, 271 insertions, 114 deletions
diff --git a/src/dw-hdfsee.c b/src/dw-hdfsee.c index 7358edcb..400fb471 100644 --- a/src/dw-hdfsee.c +++ b/src/dw-hdfsee.c @@ -230,24 +230,35 @@ static void show_simple_ring(cairo_t *cr, DisplayWindow *dw, static void maybe_draw_focus(DisplayWindow *dw, cairo_t *cr, int i, cairo_matrix_t *basic_m) { - if ( dw->calib_mode_groups == 1 ) { - if ( dw->image->det->panels[i].rigid_group - == dw->calib_mode_curr_rg ) - { + switch ( dw->calib_mode ) { + + case CALIBMODE_NONE: + break; + + case CALIBMODE_PANELS: + if ( &dw->image->det->panels[i] == dw->calib_mode_curr_p) { draw_calib_focus_rectangle(cr, basic_m, dw, i); cairo_stroke(cr); } - } else if ( dw->calib_mode_groups == 2 ) { - draw_calib_focus_rectangle(cr, basic_m, dw, i); - cairo_stroke(cr); - } else { - if ( &dw->image->det->panels[i] == dw->calib_mode_curr_p) { + break; + + case CALIBMODE_GROUPS: + if ( dw->image->det->panels[i].rigid_group == dw->calib_mode_curr_rg ) + { draw_calib_focus_rectangle(cr, basic_m, dw, i); cairo_stroke(cr); } + break; + + case CALIBMODE_ALL: + draw_calib_focus_rectangle(cr, basic_m, dw, i); + cairo_stroke(cr); + break; + } } + static int draw_stuff(cairo_surface_t *surf, DisplayWindow *dw) { cairo_t *cr; @@ -1162,8 +1173,8 @@ static gint displaywindow_set_usegeom(GtkWidget *d, DisplayWindow *dw) static gint displaywindow_set_calibmode(GtkWidget *d, DisplayWindow *dw) { - GtkWidget *w, *vbox; + int val; w = gtk_ui_manager_get_widget(dw->ui, "/ui/displaywindow/tools/calibmode"); @@ -1173,10 +1184,10 @@ static gint displaywindow_set_calibmode(GtkWidget *d, DisplayWindow *dw) } /* Get new value */ - dw->calib_mode = gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(w)); + val = gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(w)); /* When entering calibration mode */ - if ( dw->calib_mode ) { + if ( val ) { guint cc; @@ -1187,30 +1198,32 @@ static gint displaywindow_set_calibmode(GtkWidget *d, DisplayWindow *dw) dw->calib_mode_curr_p = dw->calib_mode_curr_rg->panels[0]; } - dw->calib_mode_groups = 0; + dw->calib_mode = CALIBMODE_PANELS; - dw->calibmode_statusbar = gtk_statusbar_new(); - gtk_widget_show(dw->calibmode_statusbar); + dw->statusbar = gtk_statusbar_new(); + gtk_widget_show(dw->statusbar); vbox = gtk_bin_get_child(GTK_BIN(dw->window)); - gtk_box_pack_end(GTK_BOX(vbox), dw->calibmode_statusbar, + gtk_box_pack_end(GTK_BOX(vbox), dw->statusbar, TRUE, TRUE, 0); - cc = gtk_statusbar_get_context_id(GTK_STATUSBAR(dw->calibmode_statusbar), - "calibmode"); - gtk_statusbar_push(GTK_STATUSBAR(dw->calibmode_statusbar), cc, - "Last clicked position: Not available"); + cc = gtk_statusbar_get_context_id(GTK_STATUSBAR(dw->statusbar), + "calibmode"); + gtk_statusbar_push(GTK_STATUSBAR(dw->statusbar), cc, + "Calibration mode activated"); displaywindow_update(dw); } else { - gtk_widget_destroy(dw->calibmode_statusbar); - dw->calibmode_statusbar = NULL; - displaywindow_update(dw); + dw->calib_mode = CALIBMODE_NONE; + gtk_widget_destroy(dw->statusbar); + dw->statusbar = NULL; + displaywindow_update(dw); } return 0; } + static gint displaywindow_set_rings(GtkWidget *d, DisplayWindow *dw) { GtkWidget *w; @@ -1914,7 +1927,7 @@ static void calibmode_press(DisplayWindow *dw, GdkEventButton *event) char statusbar_string[80]; guint cc; - cc = gtk_statusbar_get_context_id(GTK_STATUSBAR(dw->calibmode_statusbar), + cc = gtk_statusbar_get_context_id(GTK_STATUSBAR(dw->statusbar), "calibmode"); x = dw->binning * (event->x); @@ -1934,8 +1947,7 @@ static void calibmode_press(DisplayWindow *dw, GdkEventButton *event) " (panel %s)", x, y, fs, ss, find_panel(dw->image->det, fs, ss)->name); } - gtk_statusbar_push(GTK_STATUSBAR(dw->calibmode_statusbar), - cc, statusbar_string); + gtk_statusbar_push(GTK_STATUSBAR(dw->statusbar), cc, statusbar_string); } @@ -1960,7 +1972,7 @@ static gint displaywindow_press(GtkWidget *widget, GdkEventButton *event, numbers_update(dw); } - if ( dw->calibmode_statusbar != NULL ) { + if ( dw->statusbar != NULL ) { calibmode_press(dw, event); } @@ -1980,8 +1992,8 @@ static int curr_rg_pointer_index(DisplayWindow *dw) } } - // should never be reached. Here just to make the compiler happy - return -1; + /* Never reached (we hope) */ + return 999; } @@ -1995,8 +2007,8 @@ static int curr_p_pointer_index_in_rg(DisplayWindow *dw) } } - // should never be reached. Here just to make the compiler happy - return -1; + /* Never reached (we hope) */ + return 999; } @@ -2044,102 +2056,253 @@ static void select_prev_panel(DisplayWindow *dw, int num_p) } +static void toggle_calibmode_groupmode(DisplayWindow *dw) +{ + struct rigid_group *rg; + struct detector *det = dw->image->det; + + switch ( dw->calib_mode ) { + + case CALIBMODE_NONE: + break; + + case CALIBMODE_PANELS: + if ( det->n_rigid_groups != det->n_panels ) { + /* Only change if there are any rigid groups defined */ + dw->calib_mode = CALIBMODE_GROUPS; + rg = dw->calib_mode_curr_p->rigid_group; + dw->calib_mode_curr_rg = rg; + } else { + /* ...otherwise skip to ALL mode */ + dw->calib_mode = CALIBMODE_ALL; + } + break; + + case CALIBMODE_GROUPS: + dw->calib_mode = CALIBMODE_ALL; + break; + + case CALIBMODE_ALL: + dw->calib_mode = CALIBMODE_PANELS; + dw->calib_mode_curr_p = dw->calib_mode_curr_rg->panels[0]; + break; + + } +} + + +static void calibmode_next(DisplayWindow *dw) +{ + int n; + + switch ( dw->calib_mode ) { + + case CALIBMODE_NONE: + break; + + case CALIBMODE_PANELS: + n = dw->calib_mode_curr_rg->n_panels; + select_next_panel(dw, n); + break; + + case CALIBMODE_GROUPS: + n = dw->image->det->n_rigid_groups; + select_next_group(dw, n); + break; + + case CALIBMODE_ALL: + break; + + } +} + + +static void calibmode_prev(DisplayWindow *dw) +{ + int n; + + switch ( dw->calib_mode ) { + + case CALIBMODE_NONE: + break; + + case CALIBMODE_PANELS: + n = dw->calib_mode_curr_rg->n_panels; + select_prev_panel(dw, n); + break; + + case CALIBMODE_GROUPS: + n = dw->image->det->n_rigid_groups; + select_prev_group(dw, n); + break; + + case CALIBMODE_ALL: + break; + + } +} + + +static void calibmode_up(DisplayWindow *dw) +{ + int pi; + + switch ( dw->calib_mode ) { + + case CALIBMODE_NONE: + break; + + case CALIBMODE_PANELS: + dw->calib_mode_curr_p->cny += 1.0; + break; + + case CALIBMODE_GROUPS: + for ( pi=0; pi<dw->calib_mode_curr_rg->n_panels; ++pi ) { + dw->calib_mode_curr_rg->panels[pi]->cny += 1.0; + } + break; + + case CALIBMODE_ALL: + for ( pi=0; pi<dw->image->det->n_panels; ++pi ) { + dw->image->det->panels[pi].cny += 1.0; + } + break; + + } +} + + +static void calibmode_down(DisplayWindow *dw) +{ + int pi; + + switch ( dw->calib_mode ) { + + case CALIBMODE_NONE: + break; + + case CALIBMODE_PANELS: + dw->calib_mode_curr_p->cny -= 1.0; + break; + + case CALIBMODE_GROUPS: + for ( pi=0; pi<dw->calib_mode_curr_rg->n_panels; ++pi ) { + dw->calib_mode_curr_rg->panels[pi]->cny -= 1.0; + } + break; + + case CALIBMODE_ALL: + for ( pi=0; pi<dw->image->det->n_panels; ++pi ) { + dw->image->det->panels[pi].cny -= 1.0; + } + break; + + } +} + + +static void calibmode_left(DisplayWindow *dw) +{ + int pi; + + switch ( dw->calib_mode ) { + + case CALIBMODE_NONE: + break; + + case CALIBMODE_PANELS: + dw->calib_mode_curr_p->cnx -= 1.0; + break; + + case CALIBMODE_GROUPS: + for ( pi=0; pi<dw->calib_mode_curr_rg->n_panels; ++pi ) { + dw->calib_mode_curr_rg->panels[pi]->cnx -= 1.0; + } + break; + + case CALIBMODE_ALL: + for ( pi=0; pi<dw->image->det->n_panels; ++pi ) { + dw->image->det->panels[pi].cnx -= 1.0; + } + break; + + } +} + + +static void calibmode_right(DisplayWindow *dw) +{ + int pi; + + switch ( dw->calib_mode ) { + + case CALIBMODE_NONE: + break; + + case CALIBMODE_PANELS: + dw->calib_mode_curr_p->cnx += 1.0; + break; + + case CALIBMODE_GROUPS: + for ( pi=0; pi<dw->calib_mode_curr_rg->n_panels; ++pi ) { + dw->calib_mode_curr_rg->panels[pi]->cnx += 1.0; + } + break; + + case CALIBMODE_ALL: + for ( pi=0; pi<dw->image->det->n_panels; ++pi ) { + dw->image->det->panels[pi].cnx += 1.0; + } + break; + + } +} + + static gint displaywindow_keypress(GtkWidget *widget, GdkEventKey *event, DisplayWindow *dw) { - int pi, s, num_rg, num_p; + int s; if ( !dw->calib_mode ) { return 0; } - num_rg = dw->image->det->n_rigid_groups; - switch ( event->keyval ) { case GDK_Up: case GDK_KP_Up: - if ( dw->calib_mode_groups == 1 ) { - for ( pi=0; pi<dw->calib_mode_curr_rg->n_panels; ++pi ) { - dw->calib_mode_curr_rg->panels[pi]->cny += 1.0; - } - } else if ( dw->calib_mode_groups == 0 ) { - dw->calib_mode_curr_p->cny += 1.0; - } else { - for ( pi=0; pi<dw->image->det->n_panels; ++pi ) { - dw->image->det->panels[pi].cny += 1.0; - } - } + calibmode_up(dw); redraw_window(dw); break; case GDK_Down: case GDK_KP_Down: - if ( dw->calib_mode_groups == 1 ) { - for ( pi=0; pi<dw->calib_mode_curr_rg->n_panels; ++pi ) { - dw->calib_mode_curr_rg->panels[pi]->cny -= 1.0; - } - } else if ( dw->calib_mode_groups == 0 ) { - dw->calib_mode_curr_p->cny -= 1.0; - } else { - for ( pi=0; pi<dw->image->det->n_panels; ++pi ) { - dw->image->det->panels[pi].cny -= 1.0; - } - } + calibmode_down(dw); redraw_window(dw); break; case GDK_Left: case GDK_KP_Left: - if ( dw->calib_mode_groups == 1 ) { - for ( pi=0; pi<dw->calib_mode_curr_rg->n_panels; ++pi ) { - dw->calib_mode_curr_rg->panels[pi]->cnx -= 1.0; - } - } else if ( dw->calib_mode_groups == 0 ) { - dw->calib_mode_curr_p->cnx -= 1.0; - } else { - for ( pi=0; pi<dw->image->det->n_panels; ++pi ) { - dw->image->det->panels[pi].cnx -= 1.0; - } - } + calibmode_left(dw); redraw_window(dw); break; case GDK_Right: case GDK_KP_Right: - if ( dw->calib_mode_groups == 1 ) { - for ( pi=0; pi<dw->calib_mode_curr_rg->n_panels; ++pi ) { - dw->calib_mode_curr_rg->panels[pi]->cnx += 1.0; - } - } else if ( dw->calib_mode_groups == 0 ) { - dw->calib_mode_curr_p->cnx += 1.0; - } else { - for ( pi=0; pi<dw->image->det->n_panels; ++pi ) { - dw->image->det->panels[pi].cnx += 1.0; - } - } + calibmode_right(dw); redraw_window(dw); break; case GDK_plus: case GDK_KP_Add: - num_p = dw->calib_mode_curr_rg->n_panels; - if ( dw->calib_mode_groups == 1 ) { - select_next_group(dw, num_rg); - } else if ( dw->calib_mode_groups == 0 ) { - select_next_panel(dw, num_p); - } + calibmode_next(dw); redraw_window(dw); break; case GDK_minus: case GDK_KP_Subtract: - num_p = dw->calib_mode_curr_rg->n_panels; - if ( dw->calib_mode_groups == 1 ) { - select_prev_group(dw, num_rg); - } else if ( dw->calib_mode_groups == 0 ) { - select_prev_panel(dw, num_p); - } + calibmode_prev(dw); redraw_window(dw); break; @@ -2149,19 +2312,7 @@ static gint displaywindow_keypress(GtkWidget *widget, GdkEventKey *event, break; case GDK_g: - if ( dw->calib_mode_groups == 0) { - if ( dw->image->det->n_rigid_groups == dw->image->det->n_panels ) { - dw->calib_mode_groups = 2; - } else { - dw->calib_mode_groups = 1; - dw->calib_mode_curr_rg = dw->calib_mode_curr_p->rigid_group; - } - } else if ( dw->calib_mode_groups == 1 ) { - dw->calib_mode_groups = 2; - } else { - dw->calib_mode_groups = 0; - dw->calib_mode_curr_p = dw->calib_mode_curr_rg->panels[0]; - } + toggle_calibmode_groupmode(dw); redraw_window(dw); break; @@ -2221,12 +2372,11 @@ DisplayWindow *displaywindow_open(const char *filename, const char *peaks, dw->n_rings = n_rings; dw->median_filter = median_filter; dw->image = calloc(1, sizeof(struct image)); - dw->calib_mode = 0; + dw->calib_mode = CALIBMODE_NONE; dw->calib_mode_curr_rg = NULL; dw->calib_mode_curr_p = NULL; dw->calib_mode_show_focus = 1; - dw->calib_mode_groups = 1; - dw->calibmode_statusbar = NULL; + dw->statusbar = NULL; if ( beam != NULL ) { dw->image->beam = get_beam_parameters(beam); diff --git a/src/dw-hdfsee.h b/src/dw-hdfsee.h index b469e79d..22e44a34 100644 --- a/src/dw-hdfsee.h +++ b/src/dw-hdfsee.h @@ -67,6 +67,14 @@ struct numberswindow { }; +typedef enum { + CALIBMODE_NONE, + CALIBMODE_PANELS, + CALIBMODE_GROUPS, + CALIBMODE_ALL +} CalibMode; + + typedef struct { GtkWidget *window; @@ -87,8 +95,8 @@ typedef struct { struct image *image; /* Dialog boxes */ - BinningDialog *binning_dialog; - BoostIntDialog *boostint_dialog; + BinningDialog *binning_dialog; + BoostIntDialog *boostint_dialog; RingRadiusDialog *ringradius_dialog; struct numberswindow *numbers_window; @@ -109,13 +117,12 @@ typedef struct { double ring_radius; double *ring_radii; int n_rings; - int calib_mode; - struct rigid_group *calib_mode_curr_rg; - struct panel *calib_mode_curr_p; - int calib_mode_show_focus; - int calib_mode_groups; - GtkWidget *calibmode_statusbar; + CalibMode calib_mode; + struct rigid_group *calib_mode_curr_rg; + struct panel *calib_mode_curr_p; + int calib_mode_show_focus; + GtkWidget *statusbar; int show_col_scale; int scale; |