1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
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/svdstr.hrc"
22 #include "svx/svdglob.hxx"
23 #include <tools/poly.hxx>
24 #include <svx/svdpage.hxx>
25 #include "svx/globl3d.hxx"
26 #include <svx/lathe3d.hxx>
27 #include <svx/xpoly.hxx>
28 #include <svx/svxids.hrc>
29 #include <svx/svdopath.hxx>
30 #include <svx/svdmodel.hxx>
31 #include <svx/svx3ditems.hxx>
32 #include <svx/sdr/properties/e3dlatheproperties.hxx>
33 #include <svx/sdr/contact/viewcontactofe3dlathe.hxx>
34 #include <basegfx/polygon/b2dpolypolygontools.hxx>
35 #include <basegfx/polygon/b2dpolygontools.hxx>
36 #include <basegfx/matrix/b2dhommatrix.hxx>
38 //////////////////////////////////////////////////////////////////////////////
39 // DrawContact section
41 sdr::contact::ViewContact
* E3dLatheObj::CreateObjectSpecificViewContact()
43 return new sdr::contact::ViewContactOfE3dLathe(*this);
46 //////////////////////////////////////////////////////////////////////////////
48 sdr::properties::BaseProperties
* E3dLatheObj::CreateObjectSpecificProperties()
50 return new sdr::properties::E3dLatheProperties(*this);
53 //////////////////////////////////////////////////////////////////////////////
55 TYPEINIT1(E3dLatheObj
, E3dCompoundObject
);
57 // Constructor from 3D polygon, scale is the conversion factor for the coordinates
59 E3dLatheObj::E3dLatheObj(E3dDefaultAttributes
& rDefault
, const basegfx::B2DPolyPolygon rPoly2D
)
60 : E3dCompoundObject(rDefault
),
63 // since the old class PolyPolygon3D did mirror the given PolyPolygons in Y, do the same here
64 basegfx::B2DHomMatrix aMirrorY
;
65 aMirrorY
.scale(1.0, -1.0);
66 maPolyPoly2D
.transform(aMirrorY
);
69 SetDefaultAttributes(rDefault
);
71 // Superfluous items removed, in particular to prevent duplicate
72 // start and end points
73 maPolyPoly2D
.removeDoublePoints();
75 if(maPolyPoly2D
.count())
77 const basegfx::B2DPolygon
rPoly(maPolyPoly2D
.getB2DPolygon(0L));
78 sal_uInt32
nSegCnt(rPoly
.count());
80 if(nSegCnt
&& !rPoly
.isClosed())
85 GetProperties().SetObjectItemDirect(Svx3DVerticalSegmentsItem(nSegCnt
));
89 E3dLatheObj::E3dLatheObj()
93 E3dDefaultAttributes aDefault
;
94 SetDefaultAttributes(aDefault
);
97 void E3dLatheObj::SetDefaultAttributes(E3dDefaultAttributes
& rDefault
)
99 GetProperties().SetObjectItemDirect(Svx3DSmoothNormalsItem(rDefault
.GetDefaultLatheSmoothed()));
100 GetProperties().SetObjectItemDirect(Svx3DSmoothLidsItem(rDefault
.GetDefaultLatheSmoothFrontBack()));
101 GetProperties().SetObjectItemDirect(Svx3DCharacterModeItem(rDefault
.GetDefaultLatheCharacterMode()));
102 GetProperties().SetObjectItemDirect(Svx3DCloseFrontItem(rDefault
.GetDefaultLatheCloseFront()));
103 GetProperties().SetObjectItemDirect(Svx3DCloseBackItem(rDefault
.GetDefaultLatheCloseBack()));
106 sal_uInt16
E3dLatheObj::GetObjIdentifier() const
108 return E3D_LATHEOBJ_ID
;
111 E3dLatheObj
* E3dLatheObj::Clone() const
113 return CloneHelper
< E3dLatheObj
>();
116 // Convert the object to group object consisting of n polygons
118 SdrObject
*E3dLatheObj::DoConvertToPolyObj(sal_Bool
/*bBezier*/, bool /*bAddText*/) const
123 // Set Local parameters set to re-create geometry
125 void E3dLatheObj::SetPolyPoly2D(const basegfx::B2DPolyPolygon
& rNew
)
127 if(maPolyPoly2D
!= rNew
)
130 maPolyPoly2D
.removeDoublePoints();
132 if(maPolyPoly2D
.count())
134 const basegfx::B2DPolygon
rPoly(maPolyPoly2D
.getB2DPolygon(0L));
135 sal_uInt32
nSegCnt(rPoly
.count());
137 if(nSegCnt
&& !rPoly
.isClosed())
142 GetProperties().SetObjectItemDirect(Svx3DVerticalSegmentsItem(nSegCnt
));
149 // Get the name of the object (singular)
151 void E3dLatheObj::TakeObjNameSingul(XubString
& rName
) const
153 rName
=ImpGetResStr(STR_ObjNameSingulLathe3d
);
155 String
aName( GetName() );
158 rName
+= sal_Unicode(' ');
159 rName
+= sal_Unicode('\'');
161 rName
+= sal_Unicode('\'');
165 // Get the name of the object (plural)
167 void E3dLatheObj::TakeObjNamePlural(XubString
& rName
) const
169 rName
=ImpGetResStr(STR_ObjNamePluralLathe3d
);
172 bool E3dLatheObj::IsBreakObjPossible()
177 SdrAttrObj
* E3dLatheObj::GetBreakObj()
180 basegfx::B3DPolyPolygon
aLathePoly3D(basegfx::tools::createB3DPolyPolygonFromB2DPolyPolygon(maPolyPoly2D
));
181 basegfx::B2DPolyPolygon
aTransPoly(TransformToScreenCoor(aLathePoly3D
));
182 SdrPathObj
* pPathObj
= new SdrPathObj(OBJ_PLIN
, aTransPoly
);
187 SfxItemSet
aSet(GetObjectItemSet());
189 // Enable lines to guarantee that the object becomes visible
190 aSet
.Put(XLineStyleItem(XLINE_SOLID
));
192 pPathObj
->SetMergedItemSet(aSet
);
198 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */