mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-14 06:10:21 +00:00
Getting-started: port drawing.c to GtkApplication
This commit is contained in:
parent
c73ab94d3f
commit
ec07987a90
@ -129,17 +129,15 @@ close_window (void)
|
|||||||
gtk_main_quit ();
|
gtk_main_quit ();
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
static void
|
||||||
main (int argc,
|
activate (GtkApplication *app,
|
||||||
char *argv[])
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
GtkWidget *window;
|
GtkWidget *window;
|
||||||
GtkWidget *frame;
|
GtkWidget *frame;
|
||||||
GtkWidget *da;
|
GtkWidget *drawing_area;
|
||||||
|
|
||||||
gtk_init (&argc, &argv);
|
window = gtk_application_window_new (app);
|
||||||
|
|
||||||
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
|
||||||
gtk_window_set_title (GTK_WINDOW (window), "Drawing Area");
|
gtk_window_set_title (GTK_WINDOW (window), "Drawing Area");
|
||||||
|
|
||||||
g_signal_connect (window, "destroy", G_CALLBACK (close_window), NULL);
|
g_signal_connect (window, "destroy", G_CALLBACK (close_window), NULL);
|
||||||
@ -150,35 +148,46 @@ main (int argc,
|
|||||||
gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
|
gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
|
||||||
gtk_container_add (GTK_CONTAINER (window), frame);
|
gtk_container_add (GTK_CONTAINER (window), frame);
|
||||||
|
|
||||||
da = gtk_drawing_area_new ();
|
drawing_area = gtk_drawing_area_new ();
|
||||||
/* set a minimum size */
|
/* set a minimum size */
|
||||||
gtk_widget_set_size_request (da, 100, 100);
|
gtk_widget_set_size_request (drawing_area, 100, 100);
|
||||||
|
|
||||||
gtk_container_add (GTK_CONTAINER (frame), da);
|
gtk_container_add (GTK_CONTAINER (frame), drawing_area);
|
||||||
|
|
||||||
/* Signals used to handle the backing surface */
|
/* Signals used to handle the backing surface */
|
||||||
g_signal_connect (da, "draw",
|
g_signal_connect (drawing_area, "draw",
|
||||||
G_CALLBACK (draw_cb), NULL);
|
G_CALLBACK (draw_cb), NULL);
|
||||||
g_signal_connect (da,"configure-event",
|
g_signal_connect (drawing_area,"configure-event",
|
||||||
G_CALLBACK (configure_event_cb), NULL);
|
G_CALLBACK (configure_event_cb), NULL);
|
||||||
|
|
||||||
/* Event signals */
|
/* Event signals */
|
||||||
g_signal_connect (da, "motion-notify-event",
|
g_signal_connect (drawing_area, "motion-notify-event",
|
||||||
G_CALLBACK (motion_notify_event_cb), NULL);
|
G_CALLBACK (motion_notify_event_cb), NULL);
|
||||||
g_signal_connect (da, "button-press-event",
|
g_signal_connect (drawing_area, "button-press-event",
|
||||||
G_CALLBACK (button_press_event_cb), NULL);
|
G_CALLBACK (button_press_event_cb), NULL);
|
||||||
|
|
||||||
/* Ask to receive events the drawing area doesn't normally
|
/* Ask to receive events the drawing area doesn't normally
|
||||||
* subscribe to. In particular, we need to ask for the
|
* subscribe to. In particular, we need to ask for the
|
||||||
* button press and motion notify events that want to handle.
|
* button press and motion notify events that want to handle.
|
||||||
*/
|
*/
|
||||||
gtk_widget_set_events (da, gtk_widget_get_events (da)
|
gtk_widget_set_events (drawing_area, gtk_widget_get_events (drawing_area)
|
||||||
| GDK_BUTTON_PRESS_MASK
|
| GDK_BUTTON_PRESS_MASK
|
||||||
| GDK_POINTER_MOTION_MASK);
|
| GDK_POINTER_MOTION_MASK);
|
||||||
|
|
||||||
gtk_widget_show_all (window);
|
gtk_widget_show_all (window);
|
||||||
|
}
|
||||||
gtk_main ();
|
|
||||||
|
int
|
||||||
return 0;
|
main (int argc,
|
||||||
|
char **argv)
|
||||||
|
{
|
||||||
|
GtkApplication *app;
|
||||||
|
int status;
|
||||||
|
|
||||||
|
app = gtk_application_new ("org.gtk.example", G_APPLICATION_FLAGS_NONE);
|
||||||
|
g_signal_connect (app, "activate", G_CALLBACK (activate), NULL);
|
||||||
|
status = g_application_run (G_APPLICATION (app), argc, argv);
|
||||||
|
g_object_unref (app);
|
||||||
|
|
||||||
|
return status;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user