summaryrefslogtreecommitdiffstats
path: root/src/live_effects/lpe-clone-original.cpp
diff options
context:
space:
mode:
authorJabier Arraiza Cenoz <jabier.arraiza@marker.es>2017-01-25 14:36:46 +0000
committerjabiertxof <info@marker.es>2017-01-25 14:36:46 +0000
commit3400a57bdeae2cdbfaa47acc19978507f18574ae (patch)
tree46ca961bfed8dbe1377cf73c22a416bb33ad9d4f /src/live_effects/lpe-clone-original.cpp
parentRetain clone position in clone Original LPE (diff)
downloadinkscape-3400a57bdeae2cdbfaa47acc19978507f18574ae.tar.gz
inkscape-3400a57bdeae2cdbfaa47acc19978507f18574ae.zip
A bit refactor of clone object LPE
(bzr r15448)
Diffstat (limited to 'src/live_effects/lpe-clone-original.cpp')
-rw-r--r--src/live_effects/lpe-clone-original.cpp34
1 files changed, 12 insertions, 22 deletions
diff --git a/src/live_effects/lpe-clone-original.cpp b/src/live_effects/lpe-clone-original.cpp
index e70575986..04db6171e 100644
--- a/src/live_effects/lpe-clone-original.cpp
+++ b/src/live_effects/lpe-clone-original.cpp
@@ -258,28 +258,18 @@ LPECloneOriginal::doBeforeEffect (SPLPEItem const* lpeitem){
style_attr.erase (style_attr.size()-1, 1);
}
style_attr.append(Glib::ustring(style_attributes.param_getSVGValue()).append(","));
- if (inverse) {
- cloneAttrbutes(SP_OBJECT(sp_lpe_item), linked_item.getObject(), true, g_strdup(attr.c_str()), g_strdup(style_attr.c_str()), true);
- Geom::OptRect bbox = SP_ITEM(sp_lpe_item)->geometricBounds();
- if (bbox && preserve_position && origin != Geom::Point(0,0)) {
- origin = (*bbox).corner(0) - origin;
- SP_ITEM(linked_item.getObject())->transform *= Geom::Translate(origin);
- }
- bbox = SP_ITEM(sp_lpe_item)->geometricBounds();
- if (bbox && preserve_position) {
- origin = (*bbox).corner(0);
- }
- } else {
- cloneAttrbutes(linked_item.getObject(), SP_OBJECT(sp_lpe_item), true, g_strdup(attr.c_str()), g_strdup(style_attr.c_str()), true);
- Geom::OptRect bbox = SP_ITEM(linked_item.getObject())->geometricBounds();
- if (bbox && preserve_position && origin != Geom::Point(0,0)) {
- origin = (*bbox).corner(0) - origin;
- SP_ITEM(sp_lpe_item)->transform *= Geom::Translate(origin);
- }
- bbox = SP_ITEM(linked_item.getObject())->geometricBounds();
- if (bbox && preserve_position) {
- origin = (*bbox).corner(0);
- }
+
+ SPItem * from = inverse ? SP_ITEM(sp_lpe_item) : SP_ITEM(linked_item.getObject());
+ SPItem * to = !inverse ? SP_ITEM(sp_lpe_item) : SP_ITEM(linked_item.getObject());
+ cloneAttrbutes(from, to, true, g_strdup(attr.c_str()), g_strdup(style_attr.c_str()), true);
+ Geom::OptRect bbox = from->geometricBounds();
+ if (bbox && preserve_position && origin != Geom::Point(0,0)) {
+ origin = (*bbox).corner(0) - origin;
+ to->transform *= Geom::Translate(origin);
+ }
+ bbox = from->geometricBounds();
+ if (bbox && preserve_position) {
+ origin = (*bbox).corner(0);
}
}
}