bump product version to 4.1.6.2
[LibreOffice.git] / include / svx / lathe3d.hxx
blobc43c4265bb2c813593fc968f450bfd4637b0e728
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 .
20 #ifndef _E3D_LATHE3D_HXX
21 #define _E3D_LATHE3D_HXX
23 #include <svx/obj3d.hxx>
24 #include "svx/svxdllapi.h"
26 /*************************************************************************
28 |* Create a 3D rotation object from a passed 2D polygon
30 |* The aPolyPoly3D is rotated around its axis in nHSegments steps.
31 |* nVSegments contains the number of lines of aPolyPoly3D and therefore
32 |* is effectively a vertical segmentation.
34 \************************************************************************/
36 class SVX_DLLPUBLIC E3dLatheObj : public E3dCompoundObject
38 private:
39 // Part codes for Wireframe generation: standard oder cover surface
40 enum { LATHE_PART_STD = 1, LATHE_PART_COVER = 2 };
41 basegfx::B2DPolyPolygon maPolyPoly2D;
43 protected:
44 virtual sdr::contact::ViewContact* CreateObjectSpecificViewContact();
45 virtual sdr::properties::BaseProperties* CreateObjectSpecificProperties();
46 void SetDefaultAttributes(E3dDefaultAttributes& rDefault);
48 public:
49 TYPEINFO();
50 E3dLatheObj(E3dDefaultAttributes& rDefault, const basegfx::B2DPolyPolygon rPoly2D);
51 E3dLatheObj();
53 // HorizontalSegments:
54 sal_uInt32 GetHorizontalSegments() const
55 { return ((const Svx3DHorizontalSegmentsItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_HORZ_SEGS)).GetValue(); }
57 // VerticalSegments:
58 sal_uInt32 GetVerticalSegments() const
59 { return ((const Svx3DVerticalSegmentsItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_VERT_SEGS)).GetValue(); }
61 // PercentDiagonal: 0..100, before 0.0..0.5
62 sal_uInt16 GetPercentDiagonal() const
63 { return ((const Svx3DPercentDiagonalItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_PERCENT_DIAGONAL)).GetValue(); }
65 // BackScale: 0..100, before 0.0..1.0
66 sal_uInt16 GetBackScale() const
67 { return ((const Svx3DBackscaleItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_BACKSCALE)).GetValue(); }
69 // EndAngle: 0..10000
70 sal_uInt32 GetEndAngle() const
71 { return ((const Svx3DEndAngleItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_END_ANGLE)).GetValue(); }
73 // #107245# GetSmoothNormals() for bLatheSmoothed
74 sal_Bool GetSmoothNormals() const
75 { return ((const Svx3DSmoothNormalsItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_SMOOTH_NORMALS)).GetValue(); }
77 // #107245# GetSmoothLids() for bLatheSmoothFrontBack
78 sal_Bool GetSmoothLids() const
79 { return ((const Svx3DSmoothLidsItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_SMOOTH_LIDS)).GetValue(); }
81 // #107245# GetCharacterMode() for bLatheCharacterMode
82 sal_Bool GetCharacterMode() const
83 { return ((const Svx3DCharacterModeItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_CHARACTER_MODE)).GetValue(); }
85 // #107245# GetCloseFront() for bLatheCloseFront
86 sal_Bool GetCloseFront() const
87 { return ((const Svx3DCloseFrontItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_CLOSE_FRONT)).GetValue(); }
89 // #107245# GetCloseBack() for bLatheCloseBack
90 sal_Bool GetCloseBack() const
91 { return ((const Svx3DCloseBackItem&)GetObjectItemSet().Get(SDRATTR_3DOBJ_CLOSE_BACK)).GetValue(); }
93 virtual sal_uInt16 GetObjIdentifier() const;
95 virtual E3dLatheObj* Clone() const;
97 virtual SdrObject* DoConvertToPolyObj(sal_Bool bBezier, bool bAddText) const;
99 // TakeObjName...() is for the display in the UI, for example "3 frames selected".
100 virtual void TakeObjNameSingul(String& rName) const;
101 virtual void TakeObjNamePlural(String& rName) const;
103 // set/get local parameters with geometry recreation
104 void SetPolyPoly2D(const basegfx::B2DPolyPolygon& rNew);
105 const basegfx::B2DPolyPolygon& GetPolyPoly2D() { return maPolyPoly2D; }
107 // break up
108 virtual bool IsBreakObjPossible();
109 virtual SdrAttrObj* GetBreakObj();
112 #endif // _E3D_LATHE3D_HXX
114 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */