bump product version to 5.0.4.1
[LibreOffice.git] / svx / source / svdraw / svdsnpv.cxx
blob070f4c40397e7f9826a0dddb7ce08985349054a3
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
21 #include <svx/svdsnpv.hxx>
22 #include <math.h>
24 #include <svx/svdetc.hxx>
25 #include <svx/svdobj.hxx>
26 #include <svx/svdpagv.hxx>
27 #include <svx/svdpage.hxx>
28 #include "svx/svditer.hxx"
29 #include <svx/sdr/overlay/overlayobjectlist.hxx>
30 #include <sdr/overlay/overlaycrosshair.hxx>
31 #include <sdr/overlay/overlayhelpline.hxx>
32 #include <svx/sdr/overlay/overlaymanager.hxx>
33 #include <basegfx/matrix/b2dhommatrix.hxx>
34 #include <svx/sdrpaintwindow.hxx>
37 class ImplPageOriginOverlay
39 // The OverlayObjects
40 sdr::overlay::OverlayObjectList maObjects;
42 // The current position in logical coodinates
43 basegfx::B2DPoint maPosition;
45 public:
46 ImplPageOriginOverlay(const SdrPaintView& rView, const basegfx::B2DPoint& rStartPos);
47 ~ImplPageOriginOverlay();
49 void SetPosition(const basegfx::B2DPoint& rNewPosition);
52 ImplPageOriginOverlay::ImplPageOriginOverlay(const SdrPaintView& rView, const basegfx::B2DPoint& rStartPos)
53 : maPosition(rStartPos)
55 for(sal_uInt32 a(0L); a < rView.PaintWindowCount(); a++)
57 SdrPaintWindow* pCandidate = rView.GetPaintWindow(a);
58 rtl::Reference< sdr::overlay::OverlayManager > xTargetOverlay = pCandidate->GetOverlayManager();
60 if (xTargetOverlay.is())
62 sdr::overlay::OverlayCrosshairStriped* aNew = new sdr::overlay::OverlayCrosshairStriped(
63 maPosition);
64 xTargetOverlay->add(*aNew);
65 maObjects.append(*aNew);
70 ImplPageOriginOverlay::~ImplPageOriginOverlay()
72 // The OverlayObjects are cleared using the destructor of OverlayObjectList.
73 // That destructor calls clear() at the list which removes all objects from the
74 // OverlayManager and deletes them.
77 void ImplPageOriginOverlay::SetPosition(const basegfx::B2DPoint& rNewPosition)
79 if(rNewPosition != maPosition)
81 // apply to OverlayObjects
82 for(sal_uInt32 a(0); a < maObjects.count(); a++)
84 sdr::overlay::OverlayCrosshairStriped* pCandidate =
85 static_cast< sdr::overlay::OverlayCrosshairStriped* >(&maObjects.getOverlayObject(a));
87 if(pCandidate)
89 pCandidate->setBasePosition(rNewPosition);
93 // remember new position
94 maPosition = rNewPosition;
99 class ImplHelpLineOverlay
101 // The OverlayObjects
102 sdr::overlay::OverlayObjectList maObjects;
104 // The current position in logical coodinates
105 basegfx::B2DPoint maPosition;
107 // HelpLine specific stuff
108 SdrPageView* mpPageView;
109 sal_uInt16 mnHelpLineNumber;
110 SdrHelpLineKind meHelpLineKind;
112 public:
113 ImplHelpLineOverlay(const SdrPaintView& rView, const basegfx::B2DPoint& rStartPos,
114 SdrPageView* pPageView, sal_uInt16 nHelpLineNumber, SdrHelpLineKind eKind);
115 ~ImplHelpLineOverlay();
117 void SetPosition(const basegfx::B2DPoint& rNewPosition);
119 // access to HelpLine specific stuff
120 SdrPageView* GetPageView() const { return mpPageView; }
121 sal_uInt16 GetHelpLineNumber() const { return mnHelpLineNumber; }
122 SdrHelpLineKind GetHelpLineKind() const { return meHelpLineKind; }
125 ImplHelpLineOverlay::ImplHelpLineOverlay(
126 const SdrPaintView& rView, const basegfx::B2DPoint& rStartPos,
127 SdrPageView* pPageView, sal_uInt16 nHelpLineNumber, SdrHelpLineKind eKind)
128 : maPosition(rStartPos),
129 mpPageView(pPageView),
130 mnHelpLineNumber(nHelpLineNumber),
131 meHelpLineKind(eKind)
133 for(sal_uInt32 a(0L); a < rView.PaintWindowCount(); a++)
135 SdrPaintWindow* pCandidate = rView.GetPaintWindow(a);
136 rtl::Reference< sdr::overlay::OverlayManager > xTargetOverlay = pCandidate->GetOverlayManager();
138 if (xTargetOverlay.is())
140 sdr::overlay::OverlayHelplineStriped* aNew = new sdr::overlay::OverlayHelplineStriped(
141 maPosition, meHelpLineKind);
142 xTargetOverlay->add(*aNew);
143 maObjects.append(*aNew);
148 ImplHelpLineOverlay::~ImplHelpLineOverlay()
150 // The OverlayObjects are cleared using the destructor of OverlayObjectList.
151 // That destructor calls clear() at the list which removes all objects from the
152 // OverlayManager and deletes them.
155 void ImplHelpLineOverlay::SetPosition(const basegfx::B2DPoint& rNewPosition)
157 if(rNewPosition != maPosition)
159 // apply to OverlayObjects
160 for(sal_uInt32 a(0); a < maObjects.count(); a++)
162 sdr::overlay::OverlayHelplineStriped* pCandidate =
163 static_cast< sdr::overlay::OverlayHelplineStriped* >(&maObjects.getOverlayObject(a));
165 if(pCandidate)
167 pCandidate->setBasePosition(rNewPosition);
171 // remember new position
172 maPosition = rNewPosition;
177 void SdrSnapView::ClearVars()
179 nMagnSizPix=4;
180 bSnapEnab=true;
181 bGridSnap=true;
182 bSnapTo1Pix=true;
183 bBordSnap=true;
184 bHlplSnap=true;
185 bOFrmSnap=true;
186 bOPntSnap=false;
187 bOConSnap=true;
188 bMoveMFrmSnap=true;
189 bMoveOFrmSnap=true;
190 bMoveOPntSnap=true;
191 bMoveOConSnap=true;
192 bMoveSnapOnlyTopLeft=false;
193 bOrtho=false;
194 bBigOrtho=true;
195 nSnapAngle=1500;
196 bAngleSnapEnab=false;
197 bMoveOnlyDragging=false;
198 bSlantButShear=false;
199 bCrookNoContortion=false;
200 eCrookMode=SDRCROOK_ROTATE;
201 bHlplFixed=false;
202 bEliminatePolyPoints=false;
203 nEliminatePolyPointLimitAngle=0;
205 BrkSetPageOrg();
206 BrkDragHelpLine();
209 SdrSnapView::SdrSnapView(SdrModel* pModel1, OutputDevice* pOut):
210 SdrPaintView(pModel1,pOut),
211 mpPageOriginOverlay(0L),
212 mpHelpLineOverlay(0L)
214 ClearVars();
217 SdrSnapView::~SdrSnapView()
219 BrkSetPageOrg();
220 BrkDragHelpLine();
225 bool SdrSnapView::IsAction() const
227 return IsSetPageOrg() || IsDragHelpLine() || SdrPaintView::IsAction();
230 void SdrSnapView::MovAction(const Point& rPnt)
232 SdrPaintView::MovAction(rPnt);
233 if (IsSetPageOrg()) {
234 MovSetPageOrg(rPnt);
236 if (IsDragHelpLine()) {
237 MovDragHelpLine(rPnt);
241 void SdrSnapView::EndAction()
243 if (IsSetPageOrg()) {
244 EndSetPageOrg();
246 if (IsDragHelpLine()) {
247 EndDragHelpLine();
249 SdrPaintView::EndAction();
252 void SdrSnapView::BckAction()
254 BrkSetPageOrg();
255 BrkDragHelpLine();
256 SdrPaintView::BckAction();
259 void SdrSnapView::BrkAction()
261 BrkSetPageOrg();
262 BrkDragHelpLine();
263 SdrPaintView::BrkAction();
266 void SdrSnapView::TakeActionRect(Rectangle& rRect) const
268 if (IsSetPageOrg() || IsDragHelpLine()) {
269 rRect=Rectangle(aDragStat.GetNow(),aDragStat.GetNow());
270 } else {
271 SdrPaintView::TakeActionRect(rRect);
277 Point SdrSnapView::GetSnapPos(const Point& rPnt, const SdrPageView* pPV) const
279 Point aPt(rPnt);
280 SnapPos(aPt,pPV);
281 return aPt;
284 #define NOT_SNAPPED 0x7FFFFFFF
285 SdrSnap SdrSnapView::SnapPos(Point& rPnt, const SdrPageView* pPV) const
287 if (!bSnapEnab) return SdrSnap::NOTSNAPPED;
288 long x=rPnt.X();
289 long y=rPnt.Y();
290 if (pPV==NULL) {
291 pPV=GetSdrPageView();
292 if (pPV==NULL) return SdrSnap::NOTSNAPPED;
295 long dx=NOT_SNAPPED;
296 long dy=NOT_SNAPPED;
297 long dx1,dy1;
298 long mx=aMagnSiz.Width();
299 long my=aMagnSiz.Height();
300 if (bHlplVisible && bHlplSnap && !IsDragHelpLine())
302 const SdrHelpLineList& rHLL=pPV->GetHelpLines();
303 sal_uInt16 nCount=rHLL.GetCount();
304 for (sal_uInt16 i=nCount; i>0;) {
305 i--;
306 const SdrHelpLine& rHL=rHLL[i];
307 const Point& rPos=rHL.GetPos();
308 switch (rHL.GetKind()) {
309 case SDRHELPLINE_VERTICAL: {
310 long a=x-rPos.X();
311 if (std::abs(a)<=mx) { dx1=-a; if (std::abs(dx1)<std::abs(dx)) dx=dx1; }
312 } break;
313 case SDRHELPLINE_HORIZONTAL: {
314 long b=y-rPos.Y();
315 if (std::abs(b)<=my) { dy1=-b; if (std::abs(dy1)<std::abs(dy)) dy=dy1; }
316 } break;
317 case SDRHELPLINE_POINT: {
318 long a=x-rPos.X();
319 long b=y-rPos.Y();
320 if (std::abs(a)<=mx && std::abs(b)<=my) {
321 dx1=-a; dy1=-b;
322 if (std::abs(dx1)<std::abs(dx) && std::abs(dy1)<std::abs(dy)) { dx=dx1; dy=dy1; }
324 } break;
325 } // switch
328 if (bBordVisible && bBordSnap) {
329 SdrPage* pPage=pPV->GetPage();
330 long xs=pPage->GetWdt();
331 long ys=pPage->GetHgt();
332 long lft=pPage->GetLftBorder();
333 long rgt=pPage->GetRgtBorder();
334 long upp=pPage->GetUppBorder();
335 long lwr=pPage->GetLwrBorder();
336 long a;
337 a=x- lft ; if (std::abs(a)<=mx) { dx1=-a; if (std::abs(dx1)<std::abs(dx)) dx=dx1; } // left margin
338 a=x-(xs-rgt); if (std::abs(a)<=mx) { dx1=-a; if (std::abs(dx1)<std::abs(dx)) dx=dx1; } // right margin
339 a=x ; if (std::abs(a)<=mx) { dx1=-a; if (std::abs(dx1)<std::abs(dx)) dx=dx1; } // left edge of paper
340 a=x- xs ; if (std::abs(a)<=mx) { dx1=-a; if (std::abs(dx1)<std::abs(dx)) dx=dx1; } // right edge of paper
341 a=y- upp ; if (std::abs(a)<=my) { dy1=-a; if (std::abs(dy1)<std::abs(dy)) dy=dy1; } // left margin
342 a=y-(ys-lwr); if (std::abs(a)<=my) { dy1=-a; if (std::abs(dy1)<std::abs(dy)) dy=dy1; } // right margin
343 a=y ; if (std::abs(a)<=my) { dy1=-a; if (std::abs(dy1)<std::abs(dy)) dy=dy1; } // left edge of paper
344 a=y- ys ; if (std::abs(a)<=my) { dy1=-a; if (std::abs(dy1)<std::abs(dy)) dy=dy1; } // right edge of paper
346 if (bOFrmSnap || bOPntSnap) {
347 sal_uIntPtr nMaxPointSnapCount=200;
348 sal_uIntPtr nMaxFrameSnapCount=200;
350 // go back to IM_DEEPNOGROUPS runthrough for snap to object comparisons
351 SdrObjListIter aIter(*pPV->GetPage(),IM_DEEPNOGROUPS,true);
353 while (aIter.IsMore() && (nMaxPointSnapCount>0 || nMaxFrameSnapCount>0)) {
354 SdrObject* pO=aIter.Next();
355 Rectangle aRect(pO->GetCurrentBoundRect());
356 aRect.Left ()-=mx;
357 aRect.Right ()+=mx;
358 aRect.Top ()-=my;
359 aRect.Bottom()+=my;
360 if (aRect.IsInside(rPnt)) {
361 if (bOPntSnap && nMaxPointSnapCount>0)
363 sal_uInt32 nCount(pO->GetSnapPointCount());
364 for (sal_uInt32 i(0L); i < nCount && nMaxPointSnapCount > 0L; i++)
366 Point aP(pO->GetSnapPoint(i));
367 dx1=x-aP.X();
368 dy1=y-aP.Y();
369 if (std::abs(dx1)<=mx && std::abs(dy1)<=my && std::abs(dx1)<std::abs(dx) && std::abs(dy1)<std::abs(dy)) {
370 dx=-dx1;
371 dy=-dy1;
373 nMaxPointSnapCount--;
376 if (bOFrmSnap && nMaxFrameSnapCount>0) {
377 Rectangle aLog(pO->GetSnapRect());
378 Rectangle aR1(aLog);
379 aR1.Left ()-=mx;
380 aR1.Right ()+=mx;
381 aR1.Top ()-=my;
382 aR1.Bottom()+=my;
383 if (aR1.IsInside(rPnt)) {
384 if (std::abs(x-aLog.Left ())<=mx) { dx1=-(x-aLog.Left ()); if (std::abs(dx1)<std::abs(dx)) dx=dx1; }
385 if (std::abs(x-aLog.Right ())<=mx) { dx1=-(x-aLog.Right ()); if (std::abs(dx1)<std::abs(dx)) dx=dx1; }
386 if (std::abs(y-aLog.Top ())<=my) { dy1=-(y-aLog.Top ()); if (std::abs(dy1)<std::abs(dy)) dy=dy1; }
387 if (std::abs(y-aLog.Bottom())<=my) { dy1=-(y-aLog.Bottom()); if (std::abs(dy1)<std::abs(dy)) dy=dy1; }
389 nMaxFrameSnapCount--;
394 if(bGridSnap)
396 double fSnapWidth = aSnapWdtX;
397 if(dx == NOT_SNAPPED && fSnapWidth != 0.0)
399 double fx = (double)x;
401 // round instead of trunc
402 if(fx - (double)pPV->GetPageOrigin().X() >= 0.0)
403 fx += fSnapWidth / 2.0;
404 else
405 fx -= fSnapWidth / 2.0;
407 x = (long)((fx - (double)pPV->GetPageOrigin().X()) / fSnapWidth);
408 x = (long)((double)x * fSnapWidth + (double)pPV->GetPageOrigin().X());
409 dx = 0;
411 fSnapWidth = aSnapWdtY;
412 if(dy == NOT_SNAPPED && fSnapWidth)
414 double fy = (double)y;
416 // round instead of trunc
417 if(fy - (double)pPV->GetPageOrigin().Y() >= 0.0)
418 fy += fSnapWidth / 2.0;
419 else
420 fy -= fSnapWidth / 2.0;
422 y = (long)((fy - (double)pPV->GetPageOrigin().Y()) / fSnapWidth);
423 y = (long)((double)y * fSnapWidth + (double)pPV->GetPageOrigin().Y());
424 dy = 0;
427 SdrSnap bRet=SdrSnap::NOTSNAPPED;
428 if (dx==NOT_SNAPPED) dx=0; else bRet|=SdrSnap::XSNAPPED;
429 if (dy==NOT_SNAPPED) dy=0; else bRet|=SdrSnap::YSNAPPED;
430 rPnt.X()=x+dx;
431 rPnt.Y()=y+dy;
432 return bRet;
435 void SdrSnapView::CheckSnap(const Point& rPt, const SdrPageView* pPV, long& nBestXSnap, long& nBestYSnap, bool& bXSnapped, bool& bYSnapped) const
437 Point aPt(rPt);
438 SdrSnap nRet=SnapPos(aPt,pPV);
439 aPt-=rPt;
440 if (nRet & SdrSnap::XSNAPPED) {
441 if (bXSnapped) {
442 if (std::abs(aPt.X())<std::abs(nBestXSnap)) {
443 nBestXSnap=aPt.X();
445 } else {
446 nBestXSnap=aPt.X();
447 bXSnapped=true;
450 if (nRet & SdrSnap::YSNAPPED) {
451 if (bYSnapped) {
452 if (std::abs(aPt.Y())<std::abs(nBestYSnap)) {
453 nBestYSnap=aPt.Y();
455 } else {
456 nBestYSnap=aPt.Y();
457 bYSnapped=true;
464 bool SdrSnapView::BegSetPageOrg(const Point& rPnt)
466 BrkAction();
468 DBG_ASSERT(0L == mpPageOriginOverlay, "SdrSnapView::BegSetPageOrg: There exists a ImplPageOriginOverlay (!)");
469 basegfx::B2DPoint aStartPos(rPnt.X(), rPnt.Y());
470 mpPageOriginOverlay = new ImplPageOriginOverlay(*this, aStartPos);
471 aDragStat.Reset(GetSnapPos(rPnt,NULL));
473 return true;
476 void SdrSnapView::MovSetPageOrg(const Point& rPnt)
478 if(IsSetPageOrg())
480 aDragStat.NextMove(GetSnapPos(rPnt,NULL));
481 DBG_ASSERT(mpPageOriginOverlay, "SdrSnapView::MovSetPageOrg: no ImplPageOriginOverlay (!)");
482 basegfx::B2DPoint aNewPos(aDragStat.GetNow().X(), aDragStat.GetNow().Y());
483 mpPageOriginOverlay->SetPosition(aNewPos);
487 bool SdrSnapView::EndSetPageOrg()
489 bool bRet(false);
491 if(IsSetPageOrg())
493 SdrPageView* pPV = GetSdrPageView();
495 if(pPV)
497 Point aPnt(aDragStat.GetNow());
498 pPV->SetPageOrigin(aPnt);
499 bRet = true;
502 // cleanup
503 BrkSetPageOrg();
506 return bRet;
509 void SdrSnapView::BrkSetPageOrg()
511 if(IsSetPageOrg())
513 DBG_ASSERT(mpPageOriginOverlay, "SdrSnapView::MovSetPageOrg: no ImplPageOriginOverlay (!)");
514 delete mpPageOriginOverlay;
515 mpPageOriginOverlay = 0L;
521 bool SdrSnapView::PickHelpLine(const Point& rPnt, short nTol, const OutputDevice& rOut, sal_uInt16& rnHelpLineNum, SdrPageView*& rpPV) const
523 rpPV=NULL;
524 nTol=ImpGetHitTolLogic(nTol,&rOut);
525 SdrPageView* pPV = GetSdrPageView();
527 if(pPV)
529 Point aPnt(rPnt);
530 sal_uInt16 nIndex=pPV->GetHelpLines().HitTest(aPnt,sal_uInt16(nTol),rOut);
531 if (nIndex!=SDRHELPLINE_NOTFOUND) {
532 rpPV=pPV;
533 rnHelpLineNum=nIndex;
534 return true;
537 return false;
540 // start HelpLine drag for new HelpLine
541 bool SdrSnapView::BegDragHelpLine(sal_uInt16 nHelpLineNum, SdrPageView* pPV)
543 bool bRet(false);
545 if(!bHlplFixed)
547 BrkAction();
549 if(pPV && nHelpLineNum < pPV->GetHelpLines().GetCount())
551 const SdrHelpLineList& rHelpLines = pPV->GetHelpLines();
552 const SdrHelpLine& rHelpLine = rHelpLines[nHelpLineNum];
553 Point aHelpLinePos = rHelpLine.GetPos();
554 basegfx::B2DPoint aStartPos(aHelpLinePos.X(), aHelpLinePos.Y());
556 DBG_ASSERT(0L == mpHelpLineOverlay, "SdrSnapView::BegDragHelpLine: There exists a ImplHelpLineOverlay (!)");
557 mpHelpLineOverlay = new ImplHelpLineOverlay(*this, aStartPos, pPV, nHelpLineNum, rHelpLine.GetKind());
559 aDragStat.Reset(GetSnapPos(aHelpLinePos, pPV));
560 aDragStat.SetMinMove(ImpGetMinMovLogic(-3, 0L));
562 bRet = true;
566 return bRet;
569 // start HelpLine drag with existing HelpLine
570 bool SdrSnapView::BegDragHelpLine(const Point& rPnt, SdrHelpLineKind eNewKind)
572 bool bRet(false);
574 BrkAction();
576 if(GetSdrPageView())
578 DBG_ASSERT(0L == mpHelpLineOverlay, "SdrSnapView::BegDragHelpLine: There exists a ImplHelpLineOverlay (!)");
579 basegfx::B2DPoint aStartPos(rPnt.X(), rPnt.Y());
580 mpHelpLineOverlay = new ImplHelpLineOverlay(*this, aStartPos, 0L, 0, eNewKind);
581 aDragStat.Reset(GetSnapPos(rPnt, 0L));
582 bRet = true;
585 return bRet;
588 Pointer SdrSnapView::GetDraggedHelpLinePointer() const
590 if(IsDragHelpLine())
592 switch(mpHelpLineOverlay->GetHelpLineKind())
594 case SDRHELPLINE_VERTICAL : return Pointer(PointerStyle::ESize);
595 case SDRHELPLINE_HORIZONTAL: return Pointer(PointerStyle::SSize);
596 default : return Pointer(PointerStyle::Move);
600 return Pointer(PointerStyle::Move);
603 void SdrSnapView::MovDragHelpLine(const Point& rPnt)
605 if(IsDragHelpLine() && aDragStat.CheckMinMoved(rPnt))
607 Point aPnt(GetSnapPos(rPnt, 0L));
609 if(aPnt != aDragStat.GetNow())
611 aDragStat.NextMove(aPnt);
612 DBG_ASSERT(mpHelpLineOverlay, "SdrSnapView::MovDragHelpLine: no ImplHelpLineOverlay (!)");
613 basegfx::B2DPoint aNewPos(aDragStat.GetNow().X(), aDragStat.GetNow().Y());
614 mpHelpLineOverlay->SetPosition(aNewPos);
619 bool SdrSnapView::EndDragHelpLine()
621 bool bRet(false);
623 if(IsDragHelpLine())
625 if(aDragStat.IsMinMoved())
627 SdrPageView* pPageView = mpHelpLineOverlay->GetPageView();
629 if(pPageView)
631 // moved existing one
632 Point aPnt(aDragStat.GetNow());
633 const SdrHelpLineList& rHelpLines = pPageView->GetHelpLines();
634 SdrHelpLine aChangedHelpLine = rHelpLines[mpHelpLineOverlay->GetHelpLineNumber()];
635 aChangedHelpLine.SetPos(aPnt);
636 pPageView->SetHelpLine(mpHelpLineOverlay->GetHelpLineNumber(), aChangedHelpLine);
638 bRet = true;
640 else
642 // create new one
643 pPageView = GetSdrPageView();
645 if(pPageView)
647 Point aPnt(aDragStat.GetNow());
648 SdrHelpLine aNewHelpLine(mpHelpLineOverlay->GetHelpLineKind(), aPnt);
649 pPageView->InsertHelpLine(aNewHelpLine);
651 bRet = true;
656 // cleanup
657 BrkDragHelpLine();
660 return bRet;
663 void SdrSnapView::BrkDragHelpLine()
665 if(IsDragHelpLine())
667 DBG_ASSERT(mpHelpLineOverlay, "SdrSnapView::EndDragHelpLine: no ImplHelpLineOverlay (!)");
668 delete mpHelpLineOverlay;
669 mpHelpLineOverlay = 0L;
673 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */