X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c49ba2113c3788115ec7134d2a5f37d0f4776c88..fb8d7eb7a880f1f2e32d8830f9c5e12b2536e05f:/src/gtk/artgtk.cpp diff --git a/src/gtk/artgtk.cpp b/src/gtk/artgtk.cpp index 533eab7619..b29c33dda5 100644 --- a/src/gtk/artgtk.cpp +++ b/src/gtk/artgtk.cpp @@ -205,7 +205,16 @@ GdkPixbuf *CreateStockIcon(const char *stockid, GtkIconSize size) // with "stock-id" representation (in addition to pixmap and pixbuf // ones) and would convert it to pixbuf when rendered. - GtkStyle* style = gtk_widget_get_style(wxGTKPrivate::GetButtonWidget()); + GtkWidget* widget = wxGTKPrivate::GetButtonWidget(); +#ifdef __WXGTK3__ + GtkStyleContext* sc = gtk_widget_get_style_context(widget); + GtkIconSet* iconset = gtk_style_context_lookup_icon_set(sc, stockid); + GdkPixbuf* pixbuf = NULL; + if (iconset) + pixbuf = gtk_icon_set_render_icon_pixbuf(iconset, sc, size); + return pixbuf; +#else + GtkStyle* style = gtk_widget_get_style(widget); GtkIconSet* iconset = gtk_style_lookup_icon_set(style, stockid); if (!iconset) @@ -214,6 +223,7 @@ GdkPixbuf *CreateStockIcon(const char *stockid, GtkIconSize size) return gtk_icon_set_render_icon(iconset, style, gtk_widget_get_default_direction(), GTK_STATE_NORMAL, size, NULL, NULL); +#endif } GdkPixbuf *CreateThemeIcon(const char *iconname, int size) @@ -309,8 +319,14 @@ wxGTK2ArtProvider::CreateIconBundle(const wxArtID& id, const wxString stockid = wxArtIDToStock(id); // try to load the bundle as stock icon first - GtkStyle* style = gtk_widget_get_style(wxGTKPrivate::GetButtonWidget()); + GtkWidget* widget = wxGTKPrivate::GetButtonWidget(); +#ifdef __WXGTK3__ + GtkStyleContext* sc = gtk_widget_get_style_context(widget); + GtkIconSet* iconset = gtk_style_context_lookup_icon_set(sc, stockid.utf8_str()); +#else + GtkStyle* style = gtk_widget_get_style(widget); GtkIconSet* iconset = gtk_style_lookup_icon_set(style, stockid.utf8_str()); +#endif if ( iconset ) { GtkIconSize *sizes;