Statistics
| Revision:

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
}