xref: /AOO41X/main/svx/source/svdraw/svdorect.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
29*cdf0e10cSrcweir #include "precompiled_svx.hxx"
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir #include <svx/svdorect.hxx>
32*cdf0e10cSrcweir #include <math.h>
33*cdf0e10cSrcweir #include <stdlib.h>
34*cdf0e10cSrcweir #include <svx/xpool.hxx>
35*cdf0e10cSrcweir #include <svx/xpoly.hxx>
36*cdf0e10cSrcweir #include <svx/svdattr.hxx>
37*cdf0e10cSrcweir #include <svx/svdpool.hxx>
38*cdf0e10cSrcweir #include <svx/svdtrans.hxx>
39*cdf0e10cSrcweir #include <svx/svdetc.hxx>
40*cdf0e10cSrcweir #include <svx/svddrag.hxx>
41*cdf0e10cSrcweir #include <svx/svdmodel.hxx>
42*cdf0e10cSrcweir #include <svx/svdpage.hxx>
43*cdf0e10cSrcweir #include <svx/svdocapt.hxx> // fuer Import von SdrFileVersion 2
44*cdf0e10cSrcweir #include <svx/svdpagv.hxx> // fuer
45*cdf0e10cSrcweir #include <svx/svdview.hxx> // das
46*cdf0e10cSrcweir #include <svx/svdundo.hxx> // Macro-Beispiel
47*cdf0e10cSrcweir #include <svx/svdopath.hxx>
48*cdf0e10cSrcweir #include "svx/svdglob.hxx"  // Stringcache
49*cdf0e10cSrcweir #include "svx/svdstr.hrc"   // Objektname
50*cdf0e10cSrcweir #include <svx/xflclit.hxx>
51*cdf0e10cSrcweir #include <svx/xlnclit.hxx>
52*cdf0e10cSrcweir #include <svx/xlnwtit.hxx>
53*cdf0e10cSrcweir #include "svdoimp.hxx"
54*cdf0e10cSrcweir #include <svx/sdr/properties/rectangleproperties.hxx>
55*cdf0e10cSrcweir #include <svx/sdr/contact/viewcontactofsdrrectobj.hxx>
56*cdf0e10cSrcweir #include <basegfx/polygon/b2dpolygon.hxx>
57*cdf0e10cSrcweir #include <basegfx/polygon/b2dpolygontools.hxx>
58*cdf0e10cSrcweir 
59*cdf0e10cSrcweir //////////////////////////////////////////////////////////////////////////////
60*cdf0e10cSrcweir // BaseProperties section
61*cdf0e10cSrcweir 
62*cdf0e10cSrcweir sdr::properties::BaseProperties* SdrRectObj::CreateObjectSpecificProperties()
63*cdf0e10cSrcweir {
64*cdf0e10cSrcweir 	return new sdr::properties::RectangleProperties(*this);
65*cdf0e10cSrcweir }
66*cdf0e10cSrcweir 
67*cdf0e10cSrcweir //////////////////////////////////////////////////////////////////////////////
68*cdf0e10cSrcweir // DrawContact section
69*cdf0e10cSrcweir 
70*cdf0e10cSrcweir sdr::contact::ViewContact* SdrRectObj::CreateObjectSpecificViewContact()
71*cdf0e10cSrcweir {
72*cdf0e10cSrcweir 	return new sdr::contact::ViewContactOfSdrRectObj(*this);
73*cdf0e10cSrcweir }
74*cdf0e10cSrcweir 
75*cdf0e10cSrcweir //////////////////////////////////////////////////////////////////////////////
76*cdf0e10cSrcweir 
77*cdf0e10cSrcweir TYPEINIT1(SdrRectObj,SdrTextObj);
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir SdrRectObj::SdrRectObj()
80*cdf0e10cSrcweir :	mpXPoly(0L)
81*cdf0e10cSrcweir {
82*cdf0e10cSrcweir 	bClosedObj=sal_True;
83*cdf0e10cSrcweir }
84*cdf0e10cSrcweir 
85*cdf0e10cSrcweir SdrRectObj::SdrRectObj(const Rectangle& rRect)
86*cdf0e10cSrcweir :	SdrTextObj(rRect),
87*cdf0e10cSrcweir 	mpXPoly(NULL)
88*cdf0e10cSrcweir {
89*cdf0e10cSrcweir 	bClosedObj=sal_True;
90*cdf0e10cSrcweir }
91*cdf0e10cSrcweir 
92*cdf0e10cSrcweir SdrRectObj::SdrRectObj(SdrObjKind eNewTextKind)
93*cdf0e10cSrcweir :	SdrTextObj(eNewTextKind),
94*cdf0e10cSrcweir 	mpXPoly(NULL)
95*cdf0e10cSrcweir {
96*cdf0e10cSrcweir 	DBG_ASSERT(eTextKind==OBJ_TEXT || eTextKind==OBJ_TEXTEXT ||
97*cdf0e10cSrcweir 			   eTextKind==OBJ_OUTLINETEXT || eTextKind==OBJ_TITLETEXT,
98*cdf0e10cSrcweir 			   "SdrRectObj::SdrRectObj(SdrObjKind) ist nur fuer Textrahmen gedacht");
99*cdf0e10cSrcweir 	bClosedObj=sal_True;
100*cdf0e10cSrcweir }
101*cdf0e10cSrcweir 
102*cdf0e10cSrcweir SdrRectObj::SdrRectObj(SdrObjKind eNewTextKind, const Rectangle& rRect)
103*cdf0e10cSrcweir :	SdrTextObj(eNewTextKind,rRect),
104*cdf0e10cSrcweir 	mpXPoly(NULL)
105*cdf0e10cSrcweir {
106*cdf0e10cSrcweir 	DBG_ASSERT(eTextKind==OBJ_TEXT || eTextKind==OBJ_TEXTEXT ||
107*cdf0e10cSrcweir 			   eTextKind==OBJ_OUTLINETEXT || eTextKind==OBJ_TITLETEXT,
108*cdf0e10cSrcweir 			   "SdrRectObj::SdrRectObj(SdrObjKind,...) ist nur fuer Textrahmen gedacht");
109*cdf0e10cSrcweir 	bClosedObj=sal_True;
110*cdf0e10cSrcweir }
111*cdf0e10cSrcweir 
112*cdf0e10cSrcweir SdrRectObj::SdrRectObj(SdrObjKind eNewTextKind, const Rectangle& rNewRect, SvStream& rInput, const String& rBaseURL, sal_uInt16 eFormat)
113*cdf0e10cSrcweir :    SdrTextObj(eNewTextKind,rNewRect,rInput,rBaseURL,eFormat),
114*cdf0e10cSrcweir 	mpXPoly(NULL)
115*cdf0e10cSrcweir {
116*cdf0e10cSrcweir 	DBG_ASSERT(eTextKind==OBJ_TEXT || eTextKind==OBJ_TEXTEXT ||
117*cdf0e10cSrcweir 			   eTextKind==OBJ_OUTLINETEXT || eTextKind==OBJ_TITLETEXT,
118*cdf0e10cSrcweir 			   "SdrRectObj::SdrRectObj(SdrObjKind,...) ist nur fuer Textrahmen gedacht");
119*cdf0e10cSrcweir 	bClosedObj=sal_True;
120*cdf0e10cSrcweir }
121*cdf0e10cSrcweir 
122*cdf0e10cSrcweir SdrRectObj::~SdrRectObj()
123*cdf0e10cSrcweir {
124*cdf0e10cSrcweir 	if(mpXPoly)
125*cdf0e10cSrcweir 	{
126*cdf0e10cSrcweir 		delete mpXPoly;
127*cdf0e10cSrcweir 	}
128*cdf0e10cSrcweir }
129*cdf0e10cSrcweir 
130*cdf0e10cSrcweir void SdrRectObj::SetXPolyDirty()
131*cdf0e10cSrcweir {
132*cdf0e10cSrcweir 	if(mpXPoly)
133*cdf0e10cSrcweir 	{
134*cdf0e10cSrcweir 		delete mpXPoly;
135*cdf0e10cSrcweir 		mpXPoly = 0L;
136*cdf0e10cSrcweir 	}
137*cdf0e10cSrcweir }
138*cdf0e10cSrcweir 
139*cdf0e10cSrcweir FASTBOOL SdrRectObj::PaintNeedsXPoly(long nEckRad) const
140*cdf0e10cSrcweir {
141*cdf0e10cSrcweir 	FASTBOOL bNeed=aGeo.nDrehWink!=0 || aGeo.nShearWink!=0 || nEckRad!=0;
142*cdf0e10cSrcweir 	return bNeed;
143*cdf0e10cSrcweir }
144*cdf0e10cSrcweir 
145*cdf0e10cSrcweir XPolygon SdrRectObj::ImpCalcXPoly(const Rectangle& rRect1, long nRad1) const
146*cdf0e10cSrcweir {
147*cdf0e10cSrcweir 	XPolygon aXPoly(rRect1,nRad1,nRad1);
148*cdf0e10cSrcweir 	const sal_uInt16 nPointAnz(aXPoly.GetPointCount());
149*cdf0e10cSrcweir 	XPolygon aNeuPoly(nPointAnz+1);
150*cdf0e10cSrcweir 	sal_uInt16 nShift=nPointAnz-2;
151*cdf0e10cSrcweir 	if (nRad1!=0) nShift=nPointAnz-5;
152*cdf0e10cSrcweir 	sal_uInt16 j=nShift;
153*cdf0e10cSrcweir 	for (sal_uInt16 i=1; i<nPointAnz; i++) {
154*cdf0e10cSrcweir 		aNeuPoly[i]=aXPoly[j];
155*cdf0e10cSrcweir 		aNeuPoly.SetFlags(i,aXPoly.GetFlags(j));
156*cdf0e10cSrcweir 		j++;
157*cdf0e10cSrcweir 		if (j>=nPointAnz) j=1;
158*cdf0e10cSrcweir 	}
159*cdf0e10cSrcweir 	aNeuPoly[0]=rRect1.BottomCenter();
160*cdf0e10cSrcweir 	aNeuPoly[nPointAnz]=aNeuPoly[0];
161*cdf0e10cSrcweir 	aXPoly=aNeuPoly;
162*cdf0e10cSrcweir 
163*cdf0e10cSrcweir 	// Die Winkelangaben beziehen sich immer auf die linke obere Ecke von !aRect!
164*cdf0e10cSrcweir 	if (aGeo.nShearWink!=0) ShearXPoly(aXPoly,aRect.TopLeft(),aGeo.nTan);
165*cdf0e10cSrcweir 	if (aGeo.nDrehWink!=0) RotateXPoly(aXPoly,aRect.TopLeft(),aGeo.nSin,aGeo.nCos);
166*cdf0e10cSrcweir 	return aXPoly;
167*cdf0e10cSrcweir }
168*cdf0e10cSrcweir 
169*cdf0e10cSrcweir void SdrRectObj::RecalcXPoly()
170*cdf0e10cSrcweir {
171*cdf0e10cSrcweir 	mpXPoly = new XPolygon(ImpCalcXPoly(aRect,GetEckenradius()));
172*cdf0e10cSrcweir }
173*cdf0e10cSrcweir 
174*cdf0e10cSrcweir const XPolygon& SdrRectObj::GetXPoly() const
175*cdf0e10cSrcweir {
176*cdf0e10cSrcweir 	if(!mpXPoly)
177*cdf0e10cSrcweir 	{
178*cdf0e10cSrcweir 		((SdrRectObj*)this)->RecalcXPoly();
179*cdf0e10cSrcweir 	}
180*cdf0e10cSrcweir 
181*cdf0e10cSrcweir 	return *mpXPoly;
182*cdf0e10cSrcweir }
183*cdf0e10cSrcweir 
184*cdf0e10cSrcweir void SdrRectObj::TakeObjInfo(SdrObjTransformInfoRec& rInfo) const
185*cdf0e10cSrcweir {
186*cdf0e10cSrcweir 	FASTBOOL bNoTextFrame=!IsTextFrame();
187*cdf0e10cSrcweir 	rInfo.bResizeFreeAllowed=bNoTextFrame || aGeo.nDrehWink%9000==0;
188*cdf0e10cSrcweir 	rInfo.bResizePropAllowed=sal_True;
189*cdf0e10cSrcweir 	rInfo.bRotateFreeAllowed=sal_True;
190*cdf0e10cSrcweir 	rInfo.bRotate90Allowed  =sal_True;
191*cdf0e10cSrcweir 	rInfo.bMirrorFreeAllowed=bNoTextFrame;
192*cdf0e10cSrcweir 	rInfo.bMirror45Allowed  =bNoTextFrame;
193*cdf0e10cSrcweir 	rInfo.bMirror90Allowed  =bNoTextFrame;
194*cdf0e10cSrcweir 
195*cdf0e10cSrcweir 	// allow transparence
196*cdf0e10cSrcweir 	rInfo.bTransparenceAllowed = sal_True;
197*cdf0e10cSrcweir 
198*cdf0e10cSrcweir 	// gradient depends on fillstyle
199*cdf0e10cSrcweir 	XFillStyle eFillStyle = ((XFillStyleItem&)(GetObjectItem(XATTR_FILLSTYLE))).GetValue();
200*cdf0e10cSrcweir 	rInfo.bGradientAllowed = (eFillStyle == XFILL_GRADIENT);
201*cdf0e10cSrcweir 
202*cdf0e10cSrcweir 	rInfo.bShearAllowed     =bNoTextFrame;
203*cdf0e10cSrcweir 	rInfo.bEdgeRadiusAllowed=sal_True;
204*cdf0e10cSrcweir 
205*cdf0e10cSrcweir 	FASTBOOL bCanConv=!HasText() || ImpCanConvTextToCurve();
206*cdf0e10cSrcweir 	if (bCanConv && !bNoTextFrame && !HasText()) {
207*cdf0e10cSrcweir 		bCanConv=HasFill() || HasLine();
208*cdf0e10cSrcweir 	}
209*cdf0e10cSrcweir 	rInfo.bCanConvToPath    =bCanConv;
210*cdf0e10cSrcweir 	rInfo.bCanConvToPoly    =bCanConv;
211*cdf0e10cSrcweir 	rInfo.bCanConvToContour = (rInfo.bCanConvToPoly || LineGeometryUsageIsNecessary());
212*cdf0e10cSrcweir }
213*cdf0e10cSrcweir 
214*cdf0e10cSrcweir sal_uInt16 SdrRectObj::GetObjIdentifier() const
215*cdf0e10cSrcweir {
216*cdf0e10cSrcweir 	if (IsTextFrame()) return sal_uInt16(eTextKind);
217*cdf0e10cSrcweir 	else return sal_uInt16(OBJ_RECT);
218*cdf0e10cSrcweir }
219*cdf0e10cSrcweir 
220*cdf0e10cSrcweir void SdrRectObj::TakeUnrotatedSnapRect(Rectangle& rRect) const
221*cdf0e10cSrcweir {
222*cdf0e10cSrcweir 	rRect=aRect;
223*cdf0e10cSrcweir 	if (aGeo.nShearWink!=0) {
224*cdf0e10cSrcweir 		long nDst=Round((aRect.Bottom()-aRect.Top())*aGeo.nTan);
225*cdf0e10cSrcweir 		if (aGeo.nShearWink>0) {
226*cdf0e10cSrcweir 			Point aRef(rRect.TopLeft());
227*cdf0e10cSrcweir 			rRect.Left()-=nDst;
228*cdf0e10cSrcweir 			Point aTmpPt(rRect.TopLeft());
229*cdf0e10cSrcweir 			RotatePoint(aTmpPt,aRef,aGeo.nSin,aGeo.nCos);
230*cdf0e10cSrcweir 			aTmpPt-=rRect.TopLeft();
231*cdf0e10cSrcweir 			rRect.Move(aTmpPt.X(),aTmpPt.Y());
232*cdf0e10cSrcweir 		} else {
233*cdf0e10cSrcweir 			rRect.Right()-=nDst;
234*cdf0e10cSrcweir 		}
235*cdf0e10cSrcweir 	}
236*cdf0e10cSrcweir }
237*cdf0e10cSrcweir 
238*cdf0e10cSrcweir void SdrRectObj::TakeObjNameSingul(XubString& rName) const
239*cdf0e10cSrcweir {
240*cdf0e10cSrcweir 	if (IsTextFrame())
241*cdf0e10cSrcweir 	{
242*cdf0e10cSrcweir 		SdrTextObj::TakeObjNameSingul(rName);
243*cdf0e10cSrcweir 	}
244*cdf0e10cSrcweir 	else
245*cdf0e10cSrcweir 	{
246*cdf0e10cSrcweir 		sal_uInt16 nResId=STR_ObjNameSingulRECT;
247*cdf0e10cSrcweir 		if (aGeo.nShearWink!=0) {
248*cdf0e10cSrcweir 			nResId+=4;  // Parallelogramm oder Raute
249*cdf0e10cSrcweir 			// Raute ist nicht, weil Shear die vertikalen Kanten verlaengert!
250*cdf0e10cSrcweir 			// Wenn Zeit ist, werde ich das mal berechnen.
251*cdf0e10cSrcweir 		} else {
252*cdf0e10cSrcweir 			if (aRect.GetWidth()==aRect.GetHeight()) nResId+=2; // Quadrat
253*cdf0e10cSrcweir 		}
254*cdf0e10cSrcweir 		if (GetEckenradius()!=0) nResId+=8; // abgerundet
255*cdf0e10cSrcweir 		rName=ImpGetResStr(nResId);
256*cdf0e10cSrcweir 
257*cdf0e10cSrcweir 		String aName( GetName() );
258*cdf0e10cSrcweir 		if(aName.Len())
259*cdf0e10cSrcweir 		{
260*cdf0e10cSrcweir 			rName += sal_Unicode(' ');
261*cdf0e10cSrcweir 			rName += sal_Unicode('\'');
262*cdf0e10cSrcweir 			rName += aName;
263*cdf0e10cSrcweir 			rName += sal_Unicode('\'');
264*cdf0e10cSrcweir 		}
265*cdf0e10cSrcweir 	}
266*cdf0e10cSrcweir }
267*cdf0e10cSrcweir 
268*cdf0e10cSrcweir void SdrRectObj::TakeObjNamePlural(XubString& rName) const
269*cdf0e10cSrcweir {
270*cdf0e10cSrcweir 	if (IsTextFrame()) SdrTextObj::TakeObjNamePlural(rName);
271*cdf0e10cSrcweir 	else {
272*cdf0e10cSrcweir 		sal_uInt16 nResId=STR_ObjNamePluralRECT;
273*cdf0e10cSrcweir 		if (aGeo.nShearWink!=0) {
274*cdf0e10cSrcweir 			nResId+=4;  // Parallelogramm oder Raute
275*cdf0e10cSrcweir 		} else {
276*cdf0e10cSrcweir 			if (aRect.GetWidth()==aRect.GetHeight()) nResId+=2; // Quadrat
277*cdf0e10cSrcweir 		}
278*cdf0e10cSrcweir 		if (GetEckenradius()!=0) nResId+=8; // abgerundet
279*cdf0e10cSrcweir 		rName=ImpGetResStr(nResId);
280*cdf0e10cSrcweir 	}
281*cdf0e10cSrcweir }
282*cdf0e10cSrcweir 
283*cdf0e10cSrcweir void SdrRectObj::operator=(const SdrObject& rObj)
284*cdf0e10cSrcweir {
285*cdf0e10cSrcweir 	SdrTextObj::operator=(rObj);
286*cdf0e10cSrcweir }
287*cdf0e10cSrcweir 
288*cdf0e10cSrcweir basegfx::B2DPolyPolygon SdrRectObj::TakeXorPoly() const
289*cdf0e10cSrcweir {
290*cdf0e10cSrcweir 	XPolyPolygon aXPP;
291*cdf0e10cSrcweir 	aXPP.Insert(ImpCalcXPoly(aRect,GetEckenradius()));
292*cdf0e10cSrcweir 	return aXPP.getB2DPolyPolygon();
293*cdf0e10cSrcweir }
294*cdf0e10cSrcweir 
295*cdf0e10cSrcweir void SdrRectObj::RecalcSnapRect()
296*cdf0e10cSrcweir {
297*cdf0e10cSrcweir 	long nEckRad=GetEckenradius();
298*cdf0e10cSrcweir 	if ((aGeo.nDrehWink!=0 || aGeo.nShearWink!=0) && nEckRad!=0) {
299*cdf0e10cSrcweir 		maSnapRect=GetXPoly().GetBoundRect();
300*cdf0e10cSrcweir 	} else {
301*cdf0e10cSrcweir 		SdrTextObj::RecalcSnapRect();
302*cdf0e10cSrcweir 	}
303*cdf0e10cSrcweir }
304*cdf0e10cSrcweir 
305*cdf0e10cSrcweir void SdrRectObj::NbcSetSnapRect(const Rectangle& rRect)
306*cdf0e10cSrcweir {
307*cdf0e10cSrcweir 	SdrTextObj::NbcSetSnapRect(rRect);
308*cdf0e10cSrcweir 	SetXPolyDirty();
309*cdf0e10cSrcweir }
310*cdf0e10cSrcweir 
311*cdf0e10cSrcweir void SdrRectObj::NbcSetLogicRect(const Rectangle& rRect)
312*cdf0e10cSrcweir {
313*cdf0e10cSrcweir 	SdrTextObj::NbcSetLogicRect(rRect);
314*cdf0e10cSrcweir 	SetXPolyDirty();
315*cdf0e10cSrcweir }
316*cdf0e10cSrcweir 
317*cdf0e10cSrcweir sal_uInt32 SdrRectObj::GetHdlCount() const
318*cdf0e10cSrcweir {
319*cdf0e10cSrcweir     return IsTextFrame() ? 10 : 9;
320*cdf0e10cSrcweir }
321*cdf0e10cSrcweir 
322*cdf0e10cSrcweir SdrHdl* SdrRectObj::GetHdl(sal_uInt32 nHdlNum) const
323*cdf0e10cSrcweir {
324*cdf0e10cSrcweir 	SdrHdl* pH = NULL;
325*cdf0e10cSrcweir 	Point aPnt;
326*cdf0e10cSrcweir 	SdrHdlKind eKind = HDL_MOVE;
327*cdf0e10cSrcweir 
328*cdf0e10cSrcweir     if(!IsTextFrame())
329*cdf0e10cSrcweir     {
330*cdf0e10cSrcweir         nHdlNum++;
331*cdf0e10cSrcweir     }
332*cdf0e10cSrcweir 
333*cdf0e10cSrcweir     switch(nHdlNum)
334*cdf0e10cSrcweir     {
335*cdf0e10cSrcweir         case 0:
336*cdf0e10cSrcweir         {
337*cdf0e10cSrcweir             pH = new ImpTextframeHdl(aRect);
338*cdf0e10cSrcweir 		    pH->SetObj((SdrObject*)this);
339*cdf0e10cSrcweir 		    pH->SetDrehWink(aGeo.nDrehWink);
340*cdf0e10cSrcweir             break;
341*cdf0e10cSrcweir         }
342*cdf0e10cSrcweir         case 1:
343*cdf0e10cSrcweir         {
344*cdf0e10cSrcweir             long a = GetEckenradius();
345*cdf0e10cSrcweir             long b = Max(aRect.GetWidth(),aRect.GetHeight())/2; // Wird aufgerundet, da GetWidth() eins draufaddiert
346*cdf0e10cSrcweir             if (a>b) a=b;
347*cdf0e10cSrcweir             if (a<0) a=0;
348*cdf0e10cSrcweir             aPnt=aRect.TopLeft();
349*cdf0e10cSrcweir             aPnt.X()+=a;
350*cdf0e10cSrcweir             eKind = HDL_CIRC;
351*cdf0e10cSrcweir             break;
352*cdf0e10cSrcweir         }
353*cdf0e10cSrcweir         case 2: aPnt=aRect.TopLeft();      eKind = HDL_UPLFT; break; // Oben links
354*cdf0e10cSrcweir         case 3: aPnt=aRect.TopCenter();    eKind = HDL_UPPER; break; // Oben
355*cdf0e10cSrcweir         case 4: aPnt=aRect.TopRight();     eKind = HDL_UPRGT; break; // Oben rechts
356*cdf0e10cSrcweir         case 5: aPnt=aRect.LeftCenter();   eKind = HDL_LEFT ; break; // Links
357*cdf0e10cSrcweir         case 6: aPnt=aRect.RightCenter();  eKind = HDL_RIGHT; break; // Rechts
358*cdf0e10cSrcweir         case 7: aPnt=aRect.BottomLeft();   eKind = HDL_LWLFT; break; // Unten links
359*cdf0e10cSrcweir         case 8: aPnt=aRect.BottomCenter(); eKind = HDL_LOWER; break; // Unten
360*cdf0e10cSrcweir         case 9: aPnt=aRect.BottomRight();  eKind = HDL_LWRGT; break; // Unten rechts
361*cdf0e10cSrcweir     }
362*cdf0e10cSrcweir 
363*cdf0e10cSrcweir     if(!pH)
364*cdf0e10cSrcweir     {
365*cdf0e10cSrcweir         if(aGeo.nShearWink)
366*cdf0e10cSrcweir         {
367*cdf0e10cSrcweir             ShearPoint(aPnt,aRect.TopLeft(),aGeo.nTan);
368*cdf0e10cSrcweir         }
369*cdf0e10cSrcweir 
370*cdf0e10cSrcweir         if(aGeo.nDrehWink)
371*cdf0e10cSrcweir         {
372*cdf0e10cSrcweir             RotatePoint(aPnt,aRect.TopLeft(),aGeo.nSin,aGeo.nCos);
373*cdf0e10cSrcweir         }
374*cdf0e10cSrcweir 
375*cdf0e10cSrcweir 		pH = new SdrHdl(aPnt,eKind);
376*cdf0e10cSrcweir 		pH->SetObj((SdrObject*)this);
377*cdf0e10cSrcweir 		pH->SetDrehWink(aGeo.nDrehWink);
378*cdf0e10cSrcweir 	}
379*cdf0e10cSrcweir 
380*cdf0e10cSrcweir     return pH;
381*cdf0e10cSrcweir }
382*cdf0e10cSrcweir 
383*cdf0e10cSrcweir ////////////////////////////////////////////////////////////////////////////////////////////////////
384*cdf0e10cSrcweir 
385*cdf0e10cSrcweir bool SdrRectObj::hasSpecialDrag() const
386*cdf0e10cSrcweir {
387*cdf0e10cSrcweir 	return true;
388*cdf0e10cSrcweir }
389*cdf0e10cSrcweir 
390*cdf0e10cSrcweir bool SdrRectObj::beginSpecialDrag(SdrDragStat& rDrag) const
391*cdf0e10cSrcweir {
392*cdf0e10cSrcweir 	const bool bRad(rDrag.GetHdl() && HDL_CIRC == rDrag.GetHdl()->GetKind());
393*cdf0e10cSrcweir 
394*cdf0e10cSrcweir     if(bRad)
395*cdf0e10cSrcweir     {
396*cdf0e10cSrcweir 		rDrag.SetEndDragChangesAttributes(true);
397*cdf0e10cSrcweir 
398*cdf0e10cSrcweir         return true;
399*cdf0e10cSrcweir 	}
400*cdf0e10cSrcweir 
401*cdf0e10cSrcweir     return SdrTextObj::beginSpecialDrag(rDrag);
402*cdf0e10cSrcweir }
403*cdf0e10cSrcweir 
404*cdf0e10cSrcweir bool SdrRectObj::applySpecialDrag(SdrDragStat& rDrag)
405*cdf0e10cSrcweir {
406*cdf0e10cSrcweir 	const bool bRad(rDrag.GetHdl() && HDL_CIRC == rDrag.GetHdl()->GetKind());
407*cdf0e10cSrcweir 
408*cdf0e10cSrcweir     if (bRad)
409*cdf0e10cSrcweir     {
410*cdf0e10cSrcweir 		Rectangle aBoundRect0;
411*cdf0e10cSrcweir 		Point aPt(rDrag.GetNow());
412*cdf0e10cSrcweir 
413*cdf0e10cSrcweir         if(aGeo.nDrehWink)
414*cdf0e10cSrcweir             RotatePoint(aPt,aRect.TopLeft(),-aGeo.nSin,aGeo.nCos);
415*cdf0e10cSrcweir 
416*cdf0e10cSrcweir 		sal_Int32 nRad(aPt.X() - aRect.Left());
417*cdf0e10cSrcweir 
418*cdf0e10cSrcweir         if (nRad < 0)
419*cdf0e10cSrcweir             nRad = 0;
420*cdf0e10cSrcweir 
421*cdf0e10cSrcweir         if(nRad != GetEckenradius())
422*cdf0e10cSrcweir         {
423*cdf0e10cSrcweir             NbcSetEckenradius(nRad);
424*cdf0e10cSrcweir         }
425*cdf0e10cSrcweir 
426*cdf0e10cSrcweir         return true;
427*cdf0e10cSrcweir 	}
428*cdf0e10cSrcweir     else
429*cdf0e10cSrcweir     {
430*cdf0e10cSrcweir         return SdrTextObj::applySpecialDrag(rDrag);
431*cdf0e10cSrcweir     }
432*cdf0e10cSrcweir }
433*cdf0e10cSrcweir 
434*cdf0e10cSrcweir String SdrRectObj::getSpecialDragComment(const SdrDragStat& rDrag) const
435*cdf0e10cSrcweir {
436*cdf0e10cSrcweir     const bool bCreateComment(rDrag.GetView() && this == rDrag.GetView()->GetCreateObj());
437*cdf0e10cSrcweir 
438*cdf0e10cSrcweir     if(bCreateComment)
439*cdf0e10cSrcweir     {
440*cdf0e10cSrcweir         return String();
441*cdf0e10cSrcweir     }
442*cdf0e10cSrcweir     else
443*cdf0e10cSrcweir     {
444*cdf0e10cSrcweir 	    const bool bRad(rDrag.GetHdl() && HDL_CIRC == rDrag.GetHdl()->GetKind());
445*cdf0e10cSrcweir 
446*cdf0e10cSrcweir 	    if(bRad)
447*cdf0e10cSrcweir 	    {
448*cdf0e10cSrcweir 		    Point aPt(rDrag.GetNow());
449*cdf0e10cSrcweir 
450*cdf0e10cSrcweir 		    // -sin fuer Umkehrung
451*cdf0e10cSrcweir 		    if(aGeo.nDrehWink)
452*cdf0e10cSrcweir 			    RotatePoint(aPt, aRect.TopLeft(), -aGeo.nSin, aGeo.nCos);
453*cdf0e10cSrcweir 
454*cdf0e10cSrcweir 		    sal_Int32 nRad(aPt.X() - aRect.Left());
455*cdf0e10cSrcweir 
456*cdf0e10cSrcweir 		    if(nRad < 0)
457*cdf0e10cSrcweir 			    nRad = 0;
458*cdf0e10cSrcweir 
459*cdf0e10cSrcweir 		    XubString aStr;
460*cdf0e10cSrcweir 
461*cdf0e10cSrcweir 		    ImpTakeDescriptionStr(STR_DragRectEckRad, aStr);
462*cdf0e10cSrcweir 		    aStr.AppendAscii(" (");
463*cdf0e10cSrcweir 		    aStr += GetMetrStr(nRad);
464*cdf0e10cSrcweir 		    aStr += sal_Unicode(')');
465*cdf0e10cSrcweir 
466*cdf0e10cSrcweir 		    return aStr;
467*cdf0e10cSrcweir 	    }
468*cdf0e10cSrcweir 	    else
469*cdf0e10cSrcweir 	    {
470*cdf0e10cSrcweir 		    return SdrTextObj::getSpecialDragComment(rDrag);
471*cdf0e10cSrcweir 	    }
472*cdf0e10cSrcweir     }
473*cdf0e10cSrcweir }
474*cdf0e10cSrcweir 
475*cdf0e10cSrcweir ////////////////////////////////////////////////////////////////////////////////////////////////////
476*cdf0e10cSrcweir 
477*cdf0e10cSrcweir basegfx::B2DPolyPolygon SdrRectObj::TakeCreatePoly(const SdrDragStat& rDrag) const
478*cdf0e10cSrcweir {
479*cdf0e10cSrcweir 	Rectangle aRect1;
480*cdf0e10cSrcweir 	rDrag.TakeCreateRect(aRect1);
481*cdf0e10cSrcweir 	aRect1.Justify();
482*cdf0e10cSrcweir 
483*cdf0e10cSrcweir 	basegfx::B2DPolyPolygon aRetval;
484*cdf0e10cSrcweir 	aRetval.append(ImpCalcXPoly(aRect1,GetEckenradius()).getB2DPolygon());
485*cdf0e10cSrcweir 	return aRetval;
486*cdf0e10cSrcweir }
487*cdf0e10cSrcweir 
488*cdf0e10cSrcweir Pointer SdrRectObj::GetCreatePointer() const
489*cdf0e10cSrcweir {
490*cdf0e10cSrcweir 	if (IsTextFrame()) return Pointer(POINTER_DRAW_TEXT);
491*cdf0e10cSrcweir 	return Pointer(POINTER_DRAW_RECT);
492*cdf0e10cSrcweir }
493*cdf0e10cSrcweir 
494*cdf0e10cSrcweir void SdrRectObj::NbcMove(const Size& rSiz)
495*cdf0e10cSrcweir {
496*cdf0e10cSrcweir 	SdrTextObj::NbcMove(rSiz);
497*cdf0e10cSrcweir 	SetXPolyDirty();
498*cdf0e10cSrcweir }
499*cdf0e10cSrcweir 
500*cdf0e10cSrcweir void SdrRectObj::NbcResize(const Point& rRef, const Fraction& xFact, const Fraction& yFact)
501*cdf0e10cSrcweir {
502*cdf0e10cSrcweir 	SdrTextObj::NbcResize(rRef,xFact,yFact);
503*cdf0e10cSrcweir 	SetXPolyDirty();
504*cdf0e10cSrcweir }
505*cdf0e10cSrcweir 
506*cdf0e10cSrcweir void SdrRectObj::NbcRotate(const Point& rRef, long nWink, double sn, double cs)
507*cdf0e10cSrcweir {
508*cdf0e10cSrcweir 	SdrTextObj::NbcRotate(rRef,nWink,sn,cs);
509*cdf0e10cSrcweir 	SetXPolyDirty();
510*cdf0e10cSrcweir }
511*cdf0e10cSrcweir 
512*cdf0e10cSrcweir void SdrRectObj::NbcShear(const Point& rRef, long nWink, double tn, FASTBOOL bVShear)
513*cdf0e10cSrcweir {
514*cdf0e10cSrcweir 	SdrTextObj::NbcShear(rRef,nWink,tn,bVShear);
515*cdf0e10cSrcweir 	SetXPolyDirty();
516*cdf0e10cSrcweir }
517*cdf0e10cSrcweir 
518*cdf0e10cSrcweir void SdrRectObj::NbcMirror(const Point& rRef1, const Point& rRef2)
519*cdf0e10cSrcweir {
520*cdf0e10cSrcweir 	SdrTextObj::NbcMirror(rRef1,rRef2);
521*cdf0e10cSrcweir 	SetXPolyDirty();
522*cdf0e10cSrcweir }
523*cdf0e10cSrcweir 
524*cdf0e10cSrcweir FASTBOOL SdrRectObj::DoMacro(const SdrObjMacroHitRec& rRec)
525*cdf0e10cSrcweir {
526*cdf0e10cSrcweir 	return SdrTextObj::DoMacro(rRec);
527*cdf0e10cSrcweir }
528*cdf0e10cSrcweir 
529*cdf0e10cSrcweir XubString SdrRectObj::GetMacroPopupComment(const SdrObjMacroHitRec& rRec) const
530*cdf0e10cSrcweir {
531*cdf0e10cSrcweir 	return SdrTextObj::GetMacroPopupComment(rRec);
532*cdf0e10cSrcweir }
533*cdf0e10cSrcweir 
534*cdf0e10cSrcweir SdrGluePoint SdrRectObj::GetVertexGluePoint(sal_uInt16 nPosNum) const
535*cdf0e10cSrcweir {
536*cdf0e10cSrcweir 	sal_Int32 nWdt = ImpGetLineWdt(); // #i25616# ((XLineWidthItem&)(GetObjectItem(XATTR_LINEWIDTH))).GetValue();
537*cdf0e10cSrcweir 
538*cdf0e10cSrcweir 	// #i25616#
539*cdf0e10cSrcweir 	if(!LineIsOutsideGeometry())
540*cdf0e10cSrcweir 	{
541*cdf0e10cSrcweir 		nWdt++;
542*cdf0e10cSrcweir 		nWdt /= 2;
543*cdf0e10cSrcweir 	}
544*cdf0e10cSrcweir 
545*cdf0e10cSrcweir 	Point aPt;
546*cdf0e10cSrcweir 	switch (nPosNum) {
547*cdf0e10cSrcweir 		case 0: aPt=aRect.TopCenter();    aPt.Y()-=nWdt; break;
548*cdf0e10cSrcweir 		case 1: aPt=aRect.RightCenter();  aPt.X()+=nWdt; break;
549*cdf0e10cSrcweir 		case 2: aPt=aRect.BottomCenter(); aPt.Y()+=nWdt; break;
550*cdf0e10cSrcweir 		case 3: aPt=aRect.LeftCenter();   aPt.X()-=nWdt; break;
551*cdf0e10cSrcweir 	}
552*cdf0e10cSrcweir 	if (aGeo.nShearWink!=0) ShearPoint(aPt,aRect.TopLeft(),aGeo.nTan);
553*cdf0e10cSrcweir 	if (aGeo.nDrehWink!=0) RotatePoint(aPt,aRect.TopLeft(),aGeo.nSin,aGeo.nCos);
554*cdf0e10cSrcweir 	aPt-=GetSnapRect().Center();
555*cdf0e10cSrcweir 	SdrGluePoint aGP(aPt);
556*cdf0e10cSrcweir 	aGP.SetPercent(sal_False);
557*cdf0e10cSrcweir 	return aGP;
558*cdf0e10cSrcweir }
559*cdf0e10cSrcweir 
560*cdf0e10cSrcweir SdrGluePoint SdrRectObj::GetCornerGluePoint(sal_uInt16 nPosNum) const
561*cdf0e10cSrcweir {
562*cdf0e10cSrcweir 	sal_Int32 nWdt = ImpGetLineWdt(); // #i25616# ((XLineWidthItem&)(GetObjectItem(XATTR_LINEWIDTH))).GetValue();
563*cdf0e10cSrcweir 
564*cdf0e10cSrcweir 	// #i25616#
565*cdf0e10cSrcweir 	if(!LineIsOutsideGeometry())
566*cdf0e10cSrcweir 	{
567*cdf0e10cSrcweir 		nWdt++;
568*cdf0e10cSrcweir 		nWdt /= 2;
569*cdf0e10cSrcweir 	}
570*cdf0e10cSrcweir 
571*cdf0e10cSrcweir 	Point aPt;
572*cdf0e10cSrcweir 	switch (nPosNum) {
573*cdf0e10cSrcweir 		case 0: aPt=aRect.TopLeft();     aPt.X()-=nWdt; aPt.Y()-=nWdt; break;
574*cdf0e10cSrcweir 		case 1: aPt=aRect.TopRight();    aPt.X()+=nWdt; aPt.Y()-=nWdt; break;
575*cdf0e10cSrcweir 		case 2: aPt=aRect.BottomRight(); aPt.X()+=nWdt; aPt.Y()+=nWdt; break;
576*cdf0e10cSrcweir 		case 3: aPt=aRect.BottomLeft();  aPt.X()-=nWdt; aPt.Y()+=nWdt; break;
577*cdf0e10cSrcweir 	}
578*cdf0e10cSrcweir 	if (aGeo.nShearWink!=0) ShearPoint(aPt,aRect.TopLeft(),aGeo.nTan);
579*cdf0e10cSrcweir 	if (aGeo.nDrehWink!=0) RotatePoint(aPt,aRect.TopLeft(),aGeo.nSin,aGeo.nCos);
580*cdf0e10cSrcweir 	aPt-=GetSnapRect().Center();
581*cdf0e10cSrcweir 	SdrGluePoint aGP(aPt);
582*cdf0e10cSrcweir 	aGP.SetPercent(sal_False);
583*cdf0e10cSrcweir 	return aGP;
584*cdf0e10cSrcweir }
585*cdf0e10cSrcweir 
586*cdf0e10cSrcweir SdrObject* SdrRectObj::DoConvertToPolyObj(sal_Bool bBezier) const
587*cdf0e10cSrcweir {
588*cdf0e10cSrcweir 	XPolygon aXP(ImpCalcXPoly(aRect,GetEckenradius()));
589*cdf0e10cSrcweir 	{ // #40608# Nur Uebergangsweise bis zum neuen TakeContour()
590*cdf0e10cSrcweir 		aXP.Remove(0,1);
591*cdf0e10cSrcweir 		aXP[aXP.GetPointCount()-1]=aXP[0];
592*cdf0e10cSrcweir 	}
593*cdf0e10cSrcweir 
594*cdf0e10cSrcweir 	basegfx::B2DPolyPolygon aPolyPolygon(aXP.getB2DPolygon());
595*cdf0e10cSrcweir     aPolyPolygon.removeDoublePoints();
596*cdf0e10cSrcweir 	SdrObject* pRet = 0L;
597*cdf0e10cSrcweir 
598*cdf0e10cSrcweir 	if(!IsTextFrame() || HasFill() || HasLine())
599*cdf0e10cSrcweir 	{
600*cdf0e10cSrcweir 		pRet = ImpConvertMakeObj(aPolyPolygon, sal_True, bBezier);
601*cdf0e10cSrcweir 	}
602*cdf0e10cSrcweir 
603*cdf0e10cSrcweir 	pRet = ImpConvertAddText(pRet, bBezier);
604*cdf0e10cSrcweir 
605*cdf0e10cSrcweir 	return pRet;
606*cdf0e10cSrcweir }
607*cdf0e10cSrcweir 
608*cdf0e10cSrcweir void SdrRectObj::Notify(SfxBroadcaster& rBC, const SfxHint& rHint)
609*cdf0e10cSrcweir {
610*cdf0e10cSrcweir 	SdrTextObj::Notify(rBC,rHint);
611*cdf0e10cSrcweir 	SetXPolyDirty(); // wg. Eckenradius
612*cdf0e10cSrcweir }
613*cdf0e10cSrcweir 
614*cdf0e10cSrcweir void SdrRectObj::RestGeoData(const SdrObjGeoData& rGeo)
615*cdf0e10cSrcweir {
616*cdf0e10cSrcweir 	SdrTextObj::RestGeoData(rGeo);
617*cdf0e10cSrcweir 	SetXPolyDirty();
618*cdf0e10cSrcweir }
619*cdf0e10cSrcweir 
620*cdf0e10cSrcweir // eof
621