xref: /AOO41X/main/drawinglayer/source/primitive2d/fillhatchprimitive2d.cxx (revision 0702bc67a2ac2836add565ba470821c1aa4db6ed)
1464702f4SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3464702f4SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4464702f4SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5464702f4SAndrew Rist  * distributed with this work for additional information
6464702f4SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7464702f4SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8464702f4SAndrew Rist  * "License"); you may not use this file except in compliance
9464702f4SAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11464702f4SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13464702f4SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14464702f4SAndrew Rist  * software distributed under the License is distributed on an
15464702f4SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16464702f4SAndrew Rist  * KIND, either express or implied.  See the License for the
17464702f4SAndrew Rist  * specific language governing permissions and limitations
18464702f4SAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20464702f4SAndrew Rist  *************************************************************/
21464702f4SAndrew Rist 
22464702f4SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_drawinglayer.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir #include <drawinglayer/primitive2d/fillhatchprimitive2d.hxx>
28cdf0e10cSrcweir #include <drawinglayer/texture/texture.hxx>
29cdf0e10cSrcweir #include <drawinglayer/primitive2d/polypolygonprimitive2d.hxx>
30cdf0e10cSrcweir #include <basegfx/polygon/b2dpolygontools.hxx>
31cdf0e10cSrcweir #include <basegfx/polygon/b2dpolygon.hxx>
32cdf0e10cSrcweir #include <basegfx/tools/canvastools.hxx>
33cdf0e10cSrcweir #include <drawinglayer/primitive2d/polygonprimitive2d.hxx>
34cdf0e10cSrcweir #include <drawinglayer/primitive2d/drawinglayer_primitivetypes2d.hxx>
35*0702bc67SArmin Le Grand #include <drawinglayer/geometry/viewinformation2d.hxx>
36cdf0e10cSrcweir 
37cdf0e10cSrcweir //////////////////////////////////////////////////////////////////////////////
38cdf0e10cSrcweir 
39cdf0e10cSrcweir using namespace com::sun::star;
40cdf0e10cSrcweir 
41cdf0e10cSrcweir //////////////////////////////////////////////////////////////////////////////
42cdf0e10cSrcweir 
43cdf0e10cSrcweir namespace drawinglayer
44cdf0e10cSrcweir {
45cdf0e10cSrcweir 	namespace primitive2d
46cdf0e10cSrcweir 	{
create2DDecomposition(const geometry::ViewInformation2D &) const47cdf0e10cSrcweir 		Primitive2DSequence FillHatchPrimitive2D::create2DDecomposition(const geometry::ViewInformation2D& /*rViewInformation*/) const
48cdf0e10cSrcweir 		{
49cdf0e10cSrcweir 		    Primitive2DSequence aRetval;
50*0702bc67SArmin Le Grand 
51cdf0e10cSrcweir             if(!getFillHatch().isDefault())
52cdf0e10cSrcweir             {
53cdf0e10cSrcweir 			    // create hatch
54cdf0e10cSrcweir 			    const basegfx::BColor aHatchColor(getFillHatch().getColor());
55cdf0e10cSrcweir 			    const double fAngle(getFillHatch().getAngle());
56cdf0e10cSrcweir 			    ::std::vector< basegfx::B2DHomMatrix > aMatrices;
57*0702bc67SArmin Le Grand                 double fDistance(getFillHatch().getDistance());
58*0702bc67SArmin Le Grand                 const bool bAdaptDistance(0 != getFillHatch().getMinimalDiscreteDistance());
59*0702bc67SArmin Le Grand 
60*0702bc67SArmin Le Grand                 // #120230# evtl. adapt distance
61*0702bc67SArmin Le Grand                 if(bAdaptDistance)
62*0702bc67SArmin Le Grand                 {
63*0702bc67SArmin Le Grand                     const double fDiscreteDistance(getFillHatch().getDistance() / getDiscreteUnit());
64*0702bc67SArmin Le Grand 
65*0702bc67SArmin Le Grand                     if(fDiscreteDistance < (double)getFillHatch().getMinimalDiscreteDistance())
66*0702bc67SArmin Le Grand                     {
67*0702bc67SArmin Le Grand                         fDistance = (double)getFillHatch().getMinimalDiscreteDistance() * getDiscreteUnit();
68*0702bc67SArmin Le Grand                     }
69*0702bc67SArmin Le Grand                 }
70cdf0e10cSrcweir 
71cdf0e10cSrcweir 			    // get hatch transformations
72cdf0e10cSrcweir 			    switch(getFillHatch().getStyle())
73cdf0e10cSrcweir 			    {
74cdf0e10cSrcweir 				    case attribute::HATCHSTYLE_TRIPLE:
75cdf0e10cSrcweir 				    {
76cdf0e10cSrcweir 					    // rotated 45 degrees
77*0702bc67SArmin Le Grand 					    texture::GeoTexSvxHatch aHatch(getObjectRange(), fDistance, fAngle - F_PI4);
78cdf0e10cSrcweir 					    aHatch.appendTransformations(aMatrices);
79cdf0e10cSrcweir 
80cdf0e10cSrcweir 					    // fall-through by purpose
81cdf0e10cSrcweir 				    }
82cdf0e10cSrcweir 				    case attribute::HATCHSTYLE_DOUBLE:
83cdf0e10cSrcweir 				    {
84cdf0e10cSrcweir 					    // rotated 90 degrees
85*0702bc67SArmin Le Grand 					    texture::GeoTexSvxHatch aHatch(getObjectRange(), fDistance, fAngle - F_PI2);
86cdf0e10cSrcweir 					    aHatch.appendTransformations(aMatrices);
87cdf0e10cSrcweir 
88cdf0e10cSrcweir 					    // fall-through by purpose
89cdf0e10cSrcweir 				    }
90cdf0e10cSrcweir 				    case attribute::HATCHSTYLE_SINGLE:
91cdf0e10cSrcweir 				    {
92cdf0e10cSrcweir 					    // angle as given
93*0702bc67SArmin Le Grand 					    texture::GeoTexSvxHatch aHatch(getObjectRange(), fDistance, fAngle);
94cdf0e10cSrcweir 					    aHatch.appendTransformations(aMatrices);
95cdf0e10cSrcweir 				    }
96cdf0e10cSrcweir 			    }
97cdf0e10cSrcweir 
98cdf0e10cSrcweir 			    // prepare return value
99cdf0e10cSrcweir 			    const bool bFillBackground(getFillHatch().isFillBackground());
100cdf0e10cSrcweir 			    aRetval.realloc(bFillBackground ? aMatrices.size() + 1L : aMatrices.size());
101cdf0e10cSrcweir 
102cdf0e10cSrcweir 			    // evtl. create filled background
103cdf0e10cSrcweir 			    if(bFillBackground)
104cdf0e10cSrcweir 			    {
105cdf0e10cSrcweir 				    // create primitive for background
106cdf0e10cSrcweir 				    const Primitive2DReference xRef(
107cdf0e10cSrcweir                         new PolyPolygonColorPrimitive2D(
108cdf0e10cSrcweir                             basegfx::B2DPolyPolygon(
109cdf0e10cSrcweir                                 basegfx::tools::createPolygonFromRect(getObjectRange())), getBColor()));
110cdf0e10cSrcweir 				    aRetval[0] = xRef;
111cdf0e10cSrcweir 			    }
112cdf0e10cSrcweir 
113cdf0e10cSrcweir 			    // create primitives
114cdf0e10cSrcweir 			    const basegfx::B2DPoint aStart(0.0, 0.0);
115cdf0e10cSrcweir 			    const basegfx::B2DPoint aEnd(1.0, 0.0);
116cdf0e10cSrcweir 
117cdf0e10cSrcweir 			    for(sal_uInt32 a(0L); a < aMatrices.size(); a++)
118cdf0e10cSrcweir 			    {
119cdf0e10cSrcweir 				    const basegfx::B2DHomMatrix& rMatrix = aMatrices[a];
120cdf0e10cSrcweir 				    basegfx::B2DPolygon aNewLine;
121cdf0e10cSrcweir 
122cdf0e10cSrcweir 				    aNewLine.append(rMatrix * aStart);
123cdf0e10cSrcweir 				    aNewLine.append(rMatrix * aEnd);
124cdf0e10cSrcweir 
125cdf0e10cSrcweir 				    // create hairline
126cdf0e10cSrcweir 				    const Primitive2DReference xRef(new PolygonHairlinePrimitive2D(aNewLine, aHatchColor));
127cdf0e10cSrcweir 				    aRetval[bFillBackground ? (a + 1) : a] = xRef;
128cdf0e10cSrcweir 			    }
129cdf0e10cSrcweir             }
130cdf0e10cSrcweir 
131cdf0e10cSrcweir             return aRetval;
132cdf0e10cSrcweir 		}
133cdf0e10cSrcweir 
FillHatchPrimitive2D(const basegfx::B2DRange & rObjectRange,const basegfx::BColor & rBColor,const attribute::FillHatchAttribute & rFillHatch)134cdf0e10cSrcweir 		FillHatchPrimitive2D::FillHatchPrimitive2D(
135cdf0e10cSrcweir 			const basegfx::B2DRange& rObjectRange,
136cdf0e10cSrcweir 			const basegfx::BColor& rBColor,
137cdf0e10cSrcweir 			const attribute::FillHatchAttribute& rFillHatch)
138*0702bc67SArmin Le Grand 		:	DiscreteMetricDependentPrimitive2D(),
139cdf0e10cSrcweir 			maObjectRange(rObjectRange),
140cdf0e10cSrcweir 			maFillHatch(rFillHatch),
141cdf0e10cSrcweir 			maBColor(rBColor)
142cdf0e10cSrcweir 		{
143cdf0e10cSrcweir 		}
144cdf0e10cSrcweir 
operator ==(const BasePrimitive2D & rPrimitive) const145cdf0e10cSrcweir 		bool FillHatchPrimitive2D::operator==(const BasePrimitive2D& rPrimitive) const
146cdf0e10cSrcweir 		{
147*0702bc67SArmin Le Grand 			if(DiscreteMetricDependentPrimitive2D::operator==(rPrimitive))
148cdf0e10cSrcweir 			{
149cdf0e10cSrcweir 				const FillHatchPrimitive2D& rCompare = (FillHatchPrimitive2D&)rPrimitive;
150cdf0e10cSrcweir 
151cdf0e10cSrcweir 				return (getObjectRange() == rCompare.getObjectRange()
152cdf0e10cSrcweir 					&& getFillHatch() == rCompare.getFillHatch()
153cdf0e10cSrcweir 					&& getBColor() == rCompare.getBColor());
154cdf0e10cSrcweir 			}
155cdf0e10cSrcweir 
156cdf0e10cSrcweir 			return false;
157cdf0e10cSrcweir 		}
158cdf0e10cSrcweir 
getB2DRange(const geometry::ViewInformation2D &) const159cdf0e10cSrcweir 		basegfx::B2DRange FillHatchPrimitive2D::getB2DRange(const geometry::ViewInformation2D& /*rViewInformation*/) const
160cdf0e10cSrcweir 		{
161cdf0e10cSrcweir 			// return ObjectRange
162cdf0e10cSrcweir 			return getObjectRange();
163cdf0e10cSrcweir 		}
164cdf0e10cSrcweir 
get2DDecomposition(const geometry::ViewInformation2D & rViewInformation) const165*0702bc67SArmin Le Grand 		Primitive2DSequence FillHatchPrimitive2D::get2DDecomposition(const geometry::ViewInformation2D& rViewInformation) const
166*0702bc67SArmin Le Grand         {
167*0702bc67SArmin Le Grand 			::osl::MutexGuard aGuard( m_aMutex );
168*0702bc67SArmin Le Grand             bool bAdaptDistance(0 != getFillHatch().getMinimalDiscreteDistance());
169*0702bc67SArmin Le Grand 
170*0702bc67SArmin Le Grand             if(bAdaptDistance)
171*0702bc67SArmin Le Grand             {
172*0702bc67SArmin Le Grand                 // behave view-dependent
173*0702bc67SArmin Le Grand                 return DiscreteMetricDependentPrimitive2D::get2DDecomposition(rViewInformation);
174*0702bc67SArmin Le Grand             }
175*0702bc67SArmin Le Grand             else
176*0702bc67SArmin Le Grand             {
177*0702bc67SArmin Le Grand                 // behave view-independent
178*0702bc67SArmin Le Grand                 return BufferedDecompositionPrimitive2D::get2DDecomposition(rViewInformation);
179*0702bc67SArmin Le Grand             }
180*0702bc67SArmin Le Grand         }
181*0702bc67SArmin Le Grand 
182cdf0e10cSrcweir         // provide unique ID
183cdf0e10cSrcweir 		ImplPrimitrive2DIDBlock(FillHatchPrimitive2D, PRIMITIVE2D_ID_FILLHATCHPRIMITIVE2D)
184cdf0e10cSrcweir 
185cdf0e10cSrcweir 	} // end of namespace primitive2d
186cdf0e10cSrcweir } // end of namespace drawinglayer
187cdf0e10cSrcweir 
188cdf0e10cSrcweir //////////////////////////////////////////////////////////////////////////////
189cdf0e10cSrcweir // eof
190