summaryrefslogtreecommitdiff
path: root/svgio/source/svgreader
diff options
context:
space:
mode:
Diffstat (limited to 'svgio/source/svgreader')
-rw-r--r--svgio/source/svgreader/svgmarkernode.cxx3
-rw-r--r--svgio/source/svgreader/svgstyleattributes.cxx169
2 files changed, 95 insertions, 77 deletions
diff --git a/svgio/source/svgreader/svgmarkernode.cxx b/svgio/source/svgreader/svgmarkernode.cxx
index 2279920634a6..c2e1f2716ab9 100644
--- a/svgio/source/svgreader/svgmarkernode.cxx
+++ b/svgio/source/svgreader/svgmarkernode.cxx
@@ -33,7 +33,8 @@ namespace svgio::svgreader
maMarkerWidth(3),
maMarkerHeight(3),
mfAngle(0.0),
- maMarkerOrient(MarkerOrient::notset)
+ maMarkerOrient(MarkerOrient::notset),
+ maContextStyleAttibutes(nullptr)
{
}
diff --git a/svgio/source/svgreader/svgstyleattributes.cxx b/svgio/source/svgreader/svgstyleattributes.cxx
index 5fe78f8b58d0..c3dbdaacea47 100644
--- a/svgio/source/svgreader/svgstyleattributes.cxx
+++ b/svgio/source/svgreader/svgstyleattributes.cxx
@@ -259,6 +259,23 @@ namespace svgio::svgreader
return nullptr;
}
+ const SvgMarkerNode* SvgStyleAttributes::getMarkerParentNode() const
+ {
+ if (SVGToken::Marker == mrOwner.getType())
+ return static_cast<const SvgMarkerNode *>(&mrOwner);
+
+ const SvgStyleAttributes* pSvgStyleAttributes = getParentStyle();
+ if (pSvgStyleAttributes && maResolvingParent[32] < nStyleDepthLimit)
+ {
+ ++maResolvingParent[32];
+ const SvgMarkerNode* ret = pSvgStyleAttributes->getMarkerParentNode();
+ --maResolvingParent[32];
+ return ret;
+ }
+
+ return nullptr;
+ }
+
void SvgStyleAttributes::add_text(
drawinglayer::primitive2d::Primitive2DContainer& rTarget,
drawinglayer::primitive2d::Primitive2DContainer&& rSource) const
@@ -600,9 +617,36 @@ namespace svgio::svgreader
drawinglayer::primitive2d::Primitive2DContainer& rTarget,
const basegfx::B2DRange& rGeoRange) const
{
- const basegfx::BColor* pFill = getFill();
- const SvgGradientNode* pFillGradient = getSvgGradientNodeFill();
- const SvgPatternNode* pFillPattern = getSvgPatternNodeFill();
+ const basegfx::BColor* pFill = nullptr;
+ const SvgGradientNode* pFillGradient = nullptr;
+ const SvgPatternNode* pFillPattern = nullptr;
+
+ if (mbUseFillFromContextFill)
+ {
+ if (const SvgMarkerNode* pMarker = getMarkerParentNode())
+ {
+ const SvgStyleAttributes* pStyle = pMarker->getContextStyleAttributes();
+ pFill = pStyle->getFill();
+ pFillGradient = pStyle->getSvgGradientNodeFill();
+ pFillPattern = pStyle->getSvgPatternNodeFill();
+ }
+ }
+ else if (mbUseFillFromContextStroke)
+ {
+ if (const SvgMarkerNode* pMarker = getMarkerParentNode())
+ {
+ const SvgStyleAttributes* pStyle = pMarker->getContextStyleAttributes();
+ pFill = pStyle->getStroke();
+ pFillGradient = pStyle->getSvgGradientNodeStroke();
+ pFillPattern = pStyle->getSvgPatternNodeStroke();
+ }
+ }
+ else
+ {
+ pFill = getFill();
+ pFillGradient = getSvgGradientNodeFill();
+ pFillPattern = getSvgPatternNodeFill();
+ }
if(!(pFill || pFillGradient || pFillPattern))
return;
@@ -656,9 +700,36 @@ namespace svgio::svgreader
drawinglayer::primitive2d::Primitive2DContainer& rTarget,
const basegfx::B2DRange& rGeoRange) const
{
- const basegfx::BColor* pStroke = getStroke();
- const SvgGradientNode* pStrokeGradient = getSvgGradientNodeStroke();
- const SvgPatternNode* pStrokePattern = getSvgPatternNodeStroke();
+ const basegfx::BColor* pStroke = nullptr;
+ const SvgGradientNode* pStrokeGradient = nullptr;
+ const SvgPatternNode* pStrokePattern = nullptr;
+
+ if(mbUseStrokeFromContextFill)
+ {
+ if (const SvgMarkerNode* pMarker = getMarkerParentNode())
+ {
+ const SvgStyleAttributes* pStyle = pMarker->getContextStyleAttributes();
+ pStroke = pStyle->getFill();
+ pStrokeGradient = pStyle->getSvgGradientNodeFill();
+ pStrokePattern = pStyle->getSvgPatternNodeFill();
+ }
+ }
+ else if(mbUseStrokeFromContextStroke)
+ {
+ if (const SvgMarkerNode* pMarker = getMarkerParentNode())
+ {
+ const SvgStyleAttributes* pStyle = pMarker->getContextStyleAttributes();
+ pStroke = pStyle->getStroke();
+ pStrokeGradient = pStyle->getSvgGradientNodeStroke();
+ pStrokePattern = pStyle->getSvgPatternNodeStroke();
+ }
+ }
+ else
+ {
+ pStroke = getStroke();
+ pStrokeGradient = getSvgGradientNodeStroke();
+ pStrokePattern = getSvgPatternNodeStroke();
+ }
if(!(pStroke || pStrokeGradient || pStrokePattern))
return;
@@ -823,15 +894,11 @@ namespace svgio::svgreader
rMarkerTransform.identity();
rClipRange.reset();
- // Set the current fill to the marker before calling getMarkerPrimitives,
- // which calls decomposeSvgNode to decompose the children of the marker.
- // If any of the children uses 'fill="context-fill"', then it will use it
- const_cast<SvgStyleAttributes*>(rMarker.getSvgStyleAttributes())->maContextFill = getFill();
-
- // Set the current stroke to the marker before calling getMarkerPrimitives,
+ // Set the current style attibutes to the marker before calling getMarkerPrimitives,
// which calls decomposeSvgNode to decompose the children of the marker.
- // If any of the children uses 'stroke="context-stroke"', then it will use it
- const_cast<SvgStyleAttributes*>(rMarker.getSvgStyleAttributes())->maContextStroke = getStroke();
+ // If any children uses 'context-fill' or 'context-stroke',
+ // then these style attributes will be used in add_fill or add_stroke
+ const_cast<SvgMarkerNode&>(rMarker).setContextStyleAttributes(this);
// get marker primitive representation
rMarkerPrimitives = rMarker.getMarkerPrimitives();
@@ -1320,12 +1387,12 @@ namespace svgio::svgreader
maBaselineShift(BaselineShift::Baseline),
maBaselineShiftNumber(0),
maDominantBaseline(DominantBaseline::Auto),
- maResolvingParent(35, 0),
+ maResolvingParent(34, 0),
mbStrokeDasharraySet(false),
- mbContextFill(false),
- mbContextStroke(false),
- maContextFill(nullptr),
- maContextStroke(nullptr)
+ mbUseFillFromContextFill(false),
+ mbUseFillFromContextStroke(false),
+ mbUseStrokeFromContextFill(false),
+ mbUseStrokeFromContextStroke(false)
{
}
@@ -1347,11 +1414,11 @@ namespace svgio::svgreader
if(o3tl::equalsIgnoreAsciiCase(o3tl::trim(aContent), u"context-fill"))
{
- mbContextFill = true;
+ mbUseFillFromContextFill = true;
}
else if(o3tl::equalsIgnoreAsciiCase(o3tl::trim(aContent), u"context-stroke"))
{
- mbContextStroke = true;
+ mbUseFillFromContextStroke = true;
}
else if(readSvgPaint(aContent, aSvgPaint, aURL, aOpacity))
{
@@ -1400,11 +1467,11 @@ namespace svgio::svgreader
if(o3tl::equalsIgnoreAsciiCase(o3tl::trim(aContent), u"context-stroke"))
{
- mbContextStroke = true;
+ mbUseStrokeFromContextStroke = true;
}
else if(o3tl::equalsIgnoreAsciiCase(o3tl::trim(aContent), u"context-fill"))
{
- mbContextFill = true;
+ mbUseStrokeFromContextFill = true;
}
else if(readSvgPaint(aContent, aSvgPaint, aURL, aOpacity))
{
@@ -2049,40 +2116,6 @@ namespace svgio::svgreader
}
}
- const basegfx::BColor* SvgStyleAttributes::getContextFill() const
- {
- if (SVGToken::Marker == mrOwner.getType())
- return maContextFill;
-
- const SvgStyleAttributes* pSvgStyleAttributes = getParentStyle();
- if (pSvgStyleAttributes && maResolvingParent[33] < nStyleDepthLimit)
- {
- ++maResolvingParent[33];
- auto ret = pSvgStyleAttributes->getContextFill();
- --maResolvingParent[33];
- return ret;
- }
-
- return nullptr;
- }
-
- const basegfx::BColor* SvgStyleAttributes::getContextStroke() const
- {
- if (SVGToken::Marker == mrOwner.getType())
- return maContextStroke;
-
- const SvgStyleAttributes* pSvgStyleAttributes = getParentStyle();
- if (pSvgStyleAttributes && maResolvingParent[32] < nStyleDepthLimit)
- {
- ++maResolvingParent[32];
- auto ret = pSvgStyleAttributes->getContextStroke();
- --maResolvingParent[32];
- return ret;
- }
-
- return nullptr;
- }
-
bool SvgStyleAttributes::isClipPathContent() const
{
if (SVGToken::ClipPathNode == mrOwner.getType())
@@ -2151,14 +2184,6 @@ namespace svgio::svgreader
}
}
}
- else if (mbContextFill)
- {
- return getContextFill();
- }
- else if (mbContextStroke)
- {
- return getContextStroke();
- }
else if (maNodeFillURL.isEmpty())
{
const SvgStyleAttributes* pSvgStyleAttributes = getParentStyle();
@@ -2204,14 +2229,6 @@ namespace svgio::svgreader
return &maStroke.getBColor();
}
}
- else if (mbContextFill)
- {
- return getContextFill();
- }
- else if (mbContextStroke)
- {
- return getContextStroke();
- }
else if (maNodeStrokeURL.isEmpty())
{
const SvgStyleAttributes* pSvgStyleAttributes = getParentStyle();
@@ -2430,11 +2447,11 @@ namespace svgio::svgreader
const SvgStyleAttributes* pSvgStyleAttributes = getParentStyle();
- if (pSvgStyleAttributes && maResolvingParent[34] < nStyleDepthLimit)
+ if (pSvgStyleAttributes && maResolvingParent[33] < nStyleDepthLimit)
{
- ++maResolvingParent[34];
+ ++maResolvingParent[33];
auto ret = pSvgStyleAttributes->getOpacity();
- --maResolvingParent[34];
+ --maResolvingParent[33];
return ret;
}