summaryrefslogtreecommitdiff
path: root/oox/source/shape/ShapeContextHandler.cxx
diff options
context:
space:
mode:
authorRegina Henschel <rb.henschel@t-online.de>2023-11-19 00:26:16 +0100
committerMiklos Vajna <vmiklos@collabora.com>2023-12-01 08:44:01 +0100
commit44ee19c99bfb3bf0f550d9656e87bca3e20e5ca0 (patch)
tree3c937a4c86ec15400a12fb1e69ae893fc8541d39 /oox/source/shape/ShapeContextHandler.cxx
parenta83088b05f177fb938c2e4ffb06cd19362a5a1ca (diff)
[API CHANGE] Add OOXML way of curved connector routing
The paths generated for curved connectors are basically incompatible between LibreOffice and OOXML. Thus it was not possible to render curved connectors the same way as MS Office. The patch adds an OOXML compatible method for calculating the path. The new method results in a different svg:d attribute when saved in ODF, but needs no change to ODF. The patch introduces the boolean connector property 'EdgeOOXMLCurve' to switch between the two methods. The property value is determined from the svg:d attribute in case of import from ODF. In case of missing svg:d attribute the property value is set to 'true', because Word currently does not write a svg:d attribute when it exports to ODF. The property value is set to 'true' for import of connectors on a drawing canvas in docx. Default value for new connectors is 'false'. The new property has no UI, but can be used via macro. Currently the new method is used for import of curved connectors on drawing canvas in docx documents. Change-Id: I53d99f44febe4d74c2b611f5fdb9de86628c4519 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/159708 Tested-by: Jenkins Reviewed-by: Miklos Vajna <vmiklos@collabora.com>
Diffstat (limited to 'oox/source/shape/ShapeContextHandler.cxx')
-rw-r--r--oox/source/shape/ShapeContextHandler.cxx13
1 files changed, 8 insertions, 5 deletions
diff --git a/oox/source/shape/ShapeContextHandler.cxx b/oox/source/shape/ShapeContextHandler.cxx
index 19c2deb71f57..c012097004e9 100644
--- a/oox/source/shape/ShapeContextHandler.cxx
+++ b/oox/source/shape/ShapeContextHandler.cxx
@@ -537,11 +537,14 @@ ShapeContextHandler::getShape()
{
ConnectorHelper::applyBentHandleAdjustments(rIt.second);
}
- // else use the default path of LibreOffice
- // curvedConnector2 and bentConnector2 do not have handles.
- // ToDo: OOXML defines a path for curveConnector3, curveConnector4 and
- // curveConnector5 that is basically incompatible with the way LibreOffice
- // creates the path.
+ else if (rIt.second->getConnectorName() == u"curvedConnector3"_ustr
+ || rIt.second->getConnectorName() == u"curvedConnector4"_ustr
+ || rIt.second->getConnectorName() == u"curvedConnector5"_ustr)
+ {
+ ConnectorHelper::applyCurvedHandleAdjustments(rIt.second);
+ }
+ // else use the default path of LibreOffice.
+ // curveConnector2 and bentConnector2 do not have handles.
}
}
xResult = pShape->getXShape();