diff options
author | Wilrik de Loose <wilrik@wilrik.nl> | 2008-01-09 11:31:42 (GMT) |
---|---|---|
committer | Wilrik de Loose <wilrik@wilrik.nl> | 2008-01-09 11:31:42 (GMT) |
commit | ae535cfe2dfbb6b90f41a9fad6fc863a05fb32ba (patch) | |
tree | e364e7ebca4eaa4b53693f975b5ac553a4af94b4 | |
parent | 4da3ab92496c596274a5efb2304a3e80f927c95a (diff) | |
download | 2iv35-ae535cfe2dfbb6b90f41a9fad6fc863a05fb32ba.zip 2iv35-ae535cfe2dfbb6b90f41a9fad6fc863a05fb32ba.tar.gz 2iv35-ae535cfe2dfbb6b90f41a9fad6fc863a05fb32ba.tar.bz2 |
isoline gui 'af'
-rw-r--r-- | Smoke/Week 2.suo | bin | 66560 -> 66560 bytes | |||
-rw-r--r-- | Smoke/gtk_isolines.c | 60 | ||||
-rw-r--r-- | Smoke/gui_requirements.txt | 2 | ||||
-rw-r--r-- | Smoke/renderer_gl.c | 2 |
4 files changed, 53 insertions, 11 deletions
diff --git a/Smoke/Week 2.suo b/Smoke/Week 2.suo Binary files differindex 776d701..581e8f3 100644 --- a/Smoke/Week 2.suo +++ b/Smoke/Week 2.suo diff --git a/Smoke/gtk_isolines.c b/Smoke/gtk_isolines.c index 1f4dd6a..54344af 100644 --- a/Smoke/gtk_isolines.c +++ b/Smoke/gtk_isolines.c @@ -5,7 +5,7 @@ #include "palette.h" -#include "glyphs.h" +#include "isolines.h" #include "gtk_isolines.h" @@ -24,11 +24,21 @@ static gboolean select_num_colors(GtkRange *adjustment, gpointer data) static gboolean select_num_isolines(GtkRange *adjustment, gpointer data) { - printf("%f", gtk_range_get_value(adjustment)); isolines_set_nr((int)gtk_range_get_value(adjustment)); } +static gboolean select_min_threshold(GtkRange *adjustment, gpointer data) +{ + isolines_set_threshold_min(gtk_range_get_value(adjustment)); +} + + +static gboolean select_max_threshold(GtkRange *adjustment, gpointer data) +{ + isolines_set_threshold_max(gtk_range_get_value(adjustment)); +} + static gboolean select_alpha(GtkRange *adjustment, gpointer data) { isolines_set_alpha((float)gtk_range_get_value(adjustment)); @@ -51,7 +61,6 @@ GtkWidget *create_isolines_page(void) page = gtk_vbox_new(FALSE, 0); - frame = gtk_frame_new("Scalarset"); box = gtk_hbox_new(FALSE, 0); @@ -106,14 +115,12 @@ GtkWidget *create_isolines_page(void) frame = gtk_frame_new("Colors"); box = gtk_vbox_new(FALSE, 0); - label = gtk_label_new("Colormap"); gtk_box_pack_start(GTK_BOX(box), label, FALSE, TRUE, 0); gtk_widget_show(label); - combo = gtk_combo_box_new_text(); gtk_combo_box_append_text(GTK_COMBO_BOX(combo), PALETTE_NAME_BLACKWHITE); @@ -132,6 +139,16 @@ GtkWidget *create_isolines_page(void) gtk_box_pack_start(GTK_BOX(box), combo, FALSE, TRUE, 0); gtk_widget_show(combo); + gtk_container_add(GTK_CONTAINER(frame), box); + gtk_widget_show(box); + + gtk_box_pack_start(GTK_BOX(page), frame, FALSE, TRUE, 0); + + gtk_widget_show(frame); + + frame = gtk_frame_new("Isolines"); + + box = gtk_vbox_new(FALSE, 0); label = gtk_label_new("Number of Colors"); @@ -163,14 +180,14 @@ GtkWidget *create_isolines_page(void) //gtk_widget_show(color_scale); gtk_container_add(GTK_CONTAINER(frame), box); - gtk_widget_show(box); + gtk_widget_show(frame); - label = gtk_label_new("Number of isolines"); + label = gtk_label_new("Number of isolines"); gtk_box_pack_start(GTK_BOX(box), label, FALSE, TRUE, 0); gtk_widget_show(label); - adjustment = GTK_ADJUSTMENT(gtk_adjustment_new(isolines_get_nr(), 0, 8, 0.5, 5, 0.1)); + adjustment = GTK_ADJUSTMENT(gtk_adjustment_new(isolines_get_nr(), 0, 8, 1, 1, 0)); scale = gtk_hscale_new(adjustment); gtk_scale_set_digits(GTK_SCALE(scale), 0); g_signal_connect(GTK_RANGE(scale), "value-changed", G_CALLBACK(select_num_isolines), NULL); @@ -178,6 +195,32 @@ GtkWidget *create_isolines_page(void) gtk_box_pack_start(GTK_BOX(box), scale, FALSE, TRUE, 0); gtk_widget_show(scale); + label = gtk_label_new("Minimum threshold value"); + + gtk_box_pack_start(GTK_BOX(box), label, FALSE, TRUE, 0); + gtk_widget_show(label); + + adjustment = GTK_ADJUSTMENT(gtk_adjustment_new(isolines_get_threshold_min(), 0.01, 4, 0.01, 0.1, 0)); + scale = gtk_hscale_new(adjustment); + gtk_scale_set_digits(GTK_SCALE(scale), 2); + g_signal_connect(GTK_RANGE(scale), "value-changed", G_CALLBACK(select_min_threshold), NULL); + + gtk_box_pack_start(GTK_BOX(box), scale, FALSE, TRUE, 0); + gtk_widget_show(scale); + + label = gtk_label_new("Maximum threshold value"); + + gtk_box_pack_start(GTK_BOX(box), label, FALSE, TRUE, 0); + gtk_widget_show(label); + + adjustment = GTK_ADJUSTMENT(gtk_adjustment_new(isolines_get_threshold_max(), 0, 4, 0.01, 0.1, 0)); + scale = gtk_hscale_new(adjustment); + gtk_scale_set_digits(GTK_SCALE(scale), 2); + g_signal_connect(GTK_RANGE(scale), "value-changed", G_CALLBACK(select_max_threshold), NULL); + + gtk_box_pack_start(GTK_BOX(box), scale, FALSE, TRUE, 0); + gtk_widget_show(scale); + gtk_container_add(GTK_CONTAINER(frame), box); gtk_widget_show(box); @@ -185,6 +228,5 @@ GtkWidget *create_isolines_page(void) gtk_widget_show(frame); - return page; } diff --git a/Smoke/gui_requirements.txt b/Smoke/gui_requirements.txt index f63ee38..5164a9c 100644 --- a/Smoke/gui_requirements.txt +++ b/Smoke/gui_requirements.txt @@ -26,7 +26,7 @@ ISOLINES + render isoline
+ select isoline colormap
+ / - alter number of isolines
-- alter min and max threshold
++ / - alter min and max threshold
HEIGHT PLOTS
diff --git a/Smoke/renderer_gl.c b/Smoke/renderer_gl.c index ae4d894..b8edfde 100644 --- a/Smoke/renderer_gl.c +++ b/Smoke/renderer_gl.c @@ -572,7 +572,7 @@ static void render_isolines(void) iso_scale = isolines_get_nr(); if (isolines_get_nr()) { - iso_scale = (float)(fabs(isolines_get_threshold_min() - isolines_get_threshold_max()) / (float)isolines_get_nr()); + iso_scale = (float)(fabs(isolines_get_threshold_min() - isolines_get_threshold_max()) / isolines_get_nr()); } else { iso_scale = 0.0f; } |