Statistics
| Revision:

svn-gvsig-desktop / branches / v2_0_0_prep / libraries / libDwg / src / org / gvsig / dwg / lib / readers / v1314 / DwgEllipseReader1314.java @ 28969

History | View | Annotate | Download (3 KB)

1
/*
2
 * Created on 25-ene-2007 by azabala
3
 *
4
 */
5
package org.gvsig.dwg.lib.readers.v1314;
6

    
7
import java.util.List;
8

    
9
import org.gvsig.dwg.lib.CorruptedDwgEntityException;
10
import org.gvsig.dwg.lib.DwgObject;
11
import org.gvsig.dwg.lib.DwgUtil;
12
import org.gvsig.dwg.lib.objects.DwgArc;
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 DwgEllipseReader1314 extends AbstractDwg1314Reader{
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 14 solo puede leer DwgEllipse");
30
                DwgEllipse ell = (DwgEllipse) dwgObj;
31
                int bitPos = offset;
32
                bitPos = headTailReader.readObjectHeader(data, bitPos, ell);
33
                
34
                List val = DwgUtil.getBitDouble(data, bitPos);
35
                bitPos = ((Integer) val.get(0)).intValue();
36
                double x = ((Double) val.get(1)).doubleValue();
37
                
38
                val = DwgUtil.getBitDouble(data, bitPos);
39
                bitPos = ((Integer) val.get(0)).intValue();
40
                double y = ((Double) val.get(1)).doubleValue();
41
                
42
                val = DwgUtil.getBitDouble(data, bitPos);
43
                bitPos = ((Integer) val.get(0)).intValue();
44
                double z = ((Double) val.get(1)).doubleValue();
45
                ell.setCenter(new double[]{x, y, z});
46
                
47
                val = DwgUtil.getBitDouble(data, bitPos);
48
                bitPos = ((Integer) val.get(0)).intValue();
49
                x = ((Double) val.get(1)).doubleValue();
50
                
51
                val = DwgUtil.getBitDouble(data, bitPos);
52
                bitPos = ((Integer) val.get(0)).intValue();
53
                y = ((Double) val.get(1)).doubleValue();
54
                
55
                val = DwgUtil.getBitDouble(data, bitPos);
56
                bitPos = ((Integer) val.get(0)).intValue();
57
                z = ((Double) val.get(1)).doubleValue();
58
                ell.setSemiMajorAxisVector(new double[]{x, y, z});
59
                
60
                val = DwgUtil.getBitDouble(data, bitPos);
61
                bitPos = ((Integer) val.get(0)).intValue();
62
                x = ((Double) val.get(1)).doubleValue();
63
                
64
                val = DwgUtil.getBitDouble(data, bitPos);
65
                bitPos = ((Integer) val.get(0)).intValue();
66
                y = ((Double) val.get(1)).doubleValue();
67
                
68
                val = DwgUtil.getBitDouble(data, bitPos);
69
                bitPos = ((Integer) val.get(0)).intValue();
70
                z = ((Double) val.get(1)).doubleValue();
71
                ell.setExtrusion(new double[]{x, y, z});
72
                
73
                val = DwgUtil.getBitDouble(data, bitPos);
74
                bitPos = ((Integer) val.get(0)).intValue();
75
                double axisRatio = ((Double) val.get(1)).doubleValue();
76
                ell.setAxisRatio(axisRatio);
77
                
78
                val = DwgUtil.getBitDouble(data, bitPos);
79
                bitPos = ((Integer) val.get(0)).intValue();
80
                double startAngle = ((Double) val.get(1)).doubleValue();
81
                ell.setInitAngle(startAngle);
82
                
83
                val = DwgUtil.getBitDouble(data, bitPos);
84
                bitPos = ((Integer) val.get(0)).intValue();
85
                double endAngle = ((Double) val.get(1)).doubleValue();
86
                ell.setEndAngle(endAngle);
87
                
88
                bitPos = headTailReader.readObjectTailer(data, bitPos, ell);
89
        }
90
}