X-Git-Url: http://pileus.org/git/?p=grits;a=blobdiff_plain;f=src%2Fplugins%2Ftest.c;h=e1dab0e3964338275a7a479a0984e16bb772f5e6;hp=8fb3ee6b9fda2fb2d457519d91a08dcd4bab3e49;hb=420f1ea8e4aea5dd7bddc77325ab643900c34cd5;hpb=46c47c0bc0785333480ce29b78594e60939efd35 diff --git a/src/plugins/test.c b/src/plugins/test.c index 8fb3ee6..e1dab0e 100644 --- a/src/plugins/test.c +++ b/src/plugins/test.c @@ -30,23 +30,25 @@ #include "test.h" -static void on_poly_enter(GritsPoly *poly) +static gboolean on_poly_enter(GritsPoly *poly) { - g_debug("on_poly_enter"); + g_debug("GritsPluginTest: on_poly_enter"); poly->color[3] = 0.50; grits_object_queue_draw(GRITS_OBJECT(poly)); + return FALSE; } -static void on_poly_leave(GritsPoly *poly) +static gboolean on_poly_leave(GritsPoly *poly) { - g_debug("on_poly_leave"); + g_debug("GritsPluginTest: on_poly_leave"); poly->color[3] = 0.2; grits_object_queue_draw(GRITS_OBJECT(poly)); + return FALSE; } -static void on_poly_button(GritsPoly *poly, GdkEventButton *event) +static gboolean on_poly_button(GritsPoly *poly, GdkEventButton *event) { - g_debug("on_poly_button"); + g_debug("GritsPluginTest: on_poly_button"); static int i = 0; gdouble colors[][3] = { {1, 0, 0}, {1, 1, 0}, @@ -56,42 +58,49 @@ static void on_poly_button(GritsPoly *poly, GdkEventButton *event) int idx = i++ % G_N_ELEMENTS(colors); memcpy(poly->color, colors[idx], sizeof(gdouble)*3); grits_object_queue_draw(GRITS_OBJECT(poly)); + return TRUE; } -static void on_poly_key(GritsPoly *poly, GdkEventKey *event) +static gboolean on_poly_key(GritsPoly *poly, GdkEventKey *event) { - g_debug("on_poly_key"); + g_debug("GritsPluginTest: on_poly_key - %d", event->keyval); gdouble colors[0xff][3] = { [GDK_r] {1, 0, 0}, [GDK_g] {0, 1, 0}, [GDK_b] {0, 0, 1}, }; + if (event->keyval >= G_N_ELEMENTS(colors)) + return FALSE; int key = event->keyval; memcpy(poly->color, colors[key], sizeof(gdouble)*3); grits_object_queue_draw(GRITS_OBJECT(poly)); + return TRUE; } -static void on_marker_enter(GritsMarker *marker, GritsViewer *viewer) +static gboolean on_marker_enter(GritsMarker *marker, GdkEvent *event, GritsViewer *viewer) { - g_debug("on_marker_enter"); + g_debug("GritsPluginTest: on_marker_enter"); GdkWindow *window = gtk_widget_get_window(GTK_WIDGET(viewer)); - GdkCursor *cursor = gdk_cursor_new(GDK_HAND1); + GdkCursor *cursor = gdk_cursor_new(GDK_HAND2); gdk_window_set_cursor(window, cursor); + return FALSE; } -static void on_marker_leave(GritsMarker *marker, GritsViewer *viewer) +static gboolean on_marker_leave(GritsMarker *marker, GdkEvent *event, GritsViewer *viewer) { - g_debug("on_marker_leave"); + g_debug("GritsPluginTest: on_marker_leave"); GdkWindow *window = gtk_widget_get_window(GTK_WIDGET(viewer)); gdk_window_set_cursor(window, NULL); + return FALSE; } -static void on_marker_button(GritsMarker *marker, GdkEventButton *event) +static gboolean on_marker_button(GritsMarker *marker, GdkEventButton *event) { - g_debug("on_marker_button"); + g_debug("GritsPluginTest: on_marker_button"); GtkWidget *dialog = gtk_dialog_new_with_buttons( "St. Charles!", NULL, 0, GTK_STOCK_OK, GTK_RESPONSE_OK, NULL); gtk_dialog_run(GTK_DIALOG(dialog)); + return TRUE; } /*********** @@ -104,14 +113,10 @@ void _load_marker(GritsPluginTest *test) GRITS_OBJECT(test->marker)->center.lon = -90.491982; GRITS_OBJECT(test->marker)->center.elev = 0.0; GRITS_OBJECT(test->marker)->lod = EARTH_R*3; - grits_viewer_add(test->viewer, GRITS_OBJECT(test->marker), GRITS_LEVEL_OVERLAY, FALSE); - /* These do not work on marker yet */ - //g_signal_connect(test->marker, "enter", G_CALLBACK(on_marker_enter), NULL); - //g_signal_connect(test->marker, "leave", G_CALLBACK(on_marker_leave), NULL); - //g_signal_connect(test->marker, "button-press", G_CALLBACK(on_marker_button), NULL); - (void)on_marker_enter; - (void)on_marker_leave; - (void)on_marker_button; + grits_viewer_add(test->viewer, GRITS_OBJECT(test->marker), GRITS_LEVEL_HUD, FALSE); + g_signal_connect(test->marker, "enter", G_CALLBACK(on_marker_enter), test->viewer); + g_signal_connect(test->marker, "leave", G_CALLBACK(on_marker_leave), test->viewer); + g_signal_connect(test->marker, "clicked", G_CALLBACK(on_marker_button), test->viewer); } void _load_poly(GritsPluginTest *test) @@ -123,11 +128,11 @@ void _load_poly(GritsPluginTest *test) test->poly->color[3] = 0.2; test->poly->border[3] = 1; test->poly->width = 6; - grits_viewer_add(test->viewer, GRITS_OBJECT(test->poly), GRITS_LEVEL_OVERLAY, TRUE); - g_signal_connect(test->poly, "enter", G_CALLBACK(on_poly_enter), NULL); - g_signal_connect(test->poly, "leave", G_CALLBACK(on_poly_leave), NULL); - g_signal_connect(test->poly, "button-press", G_CALLBACK(on_poly_button), NULL); - g_signal_connect(test->poly, "key-press", G_CALLBACK(on_poly_key), NULL); + grits_viewer_add(test->viewer, GRITS_OBJECT(test->poly), GRITS_LEVEL_OVERLAY, FALSE); + g_signal_connect(test->poly, "enter", G_CALLBACK(on_poly_enter), NULL); + g_signal_connect(test->poly, "leave", G_CALLBACK(on_poly_leave), NULL); + g_signal_connect(test->poly, "clicked", G_CALLBACK(on_poly_button), NULL); + g_signal_connect(test->poly, "key-press", G_CALLBACK(on_poly_key), NULL); } void _load_line(GritsPluginTest *test) @@ -138,7 +143,7 @@ void _load_line(GritsPluginTest *test) test->line->color[2] = 0; test->line->color[3] = 1; test->line->width = 8; - grits_viewer_add(test->viewer, GRITS_OBJECT(test->line), GRITS_LEVEL_OVERLAY, TRUE); + grits_viewer_add(test->viewer, GRITS_OBJECT(test->line), GRITS_LEVEL_OVERLAY, FALSE); g_signal_connect(test->line, "enter", G_CALLBACK(on_poly_enter), NULL); g_signal_connect(test->line, "leave", G_CALLBACK(on_poly_leave), NULL); g_signal_connect(test->line, "button-press", G_CALLBACK(on_poly_button), NULL);