summaryrefslogtreecommitdiff
path: root/svx
diff options
context:
space:
mode:
Diffstat (limited to 'svx')
-rw-r--r--svx/source/engine3d/view3d.cxx57
1 files changed, 18 insertions, 39 deletions
diff --git a/svx/source/engine3d/view3d.cxx b/svx/source/engine3d/view3d.cxx
index 8f06e623118e..c25a3b7afc08 100644
--- a/svx/source/engine3d/view3d.cxx
+++ b/svx/source/engine3d/view3d.cxx
@@ -999,14 +999,12 @@ void E3dView::ConvertMarkedObjTo3D(bool bExtrude, const basegfx::B2DPoint& rPnt1
struct E3dDepthNeighbour
{
- E3dDepthNeighbour* mpNext;
E3dExtrudeObj* mpObj;
basegfx::B2DPolyPolygon maPreparedPolyPolygon;
- E3dDepthNeighbour()
- : mpNext(nullptr),
- mpObj(nullptr),
- maPreparedPolyPolygon()
+ E3dDepthNeighbour(E3dExtrudeObj* pObj, basegfx::B2DPolyPolygon const & rPreparedPolyPolygon)
+ : mpObj(pObj),
+ maPreparedPolyPolygon(rPreparedPolyPolygon)
{
}
};
@@ -1014,23 +1012,12 @@ struct E3dDepthNeighbour
struct E3dDepthLayer
{
E3dDepthLayer* mpDown;
- E3dDepthNeighbour* mpNext;
+ std::vector<E3dDepthNeighbour> mvNeighbours;
E3dDepthLayer()
- : mpDown(nullptr),
- mpNext(nullptr)
+ : mpDown(nullptr)
{
}
-
- ~E3dDepthLayer()
- {
- while(mpNext)
- {
- E3dDepthNeighbour* pSucc = mpNext->mpNext;
- delete mpNext;
- mpNext = pSucc;
- }
- }
};
void E3dView::DoDepthArrange(E3dScene const * pScene, double fDepth)
@@ -1060,23 +1047,23 @@ void E3dView::DoDepthArrange(E3dScene const * pScene, double fDepth)
{
// do we have overlap with an object of this layer?
bool bOverlap(false);
- E3dDepthNeighbour* pAct = pLayer->mpNext;
+ auto itAct = pLayer->mvNeighbours.begin();
- while(!bOverlap && pAct)
+ while(!bOverlap && itAct != pLayer->mvNeighbours.end())
{
- // do pAct->mpObj and pExtrudeObj overlap? Check by
+ // do itAct->mpObj and pExtrudeObj overlap? Check by
// using logical AND clipping
const basegfx::B2DPolyPolygon aAndPolyPolygon(
basegfx::utils::solvePolygonOperationAnd(
aExtrudePoly,
- pAct->maPreparedPolyPolygon));
+ itAct->maPreparedPolyPolygon));
bOverlap = (0 != aAndPolyPolygon.count());
if(bOverlap)
{
// second criteria: is another fillstyle or color used?
- const SfxItemSet& rCompareSet = pAct->mpObj->GetMergedItemSet();
+ const SfxItemSet& rCompareSet = itAct->mpObj->GetMergedItemSet();
drawing::FillStyle eCompareFillStyle = rCompareSet.Get(XATTR_FILLSTYLE).GetValue();
@@ -1098,7 +1085,7 @@ void E3dView::DoDepthArrange(E3dScene const * pScene, double fDepth)
}
}
- pAct = pAct->mpNext;
+ ++itAct;
}
if(bOverlap)
@@ -1107,18 +1094,12 @@ void E3dView::DoDepthArrange(E3dScene const * pScene, double fDepth)
pLayer->mpDown = new E3dDepthLayer;
pLayer = pLayer->mpDown;
nNumLayers++;
- pLayer->mpNext = new E3dDepthNeighbour;
- pLayer->mpNext->mpObj = pExtrudeObj;
- pLayer->mpNext->maPreparedPolyPolygon = aExtrudePoly;
+ pLayer->mvNeighbours.emplace_back(pExtrudeObj, aExtrudePoly);
}
else
{
// no, add to current layer
- E3dDepthNeighbour* pNewNext = new E3dDepthNeighbour;
- pNewNext->mpObj = pExtrudeObj;
- pNewNext->maPreparedPolyPolygon = aExtrudePoly;
- pNewNext->mpNext = pLayer->mpNext;
- pLayer->mpNext = pNewNext;
+ pLayer->mvNeighbours.emplace(pLayer->mvNeighbours.begin(), pExtrudeObj, aExtrudePoly);
}
}
else
@@ -1127,9 +1108,7 @@ void E3dView::DoDepthArrange(E3dScene const * pScene, double fDepth)
pBaseLayer = new E3dDepthLayer;
pLayer = pBaseLayer;
nNumLayers++;
- pLayer->mpNext = new E3dDepthNeighbour;
- pLayer->mpNext->mpObj = pExtrudeObj;
- pLayer->mpNext->maPreparedPolyPolygon = aExtrudePoly;
+ pLayer->mvNeighbours.emplace_back(pExtrudeObj, aExtrudePoly);
}
}
}
@@ -1145,15 +1124,15 @@ void E3dView::DoDepthArrange(E3dScene const * pScene, double fDepth)
while(pLayer)
{
// move along layer
- E3dDepthNeighbour* pAct = pLayer->mpNext;
+ auto itAct = pLayer->mvNeighbours.begin();
- while(pAct)
+ while(itAct != pLayer->mvNeighbours.end())
{
// adapt extrude value
- pAct->mpObj->SetMergedItem(SfxUInt32Item(SDRATTR_3DOBJ_DEPTH, sal_uInt32(fMinDepth + 0.5)));
+ itAct->mpObj->SetMergedItem(SfxUInt32Item(SDRATTR_3DOBJ_DEPTH, sal_uInt32(fMinDepth + 0.5)));
// next
- pAct = pAct->mpNext;
+ ++itAct;
}
// next layer