[Libreoffice-commits] core.git: Branch 'private/swe/libreoffice-5-2+backports' - 2 commits - drawinglayer/source include/svx svx/source sw/source
Armin Le Grand
Armin.Le.Grand at cib.de
Mon Sep 18 14:56:49 UTC 2017
drawinglayer/source/primitive2d/borderlineprimitive2d.cxx | 121 ++++-
include/svx/framelink.hxx | 82 +++
svx/source/dialog/framelink.cxx | 320 ++++++--------
svx/source/dialog/framelinkarray.cxx | 78 +--
svx/source/table/viewcontactoftableobj.cxx | 20
sw/source/core/layout/paintfrm.cxx | 46 +-
6 files changed, 417 insertions(+), 250 deletions(-)
New commits:
commit 5a11b5cc191ebe90e23cab9f101c4d5a601c0eac
Author: Armin Le Grand <Armin.Le.Grand at cib.de>
Date: Mon Sep 18 16:54:43 2017 +0200
borderline: Added missing BorderLinePrimitive2D::create2DDecomposition
Was somehow lost in adaption to lo52, added now
Change-Id: I0759a9d36343b4d830047162389f28d0db379305
diff --git a/drawinglayer/source/primitive2d/borderlineprimitive2d.cxx b/drawinglayer/source/primitive2d/borderlineprimitive2d.cxx
index 11926329ebc2..413d1bdd51c9 100644
--- a/drawinglayer/source/primitive2d/borderlineprimitive2d.cxx
+++ b/drawinglayer/source/primitive2d/borderlineprimitive2d.cxx
@@ -159,15 +159,118 @@ namespace drawinglayer
if(!candidate.isGap())
{
const basegfx::B2DVector aDeltaY(aPerpendicular * (fOffset + (fWidth * 0.5)));
- const basegfx::B2DPoint aStart(getStart() - (aVector * candidate.getStartAverage()) + aDeltaY);
- const basegfx::B2DPoint aEnd(getEnd() + (aVector * candidate.getEndAverage()) + aDeltaY);
-
- addPolygonStrokePrimitive2D(
- aContainer,
- aStart,
- aEnd,
- candidate.getLineAttribute(),
- getStrokeAttribute());
+ const basegfx::B2DPoint aStart(getStart() + aDeltaY);
+ const basegfx::B2DPoint aEnd(getEnd() + aDeltaY);
+ const bool bStartPerpendicular(rtl::math::approxEqual(candidate.getStartLeft(), candidate.getStartRight()));
+ const bool bEndPerpendicular(rtl::math::approxEqual(candidate.getEndLeft(), candidate.getEndRight()));
+
+ if(bStartPerpendicular && bEndPerpendicular)
+ {
+ // start and end extends lead to an edge perpendicular to the line, so we can just use
+ // a PolygonStrokePrimitive2D for representation
+ addPolygonStrokePrimitive2D(
+ aContainer,
+ aStart - (aVector * candidate.getStartLeft()),
+ aEnd + (aVector * candidate.getEndLeft()),
+ candidate.getLineAttribute(),
+ getStrokeAttribute());
+ }
+ else
+ {
+ // start and/or end extensions lead to a lineStart/End that is *not*
+ // perpendicular to the line itself
+ if(getStrokeAttribute().isDefault() || 0.0 == getStrokeAttribute().getFullDotDashLen())
+ {
+ // without stroke, we can simply represent that using a filled polygon
+ const basegfx::B2DVector aHalfLineOffset(aPerpendicular * (candidate.getLineAttribute().getWidth() * 0.5));
+ basegfx::B2DPolygon aPolygon;
+
+ aPolygon.append(aStart - aHalfLineOffset - (aVector * candidate.getStartLeft()));
+ aPolygon.append(aEnd - aHalfLineOffset + (aVector * candidate.getEndLeft()));
+ aPolygon.append(aEnd + aHalfLineOffset + (aVector * candidate.getEndRight()));
+ aPolygon.append(aStart + aHalfLineOffset - (aVector * candidate.getStartRight()));
+
+ aContainer.push_back(
+ new PolyPolygonColorPrimitive2D(
+ basegfx::B2DPolyPolygon(aPolygon),
+ candidate.getLineAttribute().getColor()));
+ }
+ else
+ {
+ // with stroke, we have a problem - a filled polygon would lose the
+ // stroke. Let's represent the start and/or end as triangles, the main
+ // line still as PolygonStrokePrimitive2D.
+ // Fill default line Start/End for stroke, so we need no adaptions in else paths
+ basegfx::B2DPoint aStrokeStart(aStart - (aVector * candidate.getStartLeft()));
+ basegfx::B2DPoint aStrokeEnd(aEnd + (aVector * candidate.getEndLeft()));
+ const basegfx::B2DVector aHalfLineOffset(aPerpendicular * (candidate.getLineAttribute().getWidth() * 0.5));
+
+ if(!bStartPerpendicular)
+ {
+ const double fMin(std::min(candidate.getStartLeft(), candidate.getStartRight()));
+ const double fMax(std::max(candidate.getStartLeft(), candidate.getStartRight()));
+ basegfx::B2DPolygon aPolygon;
+
+ // create a triangle with min/max values for LineStart and add
+ if(rtl::math::approxEqual(candidate.getStartLeft(), fMax))
+ {
+ aPolygon.append(aStart - aHalfLineOffset - (aVector * candidate.getStartLeft()));
+ }
+
+ aPolygon.append(aStart - aHalfLineOffset - (aVector * fMin));
+ aPolygon.append(aStart + aHalfLineOffset - (aVector * fMin));
+
+ if(rtl::math::approxEqual(candidate.getStartRight(), fMax))
+ {
+ aPolygon.append(aStart + aHalfLineOffset - (aVector * candidate.getStartRight()));
+ }
+
+ aContainer.push_back(
+ new PolyPolygonColorPrimitive2D(
+ basegfx::B2DPolyPolygon(aPolygon),
+ candidate.getLineAttribute().getColor()));
+
+ // Adapt StrokeStart accordingly
+ aStrokeStart = aStart - (aVector * fMin);
+ }
+
+ if(!bEndPerpendicular)
+ {
+ const double fMin(std::min(candidate.getEndLeft(), candidate.getEndRight()));
+ const double fMax(std::max(candidate.getEndLeft(), candidate.getEndRight()));
+ basegfx::B2DPolygon aPolygon;
+
+ // create a triangle with min/max values for LineEnd and add
+ if(rtl::math::approxEqual(candidate.getEndLeft(), fMax))
+ {
+ aPolygon.append(aEnd - aHalfLineOffset + (aVector * candidate.getEndLeft()));
+ }
+
+ if(rtl::math::approxEqual(candidate.getEndRight(), fMax))
+ {
+ aPolygon.append(aEnd + aHalfLineOffset + (aVector * candidate.getEndRight()));
+ }
+
+ aPolygon.append(aEnd + aHalfLineOffset + (aVector * fMin));
+ aPolygon.append(aEnd - aHalfLineOffset + (aVector * fMin));
+
+ aContainer.push_back(
+ new PolyPolygonColorPrimitive2D(
+ basegfx::B2DPolyPolygon(aPolygon),
+ candidate.getLineAttribute().getColor()));
+
+ // Adapt StrokeEnd accordingly
+ aStrokeEnd = aEnd + (aVector * fMin);
+ }
+
+ addPolygonStrokePrimitive2D(
+ aContainer,
+ aStrokeStart,
+ aStrokeEnd,
+ candidate.getLineAttribute(),
+ getStrokeAttribute());
+ }
+ }
}
fOffset += fWidth;
commit 1e730a4870b1ef3af80f0ce15334dff839e3e37b
Author: Armin Le Grand <Armin.Le.Grand at cib.de>
Date: Mon Sep 18 12:31:45 2017 +0200
borderline: restuctured used classes
Restructuring for more efficcient usage of helper
values, some obstacles removed with that
Change-Id: Ia8c4b2d4c423db9500cda507107d87913b79e23c
Reviewed-on: https://gerrit.libreoffice.org/42409
Reviewed-by: Armin Le Grand <Armin.Le.Grand at cib.de>
Tested-by: Armin Le Grand <Armin.Le.Grand at cib.de>
diff --git a/include/svx/framelink.hxx b/include/svx/framelink.hxx
index 2e7fb0534cab..a851e39c6e44 100644
--- a/include/svx/framelink.hxx
+++ b/include/svx/framelink.hxx
@@ -214,29 +214,87 @@ public:
inline bool operator>( const Style& rL, const Style& rR ) { return rR.operator<(rL); }
// Drawing functions
-
class SAL_WARN_UNUSED SVX_DLLPUBLIC StyleVectorCombination
{
private:
- const Style& mrStyle;
- const basegfx::B2DVector maB2DVector;
- const bool mbMirrored;
+ struct OffsetAndHalfWidthAndColor
+ {
+ double mfOffset;
+ double mfHalfWidth;
+ Color maColor;
+
+ OffsetAndHalfWidthAndColor(double offset, double halfWidth, Color color) :
+ mfOffset(offset),
+ mfHalfWidth(halfWidth),
+ maColor(color)
+ {}
+ };
+ double mfRefModeOffset;
+ basegfx::B2DVector maB2DVector;
+ std::vector< OffsetAndHalfWidthAndColor > maOffsets;
public:
- StyleVectorCombination(const Style& rStyle, const basegfx::B2DVector& rB2DVector, bool bMirrored) :
- mrStyle(rStyle),
- maB2DVector(rB2DVector),
- mbMirrored(bMirrored)
+ StyleVectorCombination(
+ const Style& rStyle,
+ const basegfx::B2DVector& rB2DVector,
+ bool bMirrored,
+ const Color* pForceColor = nullptr);
+
+ double getRefModeOffset() const { return mfRefModeOffset; }
+ const basegfx::B2DVector& getB2DVector() const { return maB2DVector; }
+
+ bool empty() const { return maOffsets.empty(); }
+ size_t size() const { return maOffsets.size(); }
+
+ void getColorAndOffsetAndHalfWidth(size_t nIndex, Color& rColor, double& rfOffset, double& rfHalfWidth) const
{
+ if(nIndex >= maOffsets.size())
+ return;
+ const OffsetAndHalfWidthAndColor& rCandidate(maOffsets[nIndex]);
+ rfOffset = rCandidate.mfOffset;
+ rfHalfWidth = rCandidate.mfHalfWidth;
+ rColor = rCandidate.maColor;
}
- const Style& getStyle() const { return mrStyle; }
- const basegfx::B2DVector& getB2DVector() const { return maB2DVector; }
- bool isMirrored() const { return mbMirrored; }
+ bool operator<(const StyleVectorCombination& rOther) const
+ {
+ return getB2DVector().cross(rOther.getB2DVector()) < 0.0;
+ }
};
-typedef std::vector< StyleVectorCombination > StyleVectorTable;
+class SAL_WARN_UNUSED SVX_DLLPUBLIC StyleVectorTable
+{
+private:
+ std::vector< StyleVectorCombination > maEntries;
+
+public:
+ StyleVectorTable()
+ : maEntries()
+ {
+ }
+
+ void add(
+ const Style& rStyle,
+ const basegfx::B2DVector& rMyVector,
+ const basegfx::B2DVector& rOtherVector,
+ bool bMirrored)
+ {
+ if(rStyle.IsUsed() && !basegfx::areParallel(rMyVector, rOtherVector))
+ {
+ maEntries.emplace_back(rStyle, rOtherVector, bMirrored);
+ }
+ }
+
+ void sort()
+ {
+ std::sort(maEntries.begin(), maEntries.end());
+ }
+
+ bool empty() const { return maEntries.empty(); }
+ size_t size() const { return maEntries.size(); }
+ const std::vector< StyleVectorCombination >& getEntries() const{ return maEntries; }
+};
SVX_DLLPUBLIC void CreateBorderPrimitives(
drawinglayer::primitive2d::Primitive2DContainer& rTarget, /// target for created primitives
diff --git a/svx/source/dialog/framelink.cxx b/svx/source/dialog/framelink.cxx
index 16b0061c3e0a..147be36167aa 100644
--- a/svx/source/dialog/framelink.cxx
+++ b/svx/source/dialog/framelink.cxx
@@ -338,19 +338,6 @@ bool Style::operator<( const Style& rOther) const
}
// Drawing functions
-struct OffsetAndHalfWidthAndColor
-{
- double mfOffset;
- double mfHalfWidth;
- Color maColor;
-
- OffsetAndHalfWidthAndColor(double offset, double halfWidth, Color color) :
- mfOffset(offset),
- mfHalfWidth(halfWidth),
- maColor(color)
- {}
-};
-
struct CutSet
{
double mfOLML;
@@ -367,108 +354,6 @@ struct ExtendSet
ExtendSet() : mfExtLeft(0.0), mfExtRight(0.0) {}
};
-double getOffsetAndHalfWidthAndColorFromStyle(
- const Style& rStyle,
- const Color* pForceColor,
- bool bMirrored,
- std::vector< OffsetAndHalfWidthAndColor >& offsets)
-{
- // do not forget RefMode offset, primitive is free of it
- double fRefModeOffset(0.0);
-
- if (rStyle.IsUsed())
- {
- RefMode aRefMode(rStyle.GetRefMode());
- Color aPrim(rStyle.GetColorPrim());
- Color aSecn(rStyle.GetColorSecn());
- double fPrim(rStyle.Prim());
- double fSecn(rStyle.Secn());
- const bool bSecnUsed(0.0 != fSecn);
-
- if(bMirrored)
- {
- switch(aRefMode)
- {
- case REFMODE_BEGIN: aRefMode = REFMODE_END; break;
- case REFMODE_END: aRefMode = REFMODE_BEGIN; break;
- default: break;
- }
-
- if(bSecnUsed)
- {
- std::swap(aPrim, aSecn);
- std::swap(fPrim, fSecn);
- }
- }
-
- if (REFMODE_CENTERED != aRefMode)
- {
- const double fHalfWidth(rStyle.GetWidth() * 0.5);
-
- if (REFMODE_BEGIN == aRefMode)
- {
- // move aligned below vector
- fRefModeOffset = fHalfWidth;
- }
- else if (REFMODE_END == aRefMode)
- {
- // move aligned above vector
- fRefModeOffset = -fHalfWidth;
- }
- }
-
- if (bSecnUsed)
- {
- // both or all three lines used
- const bool bPrimTransparent(0xff == rStyle.GetColorPrim().GetTransparency());
- const bool bDistTransparent(!rStyle.UseGapColor() || 0xff == rStyle.GetColorGap().GetTransparency());
- const bool bSecnTransparent(0xff == aSecn.GetTransparency());
-
- if(!bPrimTransparent || !bDistTransparent || !bSecnTransparent)
- {
- const double a(fRefModeOffset - (rStyle.GetWidth() * 0.5));
- const double b(a + fPrim);
- const double c(b + rStyle.Dist());
- const double d(c + fSecn);
-
- offsets.push_back(
- OffsetAndHalfWidthAndColor(
- (a + b) * 0.5,
- fPrim * 0.5,
- nullptr != pForceColor ? *pForceColor : aPrim));
-
- offsets.push_back(
- OffsetAndHalfWidthAndColor(
- (b + c) * 0.5,
- rStyle.Dist() * 0.5,
- rStyle.UseGapColor()
- ? (nullptr != pForceColor ? *pForceColor : rStyle.GetColorGap())
- : Color(COL_TRANSPARENT)));
-
- offsets.push_back(
- OffsetAndHalfWidthAndColor(
- (c + d) * 0.5,
- fSecn * 0.5,
- nullptr != pForceColor ? *pForceColor : aSecn));
- }
- }
- else
- {
- // one line used, push two values, from outer to inner
- if(0xff != rStyle.GetColorPrim().GetTransparency())
- {
- offsets.push_back(
- OffsetAndHalfWidthAndColor(
- fRefModeOffset,
- fPrim * 0.5,
- nullptr != pForceColor ? *pForceColor : aPrim));
- }
- }
- }
-
- return fRefModeOffset;
-}
-
void getCutSet(
CutSet& rCutSet,
const basegfx::B2DPoint& rLeft,
@@ -521,12 +406,12 @@ void getAllCutSets(
bool bUpper,
bool bLower)
{
- for(const auto& rStyleVectorCombination : rStyleVectorTable)
+ for(const auto& rCombination : rStyleVectorTable.getEntries())
{
if(bUpper || bLower)
{
// use only upper or lower vectors compared to rX
- const double fCross(rX.cross(rStyleVectorCombination.getB2DVector()));
+ const double fCross(rX.cross(rCombination.getB2DVector()));
if(bUpper && fCross > 0.0)
{
@@ -541,21 +426,27 @@ void getAllCutSets(
}
}
- std::vector< OffsetAndHalfWidthAndColor > otherOffsets;
- getOffsetAndHalfWidthAndColorFromStyle(rStyleVectorCombination.getStyle(), nullptr, rStyleVectorCombination.isMirrored(), otherOffsets);
-
- if(!otherOffsets.empty())
+ if(!rCombination.empty())
{
- const basegfx::B2DVector aOtherPerpend(basegfx::getNormalizedPerpendicular(rStyleVectorCombination.getB2DVector()));
+ const basegfx::B2DVector aOtherPerpend(basegfx::getNormalizedPerpendicular(rCombination.getB2DVector()));
+ const size_t nOffsets(rCombination.size());
- for(const auto& rOtherOffset : otherOffsets)
+ for(size_t a(0); a < nOffsets; a++)
{
- const basegfx::B2DPoint aOtherLeft(rOrigin + (aOtherPerpend * (rOtherOffset.mfOffset - rOtherOffset.mfHalfWidth)));
- const basegfx::B2DPoint aOtherRight(rOrigin + (aOtherPerpend * (rOtherOffset.mfOffset + rOtherOffset.mfHalfWidth)));
- CutSet aCutSet;
+ Color aOtherColor;
+ double fOtherOffset(0.0);
+ double fOtherHalfWidth(0.0);
+ rCombination.getColorAndOffsetAndHalfWidth(a, aOtherColor, fOtherOffset, fOtherHalfWidth);
- getCutSet(aCutSet, rLeft, rRight, rX, aOtherLeft, aOtherRight, rStyleVectorCombination.getB2DVector());
- rCutSets.push_back(aCutSet);
+ if(0xff != aOtherColor.GetTransparency())
+ {
+ const basegfx::B2DPoint aOtherLeft(rOrigin + (aOtherPerpend * (fOtherOffset - fOtherHalfWidth)));
+ const basegfx::B2DPoint aOtherRight(rOrigin + (aOtherPerpend * (fOtherOffset + fOtherHalfWidth)));
+ CutSet aCutSet;
+
+ getCutSet(aCutSet, rLeft, rRight, rX, aOtherLeft, aOtherRight, rCombination.getB2DVector());
+ rCutSets.push_back(aCutSet);
+ }
}
}
}
@@ -611,23 +502,25 @@ CutSet getMinMaxCutSet(
void getExtends(
std::vector<ExtendSet>& rExtendSet, // target Left/Right values to fill
const basegfx::B2DPoint& rOrigin, // own vector start
- const basegfx::B2DVector& rX, // own vector direction and length
- const basegfx::B2DVector& rPerpendX, // normalized perpendicular to rX
- const std::vector< OffsetAndHalfWidthAndColor >& rOffsets, // own vector derivations
+ const StyleVectorCombination& rCombination, // own vector and offstets for lines
+ const basegfx::B2DVector& rPerpendX, // normalized perpendicular to own vector
const StyleVectorTable& rStyleVectorTable) // other vectors emerging in this point
{
- if(!rOffsets.empty() && rOffsets.size() == rExtendSet.size())
+ if(!rCombination.empty() && rCombination.size() == rExtendSet.size())
{
- const size_t nOffsets(rOffsets.size());
+ const size_t nOffsets(rCombination.size());
for(size_t a(0); a < nOffsets; a++)
{
- const OffsetAndHalfWidthAndColor& rOffset(rOffsets[a]);
+ Color aMyColor;
+ double fMyOffset(0.0);
+ double fMyHalfWidth(0.0);
+ rCombination.getColorAndOffsetAndHalfWidth(a, aMyColor, fMyOffset, fMyHalfWidth);
- if(0xff != rOffset.maColor.GetTransparency())
+ if(0xff != aMyColor.GetTransparency())
{
- const basegfx::B2DPoint aLeft(rOrigin + (rPerpendX * (rOffset.mfOffset - rOffset.mfHalfWidth)));
- const basegfx::B2DPoint aRight(rOrigin + (rPerpendX * (rOffset.mfOffset + rOffset.mfHalfWidth)));
+ const basegfx::B2DPoint aLeft(rOrigin + (rPerpendX * (fMyOffset - fMyHalfWidth)));
+ const basegfx::B2DPoint aRight(rOrigin + (rPerpendX * (fMyOffset + fMyHalfWidth)));
std::vector< CutSet > aCutSets;
CutSet aResult;
bool bResultSet(false);
@@ -637,7 +530,7 @@ void getExtends(
// single line:
// - get all CutSets
// - get minimum values as extension (biggest possible overlap)
- getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rX, rStyleVectorTable, false, false);
+ getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rCombination.getB2DVector(), rStyleVectorTable, false, false);
if(!aCutSets.empty())
{
@@ -653,7 +546,7 @@ void getExtends(
if(bUpper)
{
- getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rX, rStyleVectorTable, true, false);
+ getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rCombination.getB2DVector(), rStyleVectorTable, true, false);
if(!aCutSets.empty())
{
@@ -662,7 +555,7 @@ void getExtends(
}
else
{
- getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rX, rStyleVectorTable, false, true);
+ getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rCombination.getB2DVector(), rStyleVectorTable, false, true);
if(!aCutSets.empty())
{
@@ -673,7 +566,7 @@ void getExtends(
}
else if(bLower)
{
- getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rX, rStyleVectorTable, false, true);
+ getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rCombination.getB2DVector(), rStyleVectorTable, false, true);
if(!aCutSets.empty())
{
@@ -682,7 +575,7 @@ void getExtends(
}
else
{
- getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rX, rStyleVectorTable, true, false);
+ getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rCombination.getB2DVector(), rStyleVectorTable, true, false);
if(!aCutSets.empty())
{
@@ -693,7 +586,7 @@ void getExtends(
}
else // middle line
{
- getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rX, rStyleVectorTable, false, false);
+ getAllCutSets(aCutSets, rOrigin, aLeft, aRight, rCombination.getB2DVector(), rStyleVectorTable, false, false);
if(!aCutSets.empty())
{
@@ -721,6 +614,106 @@ void getExtends(
}
}
+StyleVectorCombination::StyleVectorCombination(
+ const Style& rStyle,
+ const basegfx::B2DVector& rB2DVector,
+ bool bMirrored,
+ const Color* pForceColor)
+: mfRefModeOffset(0.0),
+ maB2DVector(rB2DVector),
+ maOffsets()
+{
+ if (rStyle.IsUsed())
+ {
+ RefMode aRefMode(rStyle.GetRefMode());
+ Color aPrim(rStyle.GetColorPrim());
+ Color aSecn(rStyle.GetColorSecn());
+ double fPrim(rStyle.Prim());
+ double fSecn(rStyle.Secn());
+ const bool bSecnUsed(0.0 != fSecn);
+
+ if(bMirrored)
+ {
+ switch(aRefMode)
+ {
+ case RefMode::REFMODE_BEGIN: aRefMode = RefMode::REFMODE_END; break;
+ case RefMode::REFMODE_END: aRefMode = RefMode::REFMODE_BEGIN; break;
+ default: break;
+ }
+
+ if(bSecnUsed)
+ {
+ std::swap(aPrim, aSecn);
+ std::swap(fPrim, fSecn);
+ }
+ }
+
+ if (RefMode::REFMODE_CENTERED != aRefMode)
+ {
+ const double fHalfWidth(rStyle.GetWidth() * 0.5);
+
+ if (RefMode::REFMODE_BEGIN == aRefMode)
+ {
+ // move aligned below vector
+ mfRefModeOffset = fHalfWidth;
+ }
+ else if (RefMode::REFMODE_END == aRefMode)
+ {
+ // move aligned above vector
+ mfRefModeOffset = -fHalfWidth;
+ }
+ }
+
+ if (bSecnUsed)
+ {
+ // both or all three lines used
+ const bool bPrimTransparent(0xff == rStyle.GetColorPrim().GetTransparency());
+ const bool bDistTransparent(!rStyle.UseGapColor() || 0xff == rStyle.GetColorGap().GetTransparency());
+ const bool bSecnTransparent(0xff == aSecn.GetTransparency());
+
+ if(!bPrimTransparent || !bDistTransparent || !bSecnTransparent)
+ {
+ const double a(mfRefModeOffset - (rStyle.GetWidth() * 0.5));
+ const double b(a + fPrim);
+ const double c(b + rStyle.Dist());
+ const double d(c + fSecn);
+
+ maOffsets.push_back(
+ OffsetAndHalfWidthAndColor(
+ (a + b) * 0.5,
+ fPrim * 0.5,
+ nullptr != pForceColor ? *pForceColor : aPrim));
+
+ maOffsets.push_back(
+ OffsetAndHalfWidthAndColor(
+ (b + c) * 0.5,
+ rStyle.Dist() * 0.5,
+ rStyle.UseGapColor()
+ ? (nullptr != pForceColor ? *pForceColor : rStyle.GetColorGap())
+ : Color(COL_TRANSPARENT)));
+
+ maOffsets.push_back(
+ OffsetAndHalfWidthAndColor(
+ (c + d) * 0.5,
+ fSecn * 0.5,
+ nullptr != pForceColor ? *pForceColor : aSecn));
+ }
+ }
+ else
+ {
+ // one line used, push two values, from outer to inner
+ if(0xff != rStyle.GetColorPrim().GetTransparency())
+ {
+ maOffsets.push_back(
+ OffsetAndHalfWidthAndColor(
+ mfRefModeOffset,
+ fPrim * 0.5,
+ nullptr != pForceColor ? *pForceColor : aPrim));
+ }
+ }
+ }
+}
+
void CreateBorderPrimitives(
drawinglayer::primitive2d::Primitive2DContainer& rTarget,
const basegfx::B2DPoint& rOrigin,
@@ -731,41 +724,31 @@ void CreateBorderPrimitives(
const Color* pForceColor)
{
// get offset color pairs for style, one per visible line
- std::vector< OffsetAndHalfWidthAndColor > myOffsets;
- const double fRefModeOffset(getOffsetAndHalfWidthAndColorFromStyle(rBorder, pForceColor, false, myOffsets));
- const size_t nOffsets(myOffsets.size());
+ const StyleVectorCombination aCombination(rBorder, rX, false, pForceColor);
- if(nOffsets)
+ if(!aCombination.empty())
{
const basegfx::B2DVector aPerpendX(basegfx::getNormalizedPerpendicular(rX));
const bool bHasStartStyles(!rStartStyleVectorTable.empty());
const bool bHasEndStyles(!rEndStyleVectorTable.empty());
+ const size_t nOffsets(aCombination.size());
std::vector<ExtendSet> aExtendSetStart(nOffsets);
std::vector<ExtendSet> aExtendSetEnd(nOffsets);
if(bHasStartStyles)
{
// create extends for line starts, use given point/vector and offsets
- getExtends(aExtendSetStart, rOrigin, rX, aPerpendX, myOffsets, rStartStyleVectorTable);
+ getExtends(aExtendSetStart, rOrigin, aCombination, aPerpendX, rStartStyleVectorTable);
}
if(bHasEndStyles)
{
- // Create extends for line ends, use inverse point/vector and inverse offsets.
- // Offsets need to be inverted for different width of lines. To invert, change
- // order, but also sign of offset. Do this on a copy since myOffsets will be
- // used below to create the primitives
- std::vector< OffsetAndHalfWidthAndColor > myInverseOffsets(myOffsets);
- std::reverse(myInverseOffsets.begin(), myInverseOffsets.end());
-
- for(auto& offset : myInverseOffsets)
- {
- offset.mfOffset *= -1;
- }
+ // Create extends for line ends, create inverse point/vector and inverse offsets.
+ const StyleVectorCombination aMirroredCombination(rBorder, -rX, true, pForceColor);
- getExtends(aExtendSetEnd, rOrigin + rX, -rX, -aPerpendX, myInverseOffsets, rEndStyleVectorTable);
+ getExtends(aExtendSetEnd, rOrigin + rX, aMirroredCombination, -aPerpendX, rEndStyleVectorTable);
- // also need to reverse the result to apply to the correct lines
+ // also need to inverse the result to apply to the correct lines
std::reverse(aExtendSetEnd.begin(), aExtendSetEnd.end());
}
@@ -774,23 +757,26 @@ void CreateBorderPrimitives(
for(size_t a(0); a < nOffsets; a++)
{
- const OffsetAndHalfWidthAndColor& rOffset(myOffsets[a]);
+ Color aMyColor;
+ double fMyOffset(0.0);
+ double fMyHalfWidth(0.0);
+ aCombination.getColorAndOffsetAndHalfWidth(a, aMyColor, fMyOffset, fMyHalfWidth);
const ExtendSet& rExtStart(aExtendSetStart[a]);
const ExtendSet& rExtEnd(aExtendSetEnd[a]);
- if(0xff == rOffset.maColor.GetTransparency())
+ if(0xff == aMyColor.GetTransparency())
{
aBorderlines.push_back(
drawinglayer::primitive2d::BorderLine(
- rOffset.mfHalfWidth * 2.0));
+ fMyHalfWidth * 2.0));
}
else
{
aBorderlines.push_back(
drawinglayer::primitive2d::BorderLine(
drawinglayer::attribute::LineAttribute(
- rOffset.maColor.getBColor(),
- rOffset.mfHalfWidth * 2.0),
+ aMyColor.getBColor(),
+ fMyHalfWidth * 2.0),
fNegLength * rExtStart.mfExtLeft,
fNegLength * rExtStart.mfExtRight,
fNegLength * rExtEnd.mfExtRight,
@@ -801,7 +787,7 @@ void CreateBorderPrimitives(
static double fPatScFact(10.0); // 10.0 multiply, see old code
const std::vector<double> aDashing(svtools::GetLineDashing(rBorder.Type(), rBorder.PatternScale() * fPatScFact));
const drawinglayer::attribute::StrokeAttribute aStrokeAttribute(aDashing);
- const basegfx::B2DPoint aStart(rOrigin + (aPerpendX * fRefModeOffset));
+ const basegfx::B2DPoint aStart(rOrigin + (aPerpendX * aCombination.getRefModeOffset()));
rTarget.push_back(
drawinglayer::primitive2d::Primitive2DReference(
diff --git a/svx/source/dialog/framelinkarray.cxx b/svx/source/dialog/framelinkarray.cxx
index 4c9545588326..f9a2322cd4ce 100644
--- a/svx/source/dialog/framelinkarray.cxx
+++ b/svx/source/dialog/framelinkarray.cxx
@@ -953,11 +953,12 @@ void HelperCreateHorizontalEntry(
const Style& rStartFromBR(rArray.GetCellStyleTL( col, row ));
StyleVectorTable aStart;
- if(rStartFromTR.IsUsed()) aStart.push_back(StyleVectorCombination(rStartFromTR, rX - rY, false));
- if(rStartLFromT.IsUsed()) aStart.push_back(StyleVectorCombination(rStartLFromT, -rY, true));
- if(rStartLFromL.IsUsed()) aStart.push_back(StyleVectorCombination(rStartLFromL, -rX, true));
- if(rStartLFromB.IsUsed()) aStart.push_back(StyleVectorCombination(rStartLFromB, rY, false));
- if(rStartFromBR.IsUsed()) aStart.push_back(StyleVectorCombination(rStartFromBR, rX + rY, false));
+ aStart.add(rStartFromTR, rX, rX - rY, false);
+ aStart.add(rStartLFromT, rX, -rY, true);
+ aStart.add(rStartLFromL, rX, -rX, true);
+ aStart.add(rStartLFromB, rX, rY, false);
+ aStart.add(rStartFromBR, rX, rX + rY, false);
+ aStart.sort();
// get involved styles at end
const Style& rEndFromTL(rArray.GetCellStyleBR( col, row - 1 ));
@@ -967,11 +968,12 @@ void HelperCreateHorizontalEntry(
const Style& rEndFromBL(rArray.GetCellStyleTR( col, row ));
StyleVectorTable aEnd;
- if(rEndFromTL.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndFromTL, -rX -rY, true));
- if(rEndRFromT.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndRFromT, -rY, true));
- if(rEndRFromR.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndRFromR, rX, false));
- if(rEndRFromB.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndRFromB, rY, false));
- if(rEndFromBL.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndFromBL, rY - rX, true));
+ aEnd.add(rEndFromTL, -rX, -rX -rY, true);
+ aEnd.add(rEndRFromT, -rX, -rY, true);
+ aEnd.add(rEndRFromR, -rX, rX, false);
+ aEnd.add(rEndRFromB, -rX, rY, false);
+ aEnd.add(rEndFromBL, -rX, rY - rX, true);
+ aEnd.sort();
CreateBorderPrimitives(
rSequence,
@@ -998,11 +1000,12 @@ void HelperCreateVerticalEntry(
const Style& rStartFromBR(rArray.GetCellStyleTL( col, row ));
StyleVectorTable aStart;
- if(rStartFromBR.IsUsed()) aStart.push_back(StyleVectorCombination(rStartFromBR, rX + rY, false));
- if(rStartTFromR.IsUsed()) aStart.push_back(StyleVectorCombination(rStartTFromR, rX, false));
- if(rStartTFromT.IsUsed()) aStart.push_back(StyleVectorCombination(rStartTFromT, -rY, true));
- if(rStartTFromL.IsUsed()) aStart.push_back(StyleVectorCombination(rStartTFromL, -rX, true));
- if(rStartFromBL.IsUsed()) aStart.push_back(StyleVectorCombination(rStartFromBL, rY - rX, true));
+ aStart.add(rStartFromBR, rY, rX + rY, false);
+ aStart.add(rStartTFromR, rY, rX, false);
+ aStart.add(rStartTFromT, rY, -rY, true);
+ aStart.add(rStartTFromL, rY, -rX, true);
+ aStart.add(rStartFromBL, rY, rY - rX, true);
+ aStart.sort();
// get involved styles at end
const Style& rEndFromTL(rArray.GetCellStyleBR( col - 1, row ));
@@ -1012,11 +1015,12 @@ void HelperCreateVerticalEntry(
const Style& rEndFromTR(rArray.GetCellStyleBL( col, row ));
StyleVectorTable aEnd;
- if(rEndFromTR.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndFromTR, rX - rY, false));
- if(rEndBFromR.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndBFromR, rX, false));
- if(rEndBFromB.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndBFromB, rY, false));
- if(rEndBFromL.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndBFromL, -rX, true));
- if(rEndFromTL.IsUsed()) aEnd.push_back(StyleVectorCombination(rEndFromTL, -rX - rY, true));
+ aEnd.add(rEndFromTR, -rY, rX - rY, false);
+ aEnd.add(rEndBFromR, -rY, rX, false);
+ aEnd.add(rEndBFromB, -rY, rY, false);
+ aEnd.add(rEndBFromL, -rY, -rX, true);
+ aEnd.add(rEndFromTL, -rY, -rX - rY, true);
+ aEnd.sort();
CreateBorderPrimitives(
rSequence,
@@ -1192,20 +1196,23 @@ drawinglayer::primitive2d::Primitive2DContainer Array::CreateB2DPrimitiveRange(
if(rTLBR.IsUsed())
{
/// top-left and bottom-right Style Tables
- StyleVectorTable aStart;
- StyleVectorTable aEnd;
-
/// Fill top-left Style Table
const Style& rTLFromRight(GetCellStyleTop(_nFirstCol, _nFirstRow));
- if(rTLFromRight.IsUsed()) aStart.push_back(StyleVectorCombination(rTLFromRight, aX, false));
const Style& rTLFromBottom(GetCellStyleLeft(_nFirstCol, _nFirstRow));
- if(rTLFromBottom.IsUsed()) aStart.push_back(StyleVectorCombination(rTLFromBottom, aY, false));
+ StyleVectorTable aStart;
+
+ aStart.add(rTLFromRight, aX + aY, aX, false);
+ aStart.add(rTLFromBottom, aX + aY, aY, false);
+ aStart.sort();
/// Fill bottom-right Style Table
const Style& rBRFromBottom(GetCellStyleRight(_nLastCol, _nLastRow));
- if(rBRFromBottom.IsUsed()) aEnd.push_back(StyleVectorCombination(rBRFromBottom, -aY, true));
const Style& rBRFromLeft(GetCellStyleBottom(_nLastCol, _nLastRow));
- if(rBRFromLeft.IsUsed()) aEnd.push_back(StyleVectorCombination(rBRFromLeft, -aX, true));
+ StyleVectorTable aEnd;
+
+ aEnd.add(rBRFromBottom, -aX -aY, -aY, true);
+ aEnd.add(rBRFromLeft, -aX -aY, -aX, true);
+ aEnd.sort();
CreateBorderPrimitives(
aCrossSequence,
@@ -1222,20 +1229,23 @@ drawinglayer::primitive2d::Primitive2DContainer Array::CreateB2DPrimitiveRange(
if(rBLTR.IsUsed())
{
/// bottom-left and top-right Style Tables
- StyleVectorTable aStart;
- StyleVectorTable aEnd;
-
/// Fill bottom-left Style Table
const Style& rBLFromTop(GetCellStyleLeft(_nFirstCol, _nLastRow));
- if(rBLFromTop.IsUsed()) aStart.push_back(StyleVectorCombination(rBLFromTop, -aY, true));
const Style& rBLFromBottom(GetCellStyleBottom(_nFirstCol, _nLastRow));
- if(rBLFromBottom.IsUsed()) aStart.push_back(StyleVectorCombination(rBLFromBottom, aX, false));
+ StyleVectorTable aStart;
+
+ aStart.add(rBLFromTop, aX - aY, -aY, true);
+ aStart.add(rBLFromBottom, aX - aY, aX, false);
+ aStart.sort();
/// Fill top-right Style Table
const Style& rTRFromBottom(GetCellStyleRight(_nLastCol, _nFirstRow));
- if(rTRFromBottom.IsUsed()) aEnd.push_back(StyleVectorCombination(rTRFromBottom, -aY, true));
const Style& rTRFromLeft(GetCellStyleTop(_nLastCol, _nFirstRow));
- if(rTRFromLeft.IsUsed()) aEnd.push_back(StyleVectorCombination(rTRFromLeft, -aX, false));
+ StyleVectorTable aEnd;
+
+ aEnd.add(rTRFromBottom, aY - aX, -aY, true);
+ aEnd.add(rTRFromLeft, aY - aX, -aX, false);
+ aEnd.sort();
CreateBorderPrimitives(
aCrossSequence,
diff --git a/svx/source/table/viewcontactoftableobj.cxx b/svx/source/table/viewcontactoftableobj.cxx
index 570c3ab40017..ae2645f66e80 100644
--- a/svx/source/table/viewcontactoftableobj.cxx
+++ b/svx/source/table/viewcontactoftableobj.cxx
@@ -206,19 +206,23 @@ namespace sdr
const svx::frame::Style& rRightA, const svx::frame::Style& rRightB, const svx::frame::Style& rRightC)
{
/// top-left and bottom-right Style Tables
- svx::frame::StyleVectorTable aStart;
- svx::frame::StyleVectorTable aEnd;
const basegfx::B2DVector aY(basegfx::getNormalizedPerpendicular(rX));
/// Fill top-left Style Table
- if(rLeftA.IsUsed()) aStart.push_back(svx::frame::StyleVectorCombination(rLeftA, -aY, bHor)); // bHor ? true : false));
- if(rLeftB.IsUsed()) aStart.push_back(svx::frame::StyleVectorCombination(rLeftB, -rX, true)); // bHor ? true : true));
- if(rLeftC.IsUsed()) aStart.push_back(svx::frame::StyleVectorCombination(rLeftC, aY, !bHor)); // bHor ? false : true));
+ svx::frame::StyleVectorTable aStart;
+
+ aStart.add(rLeftA, rX, -aY, bHor); // bHor ? true : false));
+ aStart.add(rLeftB, rX, -rX, true); // bHor ? true : true));
+ aStart.add(rLeftC, rX, aY, !bHor); // bHor ? false : true));
+ aStart.sort();
/// Fill bottom-right Style Table
- if(rRightA.IsUsed()) aEnd.push_back(svx::frame::StyleVectorCombination(rRightA, -aY, bHor)); // bHor ? true : false));
- if(rRightB.IsUsed()) aEnd.push_back(svx::frame::StyleVectorCombination(rRightB, rX, false)); // bHor ? false : false));
- if(rRightC.IsUsed()) aEnd.push_back(svx::frame::StyleVectorCombination(rRightC, aY, !bHor)); // bHor ? false : true));
+ svx::frame::StyleVectorTable aEnd;
+
+ aEnd.add(rRightA, -rX, -aY, bHor); // bHor ? true : false));
+ aEnd.add(rRightB, -rX, rX, false); // bHor ? false : false));
+ aEnd.add(rRightC, -rX, aY, !bHor); // bHor ? false : true));
+ aEnd.sort();
CreateBorderPrimitives(
rContainer,
diff --git a/sw/source/core/layout/paintfrm.cxx b/sw/source/core/layout/paintfrm.cxx
index c6ab47ea5240..739a6e933774 100644
--- a/sw/source/core/layout/paintfrm.cxx
+++ b/sw/source/core/layout/paintfrm.cxx
@@ -2547,24 +2547,27 @@ void SwTabFramePainter::PaintLines(OutputDevice& rDev, const SwRect& rRect) cons
if(!aX.equalZero())
{
const basegfx::B2DVector aY(basegfx::getNormalizedPerpendicular(aX));
- svx::frame::StyleVectorTable aStartTable;
- svx::frame::StyleVectorTable aEndTable;
+ svx::frame::StyleVectorTable aStartVector;
- if(aStyles[ 1 ].IsUsed()) aStartTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 1 ], -aY, true)); // aLFromT
- if(aStyles[ 2 ].IsUsed()) aStartTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 2 ], -aX, true)); // aLFromL
- if(aStyles[ 3 ].IsUsed()) aStartTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 3 ], aY, false)); // aLFromB
+ aStartVector.add(aStyles[ 1 ], aX, -aY, true); // aLFromT
+ aStartVector.add(aStyles[ 2 ], aX, -aX, true); // aLFromL
+ aStartVector.add(aStyles[ 3 ], aX, aY, false); // aLFromB
+ aStartVector.sort();
- if(aStyles[ 4 ].IsUsed()) aEndTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 4 ], -aY, true)); // aRFromT
- if(aStyles[ 5 ].IsUsed()) aEndTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 5 ], aX, false)); // aRFromR
- if(aStyles[ 6 ].IsUsed()) aEndTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 6 ], aY, false)); // aRFromB
+ svx::frame::StyleVectorTable aEndVector;
+
+ aEndVector.add(aStyles[ 4 ], -aX, -aY, true); // aRFromT
+ aEndVector.add(aStyles[ 5 ], -aX, aX, false); // aRFromR
+ aEndVector.add(aStyles[ 6 ], -aX, aY, false); // aRFromB
+ aEndVector.sort();
CreateBorderPrimitives(
aHorizontalSequence,
aOrigin,
aX,
aStyles[ 0 ],
- aStartTable,
- aEndTable,
+ aStartVector,
+ aEndVector,
pTmpColor
);
}
@@ -2577,24 +2580,27 @@ void SwTabFramePainter::PaintLines(OutputDevice& rDev, const SwRect& rRect) cons
if(!aX.equalZero())
{
const basegfx::B2DVector aY(basegfx::getNormalizedPerpendicular(aX));
- svx::frame::StyleVectorTable aStartTable;
- svx::frame::StyleVectorTable aEndTable;
+ svx::frame::StyleVectorTable aStartVector;
+
+ aStartVector.add(aStyles[ 3 ], aX, -aY, false); // aTFromR
+ aStartVector.add(aStyles[ 2 ], aX, -aX, true); // aTFromT
+ aStartVector.add(aStyles[ 1 ], aX, aY, true); // aTFromL
+ aStartVector.sort();
- if(aStyles[ 3 ].IsUsed()) aStartTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 3 ], -aY, false)); // aTFromR
- if(aStyles[ 2 ].IsUsed()) aStartTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 2 ], -aX, true)); // aTFromT
- if(aStyles[ 1 ].IsUsed()) aStartTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 1 ], aY, true)); // aTFromL
+ svx::frame::StyleVectorTable aEndVector;
- if(aStyles[ 6 ].IsUsed()) aEndTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 6 ], -aY, false)); // aBFromR
- if(aStyles[ 5 ].IsUsed()) aEndTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 5 ], aX, false)); // aBFromB
- if(aStyles[ 4 ].IsUsed()) aEndTable.push_back(svx::frame::StyleVectorCombination(aStyles[ 4 ], aY, true)); // aBFromL
+ aEndVector.add(aStyles[ 6 ], -aX, -aY, false); // aBFromR
+ aEndVector.add(aStyles[ 5 ], -aX, aX, false); // aBFromB
+ aEndVector.add(aStyles[ 4 ], -aX, aY, true); // aBFromL
+ aEndVector.sort();
CreateBorderPrimitives(
aVerticalSequence,
aOrigin,
aX,
aStyles[ 0 ],
- aStartTable,
- aEndTable,
+ aStartVector,
+ aEndVector,
pTmpColor
);
}
More information about the Libreoffice-commits
mailing list