diff options
author | Přemysl Eric Janouch <p@janouch.name> | 2021-11-13 13:40:10 +0100 |
---|---|---|
committer | Přemysl Eric Janouch <p@janouch.name> | 2021-11-13 13:40:46 +0100 |
commit | 1f0d6b24d85eeb342a66cebb7c63f8b129c76e2f (patch) | |
tree | 873f6a77364f3f0818b4bcf7b277a57aba345115 /fastiv-browser.c | |
parent | 7d972e933475f61681cbe1a22637b1183309bf64 (diff) | |
download | fiv-1f0d6b24d85eeb342a66cebb7c63f8b129c76e2f.tar.gz fiv-1f0d6b24d85eeb342a66cebb7c63f8b129c76e2f.tar.xz fiv-1f0d6b24d85eeb342a66cebb7c63f8b129c76e2f.zip |
Cache the browser's GDK cursor object
Diffstat (limited to 'fastiv-browser.c')
-rw-r--r-- | fastiv-browser.c | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/fastiv-browser.c b/fastiv-browser.c index 0d183c4..18e2293 100644 --- a/fastiv-browser.c +++ b/fastiv-browser.c @@ -45,6 +45,7 @@ struct _FastivBrowser { GArray *layouted_rows; ///< [Row] int selected; + GdkCursor *pointer; ///< Cached pointer cursor cairo_surface_t *glow; ///< CAIRO_FORMAT_A8 mask int item_border_x; ///< L/R .item margin + border int item_border_y; ///< T/B .item margin + border @@ -285,6 +286,7 @@ fastiv_browser_finalize(GObject *gobject) g_array_free(self->entries, TRUE); g_array_free(self->layouted_rows, TRUE); cairo_surface_destroy(self->glow); + g_clear_object(&self->pointer); G_OBJECT_CLASS(fastiv_browser_parent_class)->finalize(gobject); } @@ -345,6 +347,11 @@ fastiv_browser_realize(GtkWidget *widget) gtk_widget_register_window(widget, window); gtk_widget_set_window(widget, window); gtk_widget_set_realized(widget, TRUE); + + FastivBrowser *self = FASTIV_BROWSER(widget); + g_clear_object(&self->pointer); + self->pointer = + gdk_cursor_new_from_name(gdk_window_get_display(window), "pointer"); } static void @@ -410,14 +417,7 @@ fastiv_browser_motion_notify_event(GtkWidget *widget, GdkEventMotion *event) const Entry *entry = entry_at(self, event->x, event->y); GdkWindow *window = gtk_widget_get_window(widget); - if (entry) { - GdkCursor *cursor = - gdk_cursor_new_from_name(gdk_window_get_display(window), "pointer"); - gdk_window_set_cursor(window, cursor); - g_object_unref(cursor); - } else { - gdk_window_set_cursor(window, NULL); - } + gdk_window_set_cursor(window, entry ? self->pointer : NULL); return TRUE; } |