Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
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/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
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 .
18 : */
19 :
20 :
21 : #include <string.h>
22 : #include <dxfentrd.hxx>
23 :
24 : //--------------------------DXFBasicEntity--------------------------------------
25 :
26 0 : DXFBasicEntity::DXFBasicEntity(DXFEntityType eThisType)
27 : : m_sLayer("0")
28 0 : , m_sLineType("BYLAYER")
29 : {
30 0 : eType=eThisType;
31 0 : pSucc=NULL;
32 0 : fElevation=0;
33 0 : fThickness=0;
34 0 : nColor=256;
35 0 : nSpace=0;
36 0 : aExtrusion.fx=0.0;
37 0 : aExtrusion.fy=0.0;
38 0 : aExtrusion.fz=1.0;
39 0 : }
40 :
41 0 : void DXFBasicEntity::Read(DXFGroupReader & rDGR)
42 : {
43 0 : while (rDGR.Read()!=0) EvaluateGroup(rDGR);
44 0 : }
45 :
46 0 : void DXFBasicEntity::EvaluateGroup(DXFGroupReader & rDGR)
47 : {
48 0 : switch (rDGR.GetG())
49 : {
50 0 : case 8: m_sLayer = OString(rDGR.GetS()); break;
51 0 : case 6: m_sLineType = OString(rDGR.GetS()); break;
52 0 : case 38: fElevation=rDGR.GetF(); break;
53 0 : case 39: fThickness=rDGR.GetF(); break;
54 0 : case 62: nColor=rDGR.GetI(); break;
55 0 : case 67: nSpace=rDGR.GetI(); break;
56 0 : case 210: aExtrusion.fx=rDGR.GetF(); break;
57 0 : case 220: aExtrusion.fy=rDGR.GetF(); break;
58 0 : case 230: aExtrusion.fz=rDGR.GetF(); break;
59 : }
60 0 : }
61 :
62 0 : DXFBasicEntity::~DXFBasicEntity()
63 : {
64 0 : }
65 :
66 : //--------------------------DXFLineEntity---------------------------------------
67 :
68 0 : DXFLineEntity::DXFLineEntity() : DXFBasicEntity(DXF_LINE)
69 : {
70 0 : }
71 :
72 0 : void DXFLineEntity::EvaluateGroup(DXFGroupReader & rDGR)
73 : {
74 0 : switch (rDGR.GetG()) {
75 0 : case 10: aP0.fx=rDGR.GetF(); break;
76 0 : case 20: aP0.fy=rDGR.GetF(); break;
77 0 : case 30: aP0.fz=rDGR.GetF(); break;
78 0 : case 11: aP1.fx=rDGR.GetF(); break;
79 0 : case 21: aP1.fy=rDGR.GetF(); break;
80 0 : case 31: aP1.fz=rDGR.GetF(); break;
81 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
82 : }
83 0 : }
84 :
85 : //--------------------------DXFPointEntity--------------------------------------
86 :
87 0 : DXFPointEntity::DXFPointEntity() : DXFBasicEntity(DXF_POINT)
88 : {
89 0 : }
90 :
91 0 : void DXFPointEntity::EvaluateGroup(DXFGroupReader & rDGR)
92 : {
93 0 : switch (rDGR.GetG()) {
94 0 : case 10: aP0.fx=rDGR.GetF(); break;
95 0 : case 20: aP0.fy=rDGR.GetF(); break;
96 0 : case 30: aP0.fz=rDGR.GetF(); break;
97 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
98 : }
99 0 : }
100 :
101 : //--------------------------DXFCircleEntity-------------------------------------
102 :
103 0 : DXFCircleEntity::DXFCircleEntity() : DXFBasicEntity(DXF_CIRCLE)
104 : {
105 0 : fRadius=1.0;
106 0 : }
107 :
108 0 : void DXFCircleEntity::EvaluateGroup(DXFGroupReader & rDGR)
109 : {
110 0 : switch (rDGR.GetG()) {
111 0 : case 10: aP0.fx=rDGR.GetF(); break;
112 0 : case 20: aP0.fy=rDGR.GetF(); break;
113 0 : case 30: aP0.fz=rDGR.GetF(); break;
114 0 : case 40: fRadius=rDGR.GetF(); break;
115 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
116 : }
117 0 : }
118 :
119 : //--------------------------DXFArcEntity----------------------------------------
120 :
121 0 : DXFArcEntity::DXFArcEntity() : DXFBasicEntity(DXF_ARC)
122 : {
123 0 : fRadius=1.0;
124 0 : fStart=0;
125 0 : fEnd=360.0;
126 0 : }
127 :
128 0 : void DXFArcEntity::EvaluateGroup(DXFGroupReader & rDGR)
129 : {
130 0 : switch (rDGR.GetG()) {
131 0 : case 10: aP0.fx=rDGR.GetF(); break;
132 0 : case 20: aP0.fy=rDGR.GetF(); break;
133 0 : case 30: aP0.fz=rDGR.GetF(); break;
134 0 : case 40: fRadius=rDGR.GetF(); break;
135 0 : case 50: fStart=rDGR.GetF(); break;
136 0 : case 51: fEnd=rDGR.GetF(); break;
137 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
138 : }
139 0 : }
140 :
141 : //--------------------------DXFTraceEntity--------------------------------------
142 :
143 0 : DXFTraceEntity::DXFTraceEntity() : DXFBasicEntity(DXF_TRACE)
144 : {
145 0 : }
146 :
147 0 : void DXFTraceEntity::EvaluateGroup(DXFGroupReader & rDGR)
148 : {
149 0 : switch (rDGR.GetG()) {
150 0 : case 10: aP0.fx=rDGR.GetF(); break;
151 0 : case 20: aP0.fy=rDGR.GetF(); break;
152 0 : case 30: aP0.fz=rDGR.GetF(); break;
153 0 : case 11: aP1.fx=rDGR.GetF(); break;
154 0 : case 21: aP1.fy=rDGR.GetF(); break;
155 0 : case 31: aP1.fz=rDGR.GetF(); break;
156 0 : case 12: aP2.fx=rDGR.GetF(); break;
157 0 : case 22: aP2.fy=rDGR.GetF(); break;
158 0 : case 32: aP2.fz=rDGR.GetF(); break;
159 0 : case 13: aP3.fx=rDGR.GetF(); break;
160 0 : case 23: aP3.fy=rDGR.GetF(); break;
161 0 : case 33: aP3.fz=rDGR.GetF(); break;
162 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
163 : }
164 0 : }
165 :
166 : //--------------------------DXFSolidEntity--------------------------------------
167 :
168 0 : DXFSolidEntity::DXFSolidEntity() : DXFBasicEntity(DXF_SOLID)
169 : {
170 0 : }
171 :
172 0 : void DXFSolidEntity::EvaluateGroup(DXFGroupReader & rDGR)
173 : {
174 0 : switch (rDGR.GetG()) {
175 0 : case 10: aP0.fx=rDGR.GetF(); break;
176 0 : case 20: aP0.fy=rDGR.GetF(); break;
177 0 : case 30: aP0.fz=rDGR.GetF(); break;
178 0 : case 11: aP1.fx=rDGR.GetF(); break;
179 0 : case 21: aP1.fy=rDGR.GetF(); break;
180 0 : case 31: aP1.fz=rDGR.GetF(); break;
181 0 : case 12: aP2.fx=rDGR.GetF(); break;
182 0 : case 22: aP2.fy=rDGR.GetF(); break;
183 0 : case 32: aP2.fz=rDGR.GetF(); break;
184 0 : case 13: aP3.fx=rDGR.GetF(); break;
185 0 : case 23: aP3.fy=rDGR.GetF(); break;
186 0 : case 33: aP3.fz=rDGR.GetF(); break;
187 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
188 : }
189 0 : }
190 :
191 : //--------------------------DXFTextEntity---------------------------------------
192 :
193 0 : DXFTextEntity::DXFTextEntity()
194 : : DXFBasicEntity(DXF_TEXT)
195 0 : , m_sStyle("STANDARD")
196 : {
197 0 : fHeight=1.0;
198 0 : fRotAngle=0.0;
199 0 : fXScale=1.0;
200 0 : fOblAngle=0.0;
201 0 : nGenFlags=0;
202 0 : nHorzJust=0;
203 0 : nVertJust=0;
204 0 : }
205 :
206 0 : void DXFTextEntity::EvaluateGroup(DXFGroupReader & rDGR)
207 : {
208 0 : switch (rDGR.GetG()) {
209 0 : case 10: aP0.fx=rDGR.GetF(); break;
210 0 : case 20: aP0.fy=rDGR.GetF(); break;
211 0 : case 30: aP0.fz=rDGR.GetF(); break;
212 0 : case 40: fHeight=rDGR.GetF(); break;
213 0 : case 1: m_sText = OString(rDGR.GetS()); break;
214 0 : case 50: fRotAngle=rDGR.GetF(); break;
215 0 : case 41: fXScale=rDGR.GetF(); break;
216 0 : case 42: fOblAngle=rDGR.GetF(); break;
217 0 : case 7: m_sStyle = OString(rDGR.GetS()); break;
218 0 : case 71: nGenFlags=rDGR.GetI(); break;
219 0 : case 72: nHorzJust=rDGR.GetI(); break;
220 0 : case 73: nVertJust=rDGR.GetI(); break;
221 0 : case 11: aAlign.fx=rDGR.GetF(); break;
222 0 : case 21: aAlign.fy=rDGR.GetF(); break;
223 0 : case 31: aAlign.fz=rDGR.GetF(); break;
224 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
225 : }
226 0 : }
227 :
228 : //--------------------------DXFShapeEntity--------------------------------------
229 :
230 0 : DXFShapeEntity::DXFShapeEntity() : DXFBasicEntity(DXF_SHAPE)
231 : {
232 0 : fSize=1.0;
233 0 : fRotAngle=0;
234 0 : fXScale=1.0;
235 0 : fOblAngle=0;
236 0 : }
237 :
238 0 : void DXFShapeEntity::EvaluateGroup(DXFGroupReader & rDGR)
239 : {
240 0 : switch (rDGR.GetG()) {
241 0 : case 10: aP0.fx=rDGR.GetF(); break;
242 0 : case 20: aP0.fy=rDGR.GetF(); break;
243 0 : case 30: aP0.fz=rDGR.GetF(); break;
244 0 : case 40: fSize=rDGR.GetF(); break;
245 0 : case 2: m_sName = OString(rDGR.GetS()); break;
246 0 : case 50: fRotAngle=rDGR.GetF(); break;
247 0 : case 41: fXScale=rDGR.GetF(); break;
248 0 : case 51: fOblAngle=rDGR.GetF(); break;
249 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
250 : }
251 0 : }
252 :
253 : //--------------------------DXFInsertEntity-------------------------------------
254 :
255 0 : DXFInsertEntity::DXFInsertEntity() : DXFBasicEntity(DXF_INSERT)
256 : {
257 0 : nAttrFlag=0;
258 0 : fXScale=1.0;
259 0 : fYScale=1.0;
260 0 : fZScale=1.0;
261 0 : fRotAngle=0.0;
262 0 : nColCount=1;
263 0 : nRowCount=1;
264 0 : fColSpace=0.0;
265 0 : fRowSpace=0.0;
266 0 : }
267 :
268 0 : void DXFInsertEntity::EvaluateGroup(DXFGroupReader & rDGR)
269 : {
270 0 : switch (rDGR.GetG()) {
271 0 : case 66: nAttrFlag=rDGR.GetI(); break;
272 0 : case 2: m_sName = OString(rDGR.GetS()); break;
273 0 : case 10: aP0.fx=rDGR.GetF(); break;
274 0 : case 20: aP0.fy=rDGR.GetF(); break;
275 0 : case 30: aP0.fz=rDGR.GetF(); break;
276 0 : case 41: fXScale=rDGR.GetF(); break;
277 0 : case 42: fYScale=rDGR.GetF(); break;
278 0 : case 43: fZScale=rDGR.GetF(); break;
279 0 : case 50: fRotAngle=rDGR.GetF(); break;
280 0 : case 70: nColCount=rDGR.GetI(); break;
281 0 : case 71: nRowCount=rDGR.GetI(); break;
282 0 : case 44: fColSpace=rDGR.GetF(); break;
283 0 : case 45: fRowSpace=rDGR.GetF(); break;
284 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
285 : }
286 0 : }
287 :
288 : //--------------------------DXFAttDefEntity-------------------------------------
289 :
290 0 : DXFAttDefEntity::DXFAttDefEntity()
291 : : DXFBasicEntity(DXF_ATTDEF)
292 0 : , m_sStyle("STANDARD")
293 : {
294 0 : fHeight=1.0;
295 0 : nAttrFlags=0;
296 0 : nFieldLen=0;
297 0 : fRotAngle=0.0;
298 0 : fXScale=1.0;
299 0 : fOblAngle=0.0;
300 0 : nGenFlags=0;
301 0 : nHorzJust=0;
302 0 : nVertJust=0;
303 0 : }
304 :
305 0 : void DXFAttDefEntity::EvaluateGroup(DXFGroupReader & rDGR)
306 : {
307 0 : switch (rDGR.GetG()) {
308 0 : case 10: aP0.fx=rDGR.GetF(); break;
309 0 : case 20: aP0.fy=rDGR.GetF(); break;
310 0 : case 30: aP0.fz=rDGR.GetF(); break;
311 0 : case 40: fHeight=rDGR.GetF(); break;
312 0 : case 1: m_sDefVal = OString(rDGR.GetS()); break;
313 0 : case 3: m_sPrompt = OString(rDGR.GetS()); break;
314 0 : case 2: m_sTagStr = OString(rDGR.GetS()); break;
315 0 : case 70: nAttrFlags=rDGR.GetI(); break;
316 0 : case 73: nFieldLen=rDGR.GetI(); break;
317 0 : case 50: fRotAngle=rDGR.GetF(); break;
318 0 : case 41: fXScale=rDGR.GetF(); break;
319 0 : case 51: fOblAngle=rDGR.GetF(); break;
320 0 : case 7: m_sStyle = OString(rDGR.GetS()); break;
321 0 : case 71: nGenFlags=rDGR.GetI(); break;
322 0 : case 72: nHorzJust=rDGR.GetI(); break;
323 0 : case 74: nVertJust=rDGR.GetI(); break;
324 0 : case 11: aAlign.fx=rDGR.GetF(); break;
325 0 : case 21: aAlign.fy=rDGR.GetF(); break;
326 0 : case 31: aAlign.fz=rDGR.GetF(); break;
327 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
328 : }
329 0 : }
330 :
331 : //--------------------------DXFAttribEntity-------------------------------------
332 :
333 0 : DXFAttribEntity::DXFAttribEntity()
334 : : DXFBasicEntity(DXF_ATTRIB)
335 0 : , m_sStyle("STANDARD")
336 : {
337 0 : fHeight=1.0;
338 0 : nAttrFlags=0;
339 0 : nFieldLen=0;
340 0 : fRotAngle=0.0;
341 0 : fXScale=1.0;
342 0 : fOblAngle=0.0;
343 0 : nGenFlags=0;
344 0 : nHorzJust=0;
345 0 : nVertJust=0;
346 0 : }
347 :
348 0 : void DXFAttribEntity::EvaluateGroup(DXFGroupReader & rDGR)
349 : {
350 0 : switch (rDGR.GetG()) {
351 0 : case 10: aP0.fx=rDGR.GetF(); break;
352 0 : case 20: aP0.fy=rDGR.GetF(); break;
353 0 : case 30: aP0.fz=rDGR.GetF(); break;
354 0 : case 40: fHeight=rDGR.GetF(); break;
355 0 : case 1: m_sText = OString(rDGR.GetS()); break;
356 0 : case 2: m_sTagStr = OString(rDGR.GetS()); break;
357 0 : case 70: nAttrFlags=rDGR.GetI(); break;
358 0 : case 73: nFieldLen=rDGR.GetI(); break;
359 0 : case 50: fRotAngle=rDGR.GetF(); break;
360 0 : case 41: fXScale=rDGR.GetF(); break;
361 0 : case 51: fOblAngle=rDGR.GetF(); break;
362 0 : case 7: m_sStyle = OString(rDGR.GetS()); break;
363 0 : case 71: nGenFlags=rDGR.GetI(); break;
364 0 : case 72: nHorzJust=rDGR.GetI(); break;
365 0 : case 74: nVertJust=rDGR.GetI(); break;
366 0 : case 11: aAlign.fx=rDGR.GetF(); break;
367 0 : case 21: aAlign.fy=rDGR.GetF(); break;
368 0 : case 31: aAlign.fz=rDGR.GetF(); break;
369 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
370 : }
371 0 : }
372 :
373 : //--------------------------DXFPolyLine-----------------------------------------
374 :
375 0 : DXFPolyLineEntity::DXFPolyLineEntity() : DXFBasicEntity(DXF_POLYLINE)
376 : {
377 0 : fElevation=0.0;
378 0 : nFlags=0;
379 0 : fSWidth=0.0;
380 0 : fEWidth=0.0;
381 0 : nMeshMCount=0;
382 0 : nMeshNCount=0;
383 0 : nMDensity=0;
384 0 : nNDensity=0;
385 0 : nCSSType=0;
386 0 : }
387 :
388 0 : void DXFPolyLineEntity::EvaluateGroup(DXFGroupReader & rDGR)
389 : {
390 0 : switch (rDGR.GetG()) {
391 0 : case 30: fElevation=rDGR.GetF(); break;
392 0 : case 70: nFlags=rDGR.GetI(); break;
393 0 : case 40: fSWidth=rDGR.GetF(); break;
394 0 : case 41: fEWidth=rDGR.GetF(); break;
395 0 : case 71: nMeshMCount=rDGR.GetI(); break;
396 0 : case 72: nMeshNCount=rDGR.GetI(); break;
397 0 : case 73: nMDensity=rDGR.GetI(); break;
398 0 : case 74: nNDensity=rDGR.GetI(); break;
399 0 : case 75: nCSSType=rDGR.GetI(); break;
400 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
401 : }
402 0 : }
403 :
404 : //--------------------------DXFLWPolyLine---------------------------------------
405 :
406 0 : DXFLWPolyLineEntity::DXFLWPolyLineEntity() :
407 : DXFBasicEntity( DXF_LWPOLYLINE ),
408 : nIndex( 0 ),
409 : nCount( 0 ),
410 : nFlags( 0 ),
411 : fConstantWidth( 0.0 ),
412 : fStartWidth( 0.0 ),
413 : fEndWidth( 0.0 ),
414 0 : pP( NULL )
415 : {
416 0 : }
417 :
418 0 : void DXFLWPolyLineEntity::EvaluateGroup( DXFGroupReader & rDGR )
419 : {
420 0 : switch ( rDGR.GetG() )
421 : {
422 : case 90 :
423 : {
424 0 : nCount = rDGR.GetI();
425 0 : if ( nCount )
426 0 : pP = new DXFVector[ nCount ];
427 : }
428 0 : break;
429 0 : case 70: nFlags = rDGR.GetI(); break;
430 0 : case 43: fConstantWidth = rDGR.GetF(); break;
431 0 : case 40: fStartWidth = rDGR.GetF(); break;
432 0 : case 41: fEndWidth = rDGR.GetF(); break;
433 : case 10:
434 : {
435 0 : if ( pP && ( nIndex < nCount ) )
436 0 : pP[ nIndex ].fx = rDGR.GetF();
437 : }
438 0 : break;
439 : case 20:
440 : {
441 0 : if ( pP && ( nIndex < nCount ) )
442 0 : pP[ nIndex++ ].fy = rDGR.GetF();
443 : }
444 0 : break;
445 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
446 : }
447 0 : }
448 :
449 0 : DXFLWPolyLineEntity::~DXFLWPolyLineEntity()
450 : {
451 0 : delete[] pP;
452 0 : }
453 :
454 : //--------------------------DXFHatchEntity-------------------------------------
455 :
456 0 : DXFEdgeTypeLine::DXFEdgeTypeLine() :
457 0 : DXFEdgeType( 1 )
458 : {
459 :
460 0 : }
461 0 : DXFEdgeTypeLine::~DXFEdgeTypeLine()
462 : {
463 :
464 0 : }
465 0 : sal_Bool DXFEdgeTypeLine::EvaluateGroup( DXFGroupReader & rDGR )
466 : {
467 0 : sal_Bool bExecutingGroupCode = sal_True;
468 0 : switch ( rDGR.GetG() )
469 : {
470 0 : case 10 : aStartPoint.fx = rDGR.GetF(); break;
471 0 : case 20 : aStartPoint.fy = rDGR.GetF(); break;
472 0 : case 11 : aEndPoint.fx = rDGR.GetF(); break;
473 0 : case 21 : aEndPoint.fy = rDGR.GetF(); break;
474 0 : default : bExecutingGroupCode = sal_False; break;
475 : }
476 0 : return bExecutingGroupCode;
477 : }
478 :
479 0 : DXFEdgeTypeCircularArc::DXFEdgeTypeCircularArc() :
480 : DXFEdgeType( 2 ),
481 : fRadius( 0.0 ),
482 : fStartAngle( 0.0 ),
483 : fEndAngle( 0.0 ),
484 0 : nIsCounterClockwiseFlag( 0 )
485 : {
486 0 : }
487 0 : DXFEdgeTypeCircularArc::~DXFEdgeTypeCircularArc()
488 : {
489 0 : }
490 0 : sal_Bool DXFEdgeTypeCircularArc::EvaluateGroup( DXFGroupReader & rDGR )
491 : {
492 0 : sal_Bool bExecutingGroupCode = sal_True;
493 0 : switch ( rDGR.GetG() )
494 : {
495 0 : case 10 : aCenter.fx = rDGR.GetF(); break;
496 0 : case 20 : aCenter.fy = rDGR.GetF(); break;
497 0 : case 40 : fRadius = rDGR.GetF(); break;
498 0 : case 50 : fStartAngle = rDGR.GetF(); break;
499 0 : case 51 : fEndAngle = rDGR.GetF(); break;
500 0 : case 73 : nIsCounterClockwiseFlag = rDGR.GetI(); break;
501 0 : default : bExecutingGroupCode = sal_False; break;
502 : }
503 0 : return bExecutingGroupCode;
504 : }
505 :
506 0 : DXFEdgeTypeEllipticalArc::DXFEdgeTypeEllipticalArc() :
507 : DXFEdgeType( 3 ),
508 : fLength( 0.0 ),
509 : fStartAngle( 0.0 ),
510 : fEndAngle( 0.0 ),
511 0 : nIsCounterClockwiseFlag( 0 )
512 : {
513 0 : }
514 0 : DXFEdgeTypeEllipticalArc::~DXFEdgeTypeEllipticalArc()
515 : {
516 :
517 0 : }
518 0 : sal_Bool DXFEdgeTypeEllipticalArc::EvaluateGroup( DXFGroupReader & rDGR )
519 : {
520 0 : sal_Bool bExecutingGroupCode = sal_True;
521 0 : switch( rDGR.GetG() )
522 : {
523 0 : case 10 : aCenter.fx = rDGR.GetF(); break;
524 0 : case 20 : aCenter.fy = rDGR.GetF(); break;
525 0 : case 11 : aEndPoint.fx = rDGR.GetF(); break;
526 0 : case 21 : aEndPoint.fy = rDGR.GetF(); break;
527 0 : case 40 : fLength = rDGR.GetF(); break;
528 0 : case 50 : fStartAngle = rDGR.GetF(); break;
529 0 : case 51 : fEndAngle = rDGR.GetF(); break;
530 0 : case 73 : nIsCounterClockwiseFlag = rDGR.GetI(); break;
531 0 : default : bExecutingGroupCode = sal_False; break;
532 : }
533 0 : return bExecutingGroupCode;
534 : }
535 :
536 0 : DXFEdgeTypeSpline::DXFEdgeTypeSpline() :
537 : DXFEdgeType( 4 ),
538 : nDegree( 0 ),
539 : nRational( 0 ),
540 : nPeriodic( 0 ),
541 : nKnotCount( 0 ),
542 0 : nControlCount( 0 )
543 : {
544 0 : }
545 0 : DXFEdgeTypeSpline::~DXFEdgeTypeSpline()
546 : {
547 :
548 0 : }
549 0 : sal_Bool DXFEdgeTypeSpline::EvaluateGroup( DXFGroupReader & rDGR )
550 : {
551 0 : sal_Bool bExecutingGroupCode = sal_True;
552 0 : switch ( rDGR.GetG() )
553 : {
554 0 : case 94 : nDegree = rDGR.GetI(); break;
555 0 : case 73 : nRational = rDGR.GetI(); break;
556 0 : case 74 : nPeriodic = rDGR.GetI(); break;
557 0 : case 95 : nKnotCount = rDGR.GetI(); break;
558 0 : case 96 : nControlCount = rDGR.GetI(); break;
559 0 : default : bExecutingGroupCode = sal_False; break;
560 : }
561 0 : return bExecutingGroupCode;
562 : }
563 :
564 0 : DXFBoundaryPathData::DXFBoundaryPathData() :
565 : nFlags( 0 ),
566 : nHasBulgeFlag( 0 ),
567 : nIsClosedFlag( 0 ),
568 : nPointCount( 0 ),
569 : fBulge( 0.0 ),
570 : nSourceBoundaryObjects( 0 ),
571 : nEdgeCount( 0 ),
572 : bIsPolyLine( sal_True ),
573 : nPointIndex( 0 ),
574 0 : pP( NULL )
575 : {
576 0 : }
577 :
578 0 : DXFBoundaryPathData::~DXFBoundaryPathData()
579 : {
580 0 : sal_uInt32 i = 0;
581 0 : for ( i = 0; i < aEdges.size(); i++ )
582 0 : delete aEdges[ i ];
583 0 : delete[] pP;
584 0 : }
585 :
586 0 : sal_Bool DXFBoundaryPathData::EvaluateGroup( DXFGroupReader & rDGR )
587 : {
588 0 : sal_Bool bExecutingGroupCode = sal_True;
589 0 : if ( bIsPolyLine )
590 : {
591 0 : switch( rDGR.GetG() )
592 : {
593 : case 92 :
594 : {
595 0 : nFlags = rDGR.GetI();
596 0 : if ( ( nFlags & 2 ) == 0 )
597 0 : bIsPolyLine = sal_False;
598 : }
599 0 : break;
600 : case 93 :
601 : {
602 0 : nPointCount = rDGR.GetI();
603 0 : if ( nPointCount )
604 0 : pP = new DXFVector[ nPointCount ];
605 : }
606 0 : break;
607 0 : case 72 : nHasBulgeFlag = rDGR.GetI(); break;
608 0 : case 73 : nIsClosedFlag = rDGR.GetI(); break;
609 0 : case 97 : nSourceBoundaryObjects = rDGR.GetI(); break;
610 0 : case 42 : fBulge = rDGR.GetF(); break;
611 : case 10:
612 : {
613 0 : if ( pP && ( nPointIndex < nPointCount ) )
614 0 : pP[ nPointIndex ].fx = rDGR.GetF();
615 : }
616 0 : break;
617 : case 20:
618 : {
619 0 : if ( pP && ( nPointIndex < nPointCount ) )
620 0 : pP[ nPointIndex++ ].fy = rDGR.GetF();
621 : }
622 0 : break;
623 :
624 0 : default : bExecutingGroupCode = sal_False; break;
625 : }
626 : }
627 : else
628 : {
629 0 : if ( rDGR.GetG() == 93 )
630 0 : nEdgeCount = rDGR.GetI();
631 0 : else if ( rDGR.GetG() == 72 )
632 : {
633 0 : sal_Int32 nEdgeType = rDGR.GetI();
634 0 : switch( nEdgeType )
635 : {
636 0 : case 1 : aEdges.push_back( new DXFEdgeTypeLine() ); break;
637 0 : case 2 : aEdges.push_back( new DXFEdgeTypeCircularArc() ); break;
638 0 : case 3 : aEdges.push_back( new DXFEdgeTypeEllipticalArc() ); break;
639 0 : case 4 : aEdges.push_back( new DXFEdgeTypeSpline() ); break;
640 : }
641 : }
642 0 : else if ( aEdges.size() )
643 0 : aEdges[ aEdges.size() - 1 ]->EvaluateGroup( rDGR );
644 : else
645 0 : bExecutingGroupCode = sal_False;
646 : }
647 0 : return bExecutingGroupCode;
648 : }
649 :
650 0 : DXFHatchEntity::DXFHatchEntity() :
651 : DXFBasicEntity( DXF_HATCH ),
652 : bIsInBoundaryPathContext( sal_False ),
653 : nCurrentBoundaryPathIndex( -1 ),
654 : nFlags( 0 ),
655 : nAssociativityFlag( 0 ),
656 : nBoundaryPathCount( 0 ),
657 : nHatchStyle( 0 ),
658 : nHatchPatternType( 0 ),
659 : fHatchPatternAngle( 0.0 ),
660 : fHatchPatternScale( 1.0 ),
661 : nHatchDoubleFlag( 0 ),
662 : nHatchPatternDefinitionLines( 0 ),
663 : fPixelSize( 1.0 ),
664 : nNumberOfSeedPoints( 0 ),
665 0 : pBoundaryPathData( NULL )
666 : {
667 0 : }
668 :
669 0 : void DXFHatchEntity::EvaluateGroup( DXFGroupReader & rDGR )
670 : {
671 0 : switch ( rDGR.GetG() )
672 : {
673 : // case 10 : aElevationPoint.fx = rDGR.GetF(); break;
674 : // case 20 : aElevationPoint.fy = rDGR.GetF(); break;
675 : // case 30 : aElevationPoint.fz = rDGR.GetF(); break;
676 0 : case 70 : nFlags = rDGR.GetI(); break;
677 0 : case 71 : nAssociativityFlag = rDGR.GetI(); break;
678 : case 91 :
679 : {
680 0 : bIsInBoundaryPathContext = sal_True;
681 0 : nBoundaryPathCount = rDGR.GetI();
682 0 : if ( nBoundaryPathCount )
683 0 : pBoundaryPathData = new DXFBoundaryPathData[ nBoundaryPathCount ];
684 : }
685 0 : break;
686 : case 75 :
687 : {
688 0 : nHatchStyle = rDGR.GetI();
689 0 : bIsInBoundaryPathContext = sal_False;
690 : }
691 0 : break;
692 0 : case 76 : nHatchPatternType = rDGR.GetI(); break;
693 0 : case 52 : fHatchPatternAngle = rDGR.GetF(); break;
694 0 : case 41 : fHatchPatternScale = rDGR.GetF(); break;
695 0 : case 77 : nHatchDoubleFlag = rDGR.GetI(); break;
696 0 : case 78 : nHatchPatternDefinitionLines = rDGR.GetI(); break;
697 0 : case 47 : fPixelSize = rDGR.GetF(); break;
698 0 : case 98 : nNumberOfSeedPoints = rDGR.GetI(); break;
699 :
700 : case 92:
701 0 : nCurrentBoundaryPathIndex++;
702 : //fallthrough
703 : default:
704 : {
705 0 : sal_Bool bExecutingGroupCode = sal_False;
706 0 : if ( bIsInBoundaryPathContext )
707 : {
708 0 : if ( ( nCurrentBoundaryPathIndex >= 0 ) &&
709 0 : ( nCurrentBoundaryPathIndex < nBoundaryPathCount ) )
710 0 : bExecutingGroupCode = pBoundaryPathData[ nCurrentBoundaryPathIndex ].EvaluateGroup( rDGR );
711 : }
712 0 : if ( bExecutingGroupCode == sal_False )
713 0 : DXFBasicEntity::EvaluateGroup(rDGR);
714 : }
715 0 : break;
716 : }
717 0 : }
718 :
719 0 : DXFHatchEntity::~DXFHatchEntity()
720 : {
721 0 : delete[] pBoundaryPathData;
722 0 : }
723 :
724 : //--------------------------DXFVertexEntity-------------------------------------
725 :
726 0 : DXFVertexEntity::DXFVertexEntity() : DXFBasicEntity(DXF_VERTEX)
727 : {
728 0 : fSWidth=-1.0;
729 0 : fEWidth=-1.0;
730 0 : fBulge=0.0;
731 0 : nFlags=0;
732 0 : fCFTDir=0.0;
733 :
734 0 : }
735 :
736 0 : void DXFVertexEntity::EvaluateGroup(DXFGroupReader & rDGR)
737 : {
738 0 : switch (rDGR.GetG()) {
739 0 : case 10: aP0.fx=rDGR.GetF(); break;
740 0 : case 20: aP0.fy=rDGR.GetF(); break;
741 0 : case 30: aP0.fz=rDGR.GetF(); break;
742 0 : case 40: fSWidth=rDGR.GetF(); break;
743 0 : case 41: fEWidth=rDGR.GetF(); break;
744 0 : case 42: fBulge=rDGR.GetF(); break;
745 0 : case 70: nFlags=rDGR.GetI(); break;
746 0 : case 50: fCFTDir=rDGR.GetF(); break;
747 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
748 : }
749 0 : }
750 :
751 : //--------------------------DXFSeqEndEntity-------------------------------------
752 :
753 0 : DXFSeqEndEntity::DXFSeqEndEntity() : DXFBasicEntity(DXF_SEQEND)
754 : {
755 0 : }
756 :
757 : //--------------------------DXF3DFace-------------------------------------------
758 :
759 0 : DXF3DFaceEntity::DXF3DFaceEntity() : DXFBasicEntity(DXF_3DFACE)
760 : {
761 0 : nIEFlags=0;
762 0 : }
763 :
764 0 : void DXF3DFaceEntity::EvaluateGroup(DXFGroupReader & rDGR)
765 : {
766 0 : switch (rDGR.GetG()) {
767 0 : case 10: aP0.fx=rDGR.GetF(); break;
768 0 : case 20: aP0.fy=rDGR.GetF(); break;
769 0 : case 30: aP0.fz=rDGR.GetF(); break;
770 0 : case 11: aP1.fx=rDGR.GetF(); break;
771 0 : case 21: aP1.fy=rDGR.GetF(); break;
772 0 : case 31: aP1.fz=rDGR.GetF(); break;
773 0 : case 12: aP2.fx=rDGR.GetF(); break;
774 0 : case 22: aP2.fy=rDGR.GetF(); break;
775 0 : case 32: aP2.fz=rDGR.GetF(); break;
776 0 : case 13: aP3.fx=rDGR.GetF(); break;
777 0 : case 23: aP3.fy=rDGR.GetF(); break;
778 0 : case 33: aP3.fz=rDGR.GetF(); break;
779 0 : case 70: nIEFlags=rDGR.GetI(); break;
780 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
781 : }
782 0 : }
783 :
784 :
785 : //--------------------------DXFDimensionEntity----------------------------------
786 :
787 0 : DXFDimensionEntity::DXFDimensionEntity() : DXFBasicEntity(DXF_DIMENSION)
788 : {
789 0 : }
790 :
791 0 : void DXFDimensionEntity::EvaluateGroup(DXFGroupReader & rDGR)
792 : {
793 0 : switch (rDGR.GetG()) {
794 0 : case 2: m_sPseudoBlock = OString(rDGR.GetS()); break;
795 0 : default: DXFBasicEntity::EvaluateGroup(rDGR);
796 : }
797 0 : }
798 :
799 : //---------------------------- DXFEntites --------------------------------------
800 :
801 0 : void DXFEntities::Read(DXFGroupReader & rDGR)
802 : {
803 : DXFBasicEntity * pE, * * ppSucc;
804 :
805 0 : ppSucc=&pFirst;
806 0 : while (*ppSucc!=NULL) ppSucc=&((*ppSucc)->pSucc);
807 :
808 0 : while (rDGR.GetG()!=0) rDGR.Read();
809 :
810 0 : while (strcmp(rDGR.GetS(),"ENDBLK")!=0 &&
811 0 : strcmp(rDGR.GetS(),"ENDSEC")!=0 &&
812 0 : strcmp(rDGR.GetS(),"EOF")!=0 )
813 : {
814 :
815 0 : if (strcmp(rDGR.GetS(),"LINE" )==0) pE=new DXFLineEntity;
816 0 : else if (strcmp(rDGR.GetS(),"POINT" )==0) pE=new DXFPointEntity;
817 0 : else if (strcmp(rDGR.GetS(),"CIRCLE" )==0) pE=new DXFCircleEntity;
818 0 : else if (strcmp(rDGR.GetS(),"ARC" )==0) pE=new DXFArcEntity;
819 0 : else if (strcmp(rDGR.GetS(),"TRACE" )==0) pE=new DXFTraceEntity;
820 0 : else if (strcmp(rDGR.GetS(),"SOLID" )==0) pE=new DXFSolidEntity;
821 0 : else if (strcmp(rDGR.GetS(),"TEXT" )==0) pE=new DXFTextEntity;
822 0 : else if (strcmp(rDGR.GetS(),"SHAPE" )==0) pE=new DXFShapeEntity;
823 0 : else if (strcmp(rDGR.GetS(),"INSERT" )==0) pE=new DXFInsertEntity;
824 0 : else if (strcmp(rDGR.GetS(),"ATTDEF" )==0) pE=new DXFAttDefEntity;
825 0 : else if (strcmp(rDGR.GetS(),"ATTRIB" )==0) pE=new DXFAttribEntity;
826 0 : else if (strcmp(rDGR.GetS(),"POLYLINE" )==0) pE=new DXFPolyLineEntity;
827 0 : else if (strcmp(rDGR.GetS(),"LWPOLYLINE")==0) pE=new DXFLWPolyLineEntity;
828 0 : else if (strcmp(rDGR.GetS(),"VERTEX" )==0) pE=new DXFVertexEntity;
829 0 : else if (strcmp(rDGR.GetS(),"SEQEND" )==0) pE=new DXFSeqEndEntity;
830 0 : else if (strcmp(rDGR.GetS(),"3DFACE" )==0) pE=new DXF3DFaceEntity;
831 0 : else if (strcmp(rDGR.GetS(),"DIMENSION" )==0) pE=new DXFDimensionEntity;
832 0 : else if (strcmp(rDGR.GetS(),"HATCH" )==0) pE=new DXFHatchEntity;
833 : else
834 : {
835 0 : do {
836 0 : rDGR.Read();
837 0 : } while (rDGR.GetG()!=0);
838 0 : continue;
839 : }
840 0 : *ppSucc=pE;
841 0 : ppSucc=&(pE->pSucc);
842 0 : pE->Read(rDGR);
843 : }
844 0 : }
845 :
846 0 : void DXFEntities::Clear()
847 : {
848 : DXFBasicEntity * ptmp;
849 :
850 0 : while (pFirst!=NULL) {
851 0 : ptmp=pFirst;
852 0 : pFirst=ptmp->pSucc;
853 0 : delete ptmp;
854 : }
855 0 : }
856 :
857 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|