1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 // MARKER(update_precomp.py): autogen include statement, do not remove
25 #include "precompiled_drawinglayer.hxx"
26 
27 #include <drawinglayer/processor2d/linegeometryextractor2d.hxx>
28 #include <drawinglayer/primitive2d/drawinglayer_primitivetypes2d.hxx>
29 #include <drawinglayer/primitive2d/polygonprimitive2d.hxx>
30 #include <drawinglayer/primitive2d/polypolygonprimitive2d.hxx>
31 #include <drawinglayer/primitive2d/transformprimitive2d.hxx>
32 
33 //////////////////////////////////////////////////////////////////////////////
34 
35 using namespace com::sun::star;
36 
37 //////////////////////////////////////////////////////////////////////////////
38 
39 namespace drawinglayer
40 {
41 	namespace processor2d
42 	{
43 		LineGeometryExtractor2D::LineGeometryExtractor2D(const geometry::ViewInformation2D& rViewInformation)
44 		:	BaseProcessor2D(rViewInformation),
45 			maExtractedHairlines(),
46 			maExtractedLineFills(),
47             mbInLineGeometry(false)
48 		{
49 		}
50 
51 		LineGeometryExtractor2D::~LineGeometryExtractor2D()
52 		{
53 		}
54 
55 		void LineGeometryExtractor2D::processBasePrimitive2D(const primitive2d::BasePrimitive2D& rCandidate)
56 		{
57 			switch(rCandidate.getPrimitive2DID())
58 			{
59 				case PRIMITIVE2D_ID_POLYGONSTROKEPRIMITIVE2D :
60 				case PRIMITIVE2D_ID_POLYGONSTROKEARROWPRIMITIVE2D :
61                 {
62                     // enter a line geometry group (with or without LineEnds)
63                     bool bOldState(mbInLineGeometry);
64                     mbInLineGeometry = true;
65 					process(rCandidate.get2DDecomposition(getViewInformation2D()));
66                     mbInLineGeometry = bOldState;
67                     break;
68                 }
69 				case PRIMITIVE2D_ID_POLYGONHAIRLINEPRIMITIVE2D :
70 				{
71                     if(mbInLineGeometry)
72                     {
73 					    // extract hairline line geometry in world coordinates
74 					    const primitive2d::PolygonHairlinePrimitive2D& rPolygonCandidate(static_cast< const primitive2d::PolygonHairlinePrimitive2D& >(rCandidate));
75 					    basegfx::B2DPolygon aLocalPolygon(rPolygonCandidate.getB2DPolygon());
76 					    aLocalPolygon.transform(getViewInformation2D().getObjectTransformation());
77                         maExtractedHairlines.push_back(aLocalPolygon);
78                     }
79 					break;
80 				}
81 				case PRIMITIVE2D_ID_POLYPOLYGONCOLORPRIMITIVE2D :
82 				{
83                     if(mbInLineGeometry)
84                     {
85 					    // extract filled line geometry (line with width)
86 					    const primitive2d::PolyPolygonColorPrimitive2D& rPolygonCandidate(static_cast< const primitive2d::PolyPolygonColorPrimitive2D& >(rCandidate));
87 					    basegfx::B2DPolyPolygon aLocalPolyPolygon(rPolygonCandidate.getB2DPolyPolygon());
88 					    aLocalPolyPolygon.transform(getViewInformation2D().getObjectTransformation());
89 					    maExtractedLineFills.push_back(aLocalPolyPolygon);
90                     }
91 					break;
92 				}
93 				case PRIMITIVE2D_ID_TRANSFORMPRIMITIVE2D :
94 				{
95 					// remember current transformation and ViewInformation
96 					const primitive2d::TransformPrimitive2D& rTransformCandidate(static_cast< const primitive2d::TransformPrimitive2D& >(rCandidate));
97 					const geometry::ViewInformation2D aLastViewInformation2D(getViewInformation2D());
98 
99 					// create new transformations for CurrentTransformation and for local ViewInformation2D
100 					const geometry::ViewInformation2D aViewInformation2D(
101 						getViewInformation2D().getObjectTransformation() * rTransformCandidate.getTransformation(),
102 						getViewInformation2D().getViewTransformation(),
103 						getViewInformation2D().getViewport(),
104 						getViewInformation2D().getVisualizedPage(),
105 						getViewInformation2D().getViewTime(),
106 						getViewInformation2D().getExtendedInformationSequence());
107 					updateViewInformation(aViewInformation2D);
108 
109 					// proccess content
110 					process(rTransformCandidate.getChildren());
111 
112 					// restore transformations
113 					updateViewInformation(aLastViewInformation2D);
114 
115 					break;
116 				}
117 				case PRIMITIVE2D_ID_SCENEPRIMITIVE2D :
118                 case PRIMITIVE2D_ID_WRONGSPELLPRIMITIVE2D :
119 				case PRIMITIVE2D_ID_MARKERARRAYPRIMITIVE2D :
120 				case PRIMITIVE2D_ID_POINTARRAYPRIMITIVE2D :
121 				case PRIMITIVE2D_ID_BITMAPPRIMITIVE2D :
122 				case PRIMITIVE2D_ID_METAFILEPRIMITIVE2D :
123 				case PRIMITIVE2D_ID_MASKPRIMITIVE2D :
124                 {
125 					// ignorable primitives
126 					break;
127 				}
128 				default :
129 				{
130 					// process recursively
131 					process(rCandidate.get2DDecomposition(getViewInformation2D()));
132 					break;
133 				}
134 			}
135 		}
136 	} // end of namespace processor2d
137 } // end of namespace drawinglayer
138 
139 //////////////////////////////////////////////////////////////////////////////
140 // eof
141