graph buttons

This commit is contained in:
Olaf Rempel 2008-04-19 16:45:11 +02:00
parent ffcdcc6f9b
commit 85973da3b9
2 changed files with 121 additions and 38 deletions

View File

@ -43,8 +43,18 @@ static GdkColor colors[] = {
{ .red = 0x8000, .green = 0x8000, .blue = 0x8000, }, { .red = 0x8000, .green = 0x8000, .blue = 0x8000, },
}; };
#define MOD_CONTINUOUS 0x0001
#define MOD_SINGLESHOT 0x0002
#define MOD_RUNNING 0x0004
#define MOD_STOPPED 0x0008
static int graph_mode = MOD_CONTINUOUS | MOD_RUNNING;
static struct timeval base;
static GtkWidget *box; static GtkWidget *box;
static GtkWidget *legend; static GtkWidget *legend;
static GtkWidget *yscale_min, *yscale_max;
static GtkWidget *start_button, *mode_button;
static GList *graphlist; static GList *graphlist;
@ -105,9 +115,85 @@ static void update_legend(void)
g_string_free(tmp, TRUE); g_string_free(tmp, TRUE);
} }
static void rescale_graphs(gboolean reset)
{
static GtkDataboxValue min;
static GtkDataboxValue max;
GtkDataboxValue tmp_min, tmp_max;
if (gtk_databox_calculate_extrema(GTK_DATABOX(box), &tmp_min, &tmp_max) < 0)
return;
/* swap y: min/max (high values -> higher on screen) */
if (!reset) {
min.x = MIN(min.x, tmp_min.x);
max.x = MAX(max.x, tmp_max.x);
min.y = MAX(min.y, tmp_max.y);
max.y = MIN(max.y, tmp_min.y);
} else {
min.x = tmp_min.x;
max.x = tmp_max.x;
min.y = tmp_max.y;
max.y = tmp_min.y;
}
char tmp[64];
snprintf(tmp, sizeof(tmp), "y-Min: %0.0lf", max.y);
gtk_label_set_text(GTK_LABEL(yscale_min), tmp);
snprintf(tmp, sizeof(tmp), "y-Max: %0.0lf", min.y);
gtk_label_set_text(GTK_LABEL(yscale_max), tmp);
gtk_databox_set_canvas(GTK_DATABOX(box), min, max);
}
static void rescale_button_cb(GtkWidget *widget, gpointer data)
{
rescale_graphs(TRUE);
}
static void update_button_labels(void)
{
if (graph_mode & MOD_SINGLESHOT)
gtk_button_set_label(GTK_BUTTON(mode_button), "Single Shot");
else if (graph_mode & MOD_CONTINUOUS)
gtk_button_set_label(GTK_BUTTON(mode_button), "Continuous");
if (graph_mode & MOD_RUNNING)
gtk_button_set_label(GTK_BUTTON(start_button), "Halt");
else if (graph_mode & MOD_STOPPED)
gtk_button_set_label(GTK_BUTTON(start_button), "Start");
}
static void mode_button_cb(GtkWidget *widget, gpointer data)
{
if (graph_mode & MOD_SINGLESHOT)
graph_mode = (graph_mode & ~MOD_SINGLESHOT) | MOD_CONTINUOUS;
else if (graph_mode & MOD_CONTINUOUS)
graph_mode = (graph_mode & ~MOD_CONTINUOUS) | MOD_SINGLESHOT;
update_button_labels();
}
static void start_button_cb(GtkWidget *widget, gpointer data)
{
if (graph_mode & MOD_STOPPED) {
graph_mode = (graph_mode & ~MOD_STOPPED) | MOD_RUNNING;
gettimeofday(&base, NULL);
} else if (graph_mode & MOD_RUNNING) {
graph_mode = (graph_mode & ~MOD_RUNNING) | MOD_STOPPED;
}
update_button_labels();
}
gint gui_graphtab_init(GtkNotebook *notebook) gint gui_graphtab_init(GtkNotebook *notebook)
{ {
GtkWidget *table = gtk_table_new(5, 4, FALSE); GtkWidget *table = gtk_table_new(5, 6, FALSE);
box = gtk_databox_new(); box = gtk_databox_new();
gtk_table_attach(GTK_TABLE(table), box, 1, 4, 1, 2, gtk_table_attach(GTK_TABLE(table), box, 1, 4, 1, 2,
@ -141,13 +227,27 @@ gint gui_graphtab_init(GtkNotebook *notebook)
gtk_databox_graph_add(GTK_DATABOX(box), grid); gtk_databox_graph_add(GTK_DATABOX(box), grid);
legend = gtk_label_new(NULL); legend = gtk_label_new(NULL);
gtk_table_attach(GTK_TABLE(table), legend, 1, 2, 3, 4, 0, 0, 10, 10); gtk_table_attach(GTK_TABLE(table), legend, 1, 2, 3, 6, 0, 0, 5, 5);
GtkWidget *button2 = gtk_button_new_with_label("Mode"); yscale_max = gtk_label_new("y-Max:");
gtk_table_attach(GTK_TABLE(table), button2, 2, 3, 3, 4, 0, 0, 10, 10); gtk_table_attach(GTK_TABLE(table), yscale_max, 2, 3, 3, 4, 0, 0, 5, 5);
GtkWidget *button3 = gtk_button_new_with_label("Stopp"); yscale_min = gtk_label_new("y-Min:");
gtk_table_attach(GTK_TABLE(table), button3, 3, 4, 3, 4, 0, 0, 10, 10); gtk_table_attach(GTK_TABLE(table), yscale_min, 2, 3, 4, 5, 0, 0, 5, 5);
GtkWidget *rescale_button = gtk_button_new_with_label("Autoscale");
gtk_table_attach(GTK_TABLE(table), rescale_button, 2, 3, 5, 6, 0, 0, 10, 10);
g_signal_connect(G_OBJECT(rescale_button), "clicked", G_CALLBACK(rescale_button_cb), NULL);
start_button = gtk_button_new_with_label("Start");
gtk_table_attach(GTK_TABLE(table), start_button, 3, 4, 4, 5, 0, 0, 10, 10);
g_signal_connect(G_OBJECT(start_button), "clicked", G_CALLBACK(start_button_cb), NULL);
mode_button = gtk_button_new_with_label("Continuous");
gtk_table_attach(GTK_TABLE(table), mode_button, 3, 4, 5, 6, 0, 0, 10, 10);
g_signal_connect(G_OBJECT(mode_button), "clicked", G_CALLBACK(mode_button_cb), NULL);
update_button_labels();
GtkWidget *label = gtk_label_new(" Graph "); GtkWidget *label = gtk_label_new(" Graph ");
return gtk_notebook_append_page(GTK_NOTEBOOK(notebook), table, label); return gtk_notebook_append_page(GTK_NOTEBOOK(notebook), table, label);
@ -206,42 +306,15 @@ static int calc_index(struct timeval *base, struct timeval *now, int step)
return diff.tv_usec / step; return diff.tv_usec / step;
} }
static void rescale_graphs(gboolean reset)
{
static GtkDataboxValue min;
static GtkDataboxValue max;
GtkDataboxValue tmp_min, tmp_max;
if (gtk_databox_calculate_extrema(GTK_DATABOX(box), &tmp_min, &tmp_max) < 0)
return;
float swap = tmp_min.y;
tmp_min.y = tmp_max.y;
tmp_max.y = swap;
if (!reset) {
min.x = MIN(min.x, tmp_min.x);
min.y = MAX(min.y, tmp_min.y);
max.x = MAX(max.x, tmp_max.x);
max.y = MIN(max.y, tmp_max.y);
} else {
min.x = tmp_min.x;
min.y = tmp_min.y;
max.x = tmp_max.x;
max.y = tmp_max.y;
}
gtk_databox_set_canvas(GTK_DATABOX(box), min, max);
}
void gui_graphtab_update_var(struct tdc_var *var) void gui_graphtab_update_var(struct tdc_var *var)
{ {
static struct timeval base, update; static struct timeval update;
struct xygraph *graph = (struct xygraph *)var->privdata_graphtab; struct xygraph *graph = (struct xygraph *)var->privdata_graphtab;
if (graph_mode & MOD_STOPPED)
return;
struct timeval now; struct timeval now;
gettimeofday(&now, NULL); gettimeofday(&now, NULL);
@ -250,6 +323,11 @@ void gui_graphtab_update_var(struct tdc_var *var)
base.tv_sec = now.tv_sec; base.tv_sec = now.tv_sec;
base.tv_usec = now.tv_usec; base.tv_usec = now.tv_usec;
i = 0; i = 0;
if (graph_mode & MOD_SINGLESHOT) {
graph_mode = (graph_mode & ~MOD_RUNNING) | MOD_STOPPED;
update_button_labels();
}
} }
float last_value = graph->yarr[graph->last_index]; float last_value = graph->yarr[graph->last_index];

View File

@ -57,7 +57,12 @@ static int tdcstore_destroy_var(struct tdc_board *board, int id)
if (var == NULL) if (var == NULL)
return -1; return -1;
gui_vartab_remove_var(var); if (var->privdata_vartab)
gui_vartab_remove_var(var);
if (var->privdata_graphtab)
gui_graphtab_remove_var(var);
tdcvar_destroy(var); tdcvar_destroy(var);
board->varmap[id & 0xFF] = NULL; board->varmap[id & 0xFF] = NULL;