X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=gtk%2Fgtkimage.c;h=d373b51b709d81586f61af595b9504d836775b3e;hb=6f1476edd3fbe31259e59ca3f03a01bf0f8ff67b;hp=5b0ae66f984de9b467f5d3673f986778181527ce;hpb=86f024ba0dda1c18ef45af923e5b742b193b4da1;p=~andy%2Fgtk diff --git a/gtk/gtkimage.c b/gtk/gtkimage.c index 5b0ae66f9..d373b51b7 100644 --- a/gtk/gtkimage.c +++ b/gtk/gtkimage.c @@ -815,8 +815,7 @@ gtk_image_set_from_resource (GtkImage *image, const gchar *resource_path) { GtkImagePrivate *priv; - GdkPixbuf *pixbuf = NULL; - GInputStream *stream; + GdkPixbufAnimation *animation; g_return_if_fail (GTK_IS_IMAGE (image)); @@ -832,14 +831,9 @@ gtk_image_set_from_resource (GtkImage *image, return; } - stream = g_resources_open_stream (resource_path, 0, NULL); - if (stream != NULL) - { - pixbuf = gdk_pixbuf_new_from_stream (stream, NULL, NULL); - g_object_unref (stream); - } + animation = gdk_pixbuf_animation_new_from_resource (resource_path, NULL); - if (pixbuf == NULL) + if (animation == NULL) { gtk_image_set_from_stock (image, GTK_STOCK_MISSING_IMAGE, @@ -850,11 +844,14 @@ gtk_image_set_from_resource (GtkImage *image, priv->resource_path = g_strdup (resource_path); - gtk_image_set_from_pixbuf (image, pixbuf); + if (gdk_pixbuf_animation_is_static_image (animation)) + gtk_image_set_from_pixbuf (image, gdk_pixbuf_animation_get_static_image (animation)); + else + gtk_image_set_from_animation (image, animation); g_object_notify (G_OBJECT (image), "resource"); - g_object_unref (pixbuf); + g_object_unref (animation); g_object_thaw_notify (G_OBJECT (image)); }