#include static void draw_popup (GtkDrawingArea *da, cairo_t *cr, int width, int height, gpointer data) { cairo_set_source_rgb (cr, 1, 0, 0); cairo_paint (cr); } static gboolean place_popup (GtkWidget *parent, GdkEvent *event, GtkWidget *popup) { gint width, height; gdouble x, y; gtk_window_get_size (GTK_WINDOW (popup), &width, &height); gdk_event_get_root_coords (event, &x, &y); gtk_window_move (GTK_WINDOW (popup), (int) x - width / 2, (int) y - height / 2); return FALSE; } static gboolean on_map_event (GtkWidget *parent, GdkEvent *event, gpointer data) { GtkWidget *popup, *da; popup = gtk_window_new (GTK_WINDOW_POPUP); da = gtk_drawing_area_new (); gtk_drawing_area_set_draw_func (GTK_DRAWING_AREA (da), draw_popup, NULL, NULL); gtk_container_add (GTK_CONTAINER (popup), da); gtk_widget_set_size_request (GTK_WIDGET (popup), 20, 20); gtk_window_set_transient_for (GTK_WINDOW (popup), GTK_WINDOW (parent)); g_signal_connect (parent, "motion-notify-event", G_CALLBACK (place_popup), popup); gtk_widget_show (popup); return FALSE; } int main (int argc, char *argv[]) { GtkWidget *window; gtk_init (); window = gtk_window_new (GTK_WINDOW_TOPLEVEL); g_signal_connect (window, "destroy", gtk_main_quit, NULL); g_signal_connect (window, "map-event", G_CALLBACK (on_map_event), NULL); gtk_widget_show (window); gtk_main (); return 0; }