[mutter/wip/cairo: 8/15] theme: Use cairo for drawing uncolorized IMAGEs
- From: Jasper St. Pierre <jstpierre src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/wip/cairo: 8/15] theme: Use cairo for drawing uncolorized IMAGEs
- Date: Mon, 9 Apr 2012 06:42:02 +0000 (UTC)
commit ce93785442508b52013c11bf68f2ebb680257dbc
Author: Jasper St. Pierre <jstpierre mecheye net>
Date: Fri Oct 28 22:02:18 2011 -0400
theme: Use cairo for drawing uncolorized IMAGEs
https://bugzilla.gnome.org/show_bug.cgi?id=662962
src/ui/theme.c | 29 ++++++++++++++++++++---------
1 files changed, 20 insertions(+), 9 deletions(-)
---
diff --git a/src/ui/theme.c b/src/ui/theme.c
index 3e89f42..4f5ee36 100644
--- a/src/ui/theme.c
+++ b/src/ui/theme.c
@@ -3774,21 +3774,32 @@ meta_draw_op_draw_with_env (const MetaDrawOp *op,
env->object_height = gdk_pixbuf_get_height (op->data.image.pixbuf);
}
+ rx = parse_x_position_unchecked (op->data.image.x, env);
+ ry = parse_y_position_unchecked (op->data.image.y, env);
+
rwidth = parse_size_unchecked (op->data.image.width, env);
rheight = parse_size_unchecked (op->data.image.height, env);
-
- pixbuf = draw_op_as_pixbuf (op, style_gtk, info,
- rwidth, rheight);
- if (pixbuf)
+ if (op->data.image.pixbuf != NULL &&
+ op->data.image.colorize_spec == NULL)
+ {
+ draw_image (cr,
+ op->data.image.pixbuf,
+ op->data.image.fill_type,
+ rx, ry, rwidth, rheight);
+ }
+ else if (op->data.image.colorize_spec != NULL)
{
- rx = parse_x_position_unchecked (op->data.image.x, env);
- ry = parse_y_position_unchecked (op->data.image.y, env);
+ pixbuf = draw_op_as_pixbuf (op, style_gtk, info,
+ rwidth, rheight);
- gdk_cairo_set_source_pixbuf (cr, pixbuf, rx, ry);
- cairo_paint (cr);
+ if (pixbuf)
+ {
+ gdk_cairo_set_source_pixbuf (cr, pixbuf, rx, ry);
+ cairo_paint (cr);
- g_object_unref (G_OBJECT (pixbuf));
+ g_object_unref (G_OBJECT (pixbuf));
+ }
}
}
break;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]