root / trunk / org.gvsig.dwg / org.gvsig.dwg.lib / src / main / java / org / gvsig / dwg / lib / readers / v2004 / DwgEllipseReader2004.java @ 5
History | View | Annotate | Download (2.88 KB)
1 | 5 | jldominguez | /*
|
---|---|---|---|
2 | * Created on 25-ene-2007 by azabala
|
||
3 | *
|
||
4 | */
|
||
5 | package org.gvsig.dwg.lib.readers.v2004; |
||
6 | |||
7 | import java.util.ArrayList; |
||
8 | |||
9 | import org.gvsig.dwg.lib.CorruptedDwgEntityException; |
||
10 | import org.gvsig.dwg.lib.DwgHandleReference; |
||
11 | import org.gvsig.dwg.lib.DwgObject; |
||
12 | import org.gvsig.dwg.lib.DwgUtil; |
||
13 | import org.gvsig.dwg.lib.objects.DwgEllipse; |
||
14 | |||
15 | |||
16 | /**
|
||
17 | * @author alzabord
|
||
18 | *
|
||
19 | * TODO To change the template for this generated type comment go to
|
||
20 | * Window - Preferences - Java - Code Style - Code Templates
|
||
21 | */
|
||
22 | public class DwgEllipseReader2004 extends AbstractDwg2004Reader{ |
||
23 | |||
24 | /* (non-Javadoc)
|
||
25 | * @see com.iver.cit.jdwglib.dwg.readers.IDwgObjectReader#readSpecificObj(int[], int, com.iver.cit.jdwglib.dwg.DwgObject)
|
||
26 | */
|
||
27 | public void readSpecificObj(int[] data, int offset, DwgObject dwgObj) throws RuntimeException, CorruptedDwgEntityException { |
||
28 | if(! (dwgObj instanceof DwgEllipse)) |
||
29 | throw new RuntimeException("ArcReader 2004 solo puede leer DwgEllipse"); |
||
30 | DwgEllipse ell = (DwgEllipse) dwgObj; |
||
31 | int bitPos = offset;
|
||
32 | ell.inserta(); |
||
33 | ArrayList v;
|
||
34 | |||
35 | |||
36 | bitPos = readObjectHeader(data, bitPos, ell); |
||
37 | |||
38 | v = DwgUtil.getBitDouble(data, bitPos); |
||
39 | bitPos = ((Integer)v.get(0)).intValue(); |
||
40 | double x = ((Double)v.get(1)).doubleValue(); |
||
41 | v = DwgUtil.getBitDouble(data, bitPos); |
||
42 | bitPos = ((Integer)v.get(0)).intValue(); |
||
43 | double y = ((Double)v.get(1)).doubleValue(); |
||
44 | v = DwgUtil.getBitDouble(data, bitPos); |
||
45 | bitPos = ((Integer)v.get(0)).intValue(); |
||
46 | double z = ((Double)v.get(1)).doubleValue(); |
||
47 | double[] coord = new double[]{x, y, z}; |
||
48 | ell.setCenter(coord); |
||
49 | v = DwgUtil.getBitDouble(data, bitPos); |
||
50 | bitPos = ((Integer)v.get(0)).intValue(); |
||
51 | x = ((Double)v.get(1)).doubleValue(); |
||
52 | v = DwgUtil.getBitDouble(data, bitPos); |
||
53 | bitPos = ((Integer)v.get(0)).intValue(); |
||
54 | y = ((Double)v.get(1)).doubleValue(); |
||
55 | v = DwgUtil.getBitDouble(data, bitPos); |
||
56 | bitPos = ((Integer)v.get(0)).intValue(); |
||
57 | z = ((Double)v.get(1)).doubleValue(); |
||
58 | coord = new double[]{x, y, z}; |
||
59 | ell.setSemiMajorAxisVector(coord); |
||
60 | v = DwgUtil.getBitDouble(data, bitPos); |
||
61 | bitPos = ((Integer)v.get(0)).intValue(); |
||
62 | x = ((Double)v.get(1)).doubleValue(); |
||
63 | v = DwgUtil.getBitDouble(data, bitPos); |
||
64 | bitPos = ((Integer)v.get(0)).intValue(); |
||
65 | y = ((Double)v.get(1)).doubleValue(); |
||
66 | v = DwgUtil.getBitDouble(data, bitPos); |
||
67 | bitPos = ((Integer)v.get(0)).intValue(); |
||
68 | z = ((Double)v.get(1)).doubleValue(); |
||
69 | coord = new double[]{x, y, z}; |
||
70 | ell.setExtrusion(coord); |
||
71 | v = DwgUtil.getBitDouble(data, bitPos); |
||
72 | bitPos = ((Integer)v.get(0)).intValue(); |
||
73 | double val = ((Double)v.get(1)).doubleValue(); |
||
74 | ell.setAxisRatio(val); |
||
75 | v = DwgUtil.getBitDouble(data, bitPos); |
||
76 | bitPos = ((Integer)v.get(0)).intValue(); |
||
77 | val = ((Double)v.get(1)).doubleValue(); |
||
78 | ell.setInitAngle(val); |
||
79 | v = DwgUtil.getBitDouble(data, bitPos); |
||
80 | bitPos = ((Integer)v.get(0)).intValue(); |
||
81 | val = ((Double)v.get(1)).doubleValue(); |
||
82 | ell.setEndAngle(val); |
||
83 | bitPos = readObjectTailer(data, bitPos, ell); |
||
84 | } |
||
85 | } |