iconhelper: always ensure a stated pixbuf
Even when we are set a pixbuf itself. https://bugzilla.gnome.org/show_bug.cgi?id=726271
This commit is contained in:
parent
19510cdec7
commit
b0a0b7ebe7
@ -388,6 +388,7 @@ ensure_pixbuf_at_size (GtkIconHelper *self,
|
|||||||
GtkStyleContext *context)
|
GtkStyleContext *context)
|
||||||
{
|
{
|
||||||
gint width, height;
|
gint width, height;
|
||||||
|
GdkPixbuf *stated;
|
||||||
|
|
||||||
if (!check_invalidate_pixbuf (self, context))
|
if (!check_invalidate_pixbuf (self, context))
|
||||||
return;
|
return;
|
||||||
@ -427,6 +428,10 @@ ensure_pixbuf_at_size (GtkIconHelper *self,
|
|||||||
|
|
||||||
if (!self->priv->rendered_pixbuf)
|
if (!self->priv->rendered_pixbuf)
|
||||||
self->priv->rendered_pixbuf = g_object_ref (self->priv->orig_pixbuf);
|
self->priv->rendered_pixbuf = g_object_ref (self->priv->orig_pixbuf);
|
||||||
|
|
||||||
|
stated = ensure_stated_pixbuf_from_pixbuf (self, context, self->priv->rendered_pixbuf);
|
||||||
|
g_object_unref (self->priv->rendered_pixbuf);
|
||||||
|
self->priv->rendered_pixbuf = stated;
|
||||||
}
|
}
|
||||||
|
|
||||||
GdkPixbuf *
|
GdkPixbuf *
|
||||||
@ -545,7 +550,7 @@ ensure_surface_from_pixbuf (GtkIconHelper *self,
|
|||||||
GtkStyleContext *context)
|
GtkStyleContext *context)
|
||||||
{
|
{
|
||||||
gint width, height;
|
gint width, height;
|
||||||
GdkPixbuf *pixbuf;
|
GdkPixbuf *pixbuf, *stated;
|
||||||
int scale;
|
int scale;
|
||||||
|
|
||||||
if (!check_invalidate_surface (self, context))
|
if (!check_invalidate_surface (self, context))
|
||||||
@ -585,6 +590,10 @@ ensure_surface_from_pixbuf (GtkIconHelper *self,
|
|||||||
scale = self->priv->orig_pixbuf_scale;
|
scale = self->priv->orig_pixbuf_scale;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stated = ensure_stated_pixbuf_from_pixbuf (self, context, pixbuf);
|
||||||
|
g_object_unref (pixbuf);
|
||||||
|
pixbuf = stated;
|
||||||
|
|
||||||
self->priv->rendered_surface_width = (gdk_pixbuf_get_width (pixbuf) + scale - 1) / scale;
|
self->priv->rendered_surface_width = (gdk_pixbuf_get_width (pixbuf) + scale - 1) / scale;
|
||||||
self->priv->rendered_surface_height = (gdk_pixbuf_get_height (pixbuf) + scale - 1) / scale;
|
self->priv->rendered_surface_height = (gdk_pixbuf_get_height (pixbuf) + scale - 1) / scale;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user