diff options
author | Regina Henschel <rb.henschel@t-online.de> | 2023-11-19 00:26:16 +0100 |
---|---|---|
committer | Miklos Vajna <vmiklos@collabora.com> | 2023-12-01 08:44:01 +0100 |
commit | 44ee19c99bfb3bf0f550d9656e87bca3e20e5ca0 (patch) | |
tree | 3c937a4c86ec15400a12fb1e69ae893fc8541d39 /oox/source/shape/ShapeContextHandler.cxx | |
parent | a83088b05f177fb938c2e4ffb06cd19362a5a1ca (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.cxx | 13 |
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(); |