From 19d49df9dbf718f50d4c0b203724782b191e79de Mon Sep 17 00:00:00 2001 From: bulia byak Date: Sun, 22 Oct 2006 21:57:30 +0000 Subject: do not embed transform if it's not translation and the object has a filter (bzr r1837) --- src/sp-item.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'src/sp-item.cpp') diff --git a/src/sp-item.cpp b/src/sp-item.cpp index ff7857e6f..5a138c866 100644 --- a/src/sp-item.cpp +++ b/src/sp-item.cpp @@ -1219,11 +1219,16 @@ sp_item_write_transform(SPItem *item, Inkscape::XML::Node *repr, NR::Matrix cons sp_item_adjust_paint_recursive (item, NR::identity(), NR::identity(), false); } - // run the object's set_transform if transforms are stored optimized and there's no clippath or mask gint preserve = prefs_get_int_attribute("options.preservetransform", "value", 0); NR::Matrix transform_attr (transform); - if (((SPItemClass *) G_OBJECT_GET_CLASS(item))->set_transform - && !preserve && !item->clip_ref->getObject() && !item->mask_ref->getObject()) { + if ( // run the object's set_transform (i.e. embed transform) only if: + ((SPItemClass *) G_OBJECT_GET_CLASS(item))->set_transform && // it does have a set_transform method + !preserve && // user did not chose to preserve all transforms + !item->clip_ref->getObject() && // the object does not have a clippath + !item->mask_ref->getObject() && // the object does not have a mask + !(!transform.is_translation() && SP_OBJECT_STYLE(item) && SP_OBJECT_STYLE(item)->filter.filter) + // the object does not have a filter, or the transform is translation (which is supposed to not affect filters) + ) { transform_attr = ((SPItemClass *) G_OBJECT_GET_CLASS(item))->set_transform(item, transform); } sp_item_set_item_transform(item, transform_attr); -- cgit v1.2.3