aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2021-03-01 09:47:57 +0100
committerThomas White <taw@physics.org>2021-03-01 09:47:57 +0100
commit85bf423b8ec734cee29863b7a411cdb7e5ce0399 (patch)
treeac71550a6241f288fcc6c736a274560657d425c3
parent1584bced3ecc9fe699bd972a66741968a838398a (diff)
GUI: Add history list for random image selection
-rw-r--r--src/crystfel_gui.c41
-rw-r--r--src/gui_project.c2
-rw-r--r--src/gui_project.h5
3 files changed, 45 insertions, 3 deletions
diff --git a/src/crystfel_gui.c b/src/crystfel_gui.c
index e2be0841..cd69f494 100644
--- a/src/crystfel_gui.c
+++ b/src/crystfel_gui.c
@@ -277,6 +277,32 @@ void update_imageview(struct crystfelproject *proj)
}
+static void push_random_frame(struct crystfelproject *proj, int fr)
+{
+ memmove(&proj->random_history[1],
+ &proj->random_history[0],
+ (N_RANDOM_HISTORY-1)*sizeof(int));
+ proj->random_history[0] = fr;
+ proj->n_random_history++;
+ if ( proj->n_random_history > N_RANDOM_HISTORY ) {
+ proj->n_random_history = N_RANDOM_HISTORY;
+ }
+}
+
+
+static int pop_random_frame(struct crystfelproject *proj)
+{
+ int fr;
+ assert(proj->n_random_history > 0);
+ fr = proj->random_history[0];
+ memmove(&proj->random_history[0],
+ &proj->random_history[1],
+ (N_RANDOM_HISTORY-1)*sizeof(int));
+ proj->n_random_history--;
+ return fr;
+}
+
+
/* File->Quit */
static gint quit_sig(GtkWidget *widget, struct crystfelproject *proj)
{
@@ -344,10 +370,19 @@ static gint prev_frame_sig(GtkWidget *widget,
static gint random_frame_sig(GtkWidget *widget,
+ GdkEventButton *event,
struct crystfelproject *proj)
{
- proj->cur_frame = random()*proj->n_frames / RAND_MAX;
- update_imageview(proj);
+ if ( event->state & GDK_SHIFT_MASK ) {
+ if ( proj->n_random_history > 0 ) {
+ proj->cur_frame = pop_random_frame(proj);
+ update_imageview(proj);
+ }
+ } else {
+ push_random_frame(proj, proj->cur_frame);
+ proj->cur_frame = random()*proj->n_frames / RAND_MAX;
+ update_imageview(proj);
+ }
return FALSE;
}
@@ -720,7 +755,7 @@ int main(int argc, char *argv[])
button = gtk_button_new_from_icon_name("media-playlist-shuffle",
GTK_ICON_SIZE_LARGE_TOOLBAR);
gtk_box_pack_start(GTK_BOX(toolbar), button, FALSE, FALSE, 2.0);
- g_signal_connect(G_OBJECT(button), "clicked",
+ g_signal_connect(G_OBJECT(button), "button-press-event",
G_CALLBACK(random_frame_sig), &proj);
/* Next */
diff --git a/src/gui_project.c b/src/gui_project.c
index 12377d83..752cbc20 100644
--- a/src/gui_project.c
+++ b/src/gui_project.c
@@ -1060,6 +1060,8 @@ void default_project(struct crystfelproject *proj)
proj->geom_filename = NULL;
proj->n_frames = 0;
proj->max_frames = 0;
+ proj->n_random_history = 0;
+ memset(proj->random_history, 0, N_RANDOM_HISTORY*sizeof(int));
proj->filenames = NULL;
proj->events = NULL;
proj->peak_params = NULL;
diff --git a/src/gui_project.h b/src/gui_project.h
index e08e20a7..e0717007 100644
--- a/src/gui_project.h
+++ b/src/gui_project.h
@@ -241,6 +241,9 @@ struct gui_task
void *job_priv;
};
+
+#define N_RANDOM_HISTORY (16)
+
struct crystfelproject {
GtkWidget *window;
@@ -262,6 +265,8 @@ struct crystfelproject {
int cur_frame;
struct image *cur_image;
+ int random_history[N_RANDOM_HISTORY];
+ int n_random_history;
char *geom_filename;
char *stream_filename;