2015-05-08 00:01:14 +00:00
|
|
|
/* Cursors
|
|
|
|
*
|
2020-06-07 02:05:52 +00:00
|
|
|
* Demonstrates a useful set of available cursors. The cursors shown here are the
|
|
|
|
* ones defined by CSS, which we assume to be available. The example shows creating
|
|
|
|
* cursors by name or from an image, with or without a fallback.
|
2015-05-08 00:01:14 +00:00
|
|
|
*/
|
|
|
|
|
2017-11-04 23:04:23 +00:00
|
|
|
#include <gtk/gtk.h>
|
2015-05-08 00:01:14 +00:00
|
|
|
|
2017-11-04 23:04:23 +00:00
|
|
|
static GtkWidget *window = NULL;
|
2015-05-08 00:01:14 +00:00
|
|
|
|
|
|
|
static void
|
2017-11-04 23:04:23 +00:00
|
|
|
on_destroy (gpointer data)
|
2015-05-08 00:01:14 +00:00
|
|
|
{
|
2017-11-04 23:04:23 +00:00
|
|
|
window = NULL;
|
2015-05-08 00:01:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
GtkWidget *
|
|
|
|
do_cursors (GtkWidget *do_widget)
|
|
|
|
{
|
|
|
|
if (!window)
|
|
|
|
{
|
2017-11-04 23:04:23 +00:00
|
|
|
GtkBuilder *builder;
|
2015-05-08 00:01:14 +00:00
|
|
|
|
2017-11-04 23:04:23 +00:00
|
|
|
builder = gtk_builder_new_from_resource ("/cursors/cursors.ui");
|
|
|
|
window = GTK_WIDGET (gtk_builder_get_object (builder, "window"));
|
2017-10-31 06:41:15 +00:00
|
|
|
gtk_window_set_display (GTK_WINDOW (window),
|
|
|
|
gtk_widget_get_display (do_widget));
|
2015-05-08 00:01:14 +00:00
|
|
|
g_signal_connect (window, "destroy",
|
2017-11-04 23:04:23 +00:00
|
|
|
G_CALLBACK (on_destroy), NULL);
|
2020-05-21 19:41:00 +00:00
|
|
|
g_object_unref (builder);
|
2015-05-08 00:01:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!gtk_widget_get_visible (window))
|
2017-01-19 09:02:04 +00:00
|
|
|
gtk_widget_show (window);
|
2015-05-08 00:01:14 +00:00
|
|
|
else
|
2017-11-04 23:04:23 +00:00
|
|
|
{
|
2020-05-09 14:26:22 +00:00
|
|
|
gtk_window_destroy (GTK_WINDOW (window));
|
2017-11-04 23:04:23 +00:00
|
|
|
}
|
2015-05-08 00:01:14 +00:00
|
|
|
|
|
|
|
return window;
|
|
|
|
}
|