[libgxps/wip/nacho/res-sep: 2/2] Add initial support for brush resources
- From: Ignacio Casal Quinteiro <icq src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libgxps/wip/nacho/res-sep: 2/2] Add initial support for brush resources
- Date: Tue, 31 Jan 2017 08:40:07 +0000 (UTC)
commit b6c680d81e0be402f0b12821dc542718efc0fbbc
Author: Ignacio Casal Quinteiro <ignacio casal nice-software com>
Date: Thu Jan 26 16:46:51 2017 +0100
Add initial support for brush resources
For now only the Fill tag in the Path is handled.
https://bugzilla.gnome.org/show_bug.cgi?id=742630
libgxps/gxps-page.c | 17 +++++++++++++++--
1 files changed, 15 insertions(+), 2 deletions(-)
---
diff --git a/libgxps/gxps-page.c b/libgxps/gxps-page.c
index a82021b..675b9a1 100644
--- a/libgxps/gxps-page.c
+++ b/libgxps/gxps-page.c
@@ -412,6 +412,12 @@ resource_start_element (GMarkupParseContext *context,
GXPSPath *path = (GXPSPath *)user_data;
gxps_path_parser_push (context, path);
+ } else if (g_str_has_suffix (element_name, "Brush")) {
+ GXPSPath *path = (GXPSPath *)user_data;
+ GXPSBrush *brush;
+
+ brush = gxps_brush_new (path->ctx);
+ gxps_brush_parser_push (context, brush);
}
}
@@ -423,6 +429,12 @@ resource_end_element (GMarkupParseContext *context,
{
if (strcmp (element_name, "Resource.PathGeometry") == 0) {
g_markup_parse_context_pop (context);
+ } else if (g_str_has_suffix (element_name, "Brush")) {
+ GXPSPath *path = (GXPSPath *)user_data;
+ GXPSBrush *brush = g_markup_parse_context_pop (context);
+
+ path->fill_pattern = cairo_pattern_reference (brush->pattern);
+ gxps_brush_free (brush);
}
}
@@ -518,8 +530,8 @@ render_start_element (GMarkupParseContext *context,
} else if (strcmp (names[i], "Clip") == 0) {
path->clip_data = g_strdup (values[i]);
} else if (strcmp (names[i], "Fill") == 0) {
- GXPS_DEBUG (g_message ("set_fill_pattern (solid)"));
- if (!gxps_brush_solid_color_parse (values[i], ctx->page->priv->zip, 1.,
&path->fill_pattern)) {
+ if (!expand_resource (ctx->page, values[i], path) &&
+ !gxps_brush_solid_color_parse (values[i], ctx->page->priv->zip, 1.,
&path->fill_pattern)) {
gxps_parse_error (context,
ctx->page->priv->source,
G_MARKUP_ERROR_INVALID_CONTENT,
@@ -527,6 +539,7 @@ render_start_element (GMarkupParseContext *context,
gxps_path_free (path);
return;
}
+ GXPS_DEBUG (g_message ("set_fill_pattern (solid)"));
} else if (strcmp (names[i], "Stroke") == 0) {
GXPS_DEBUG (g_message ("set_stroke_pattern (solid)"));
if (!gxps_brush_solid_color_parse (values[i], ctx->page->priv->zip, 1.,
&path->stroke_pattern)) {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]