Statistics
| Revision:

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

History | View | Annotate | Download (2.66 KB)

1
/*
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.DwgPoint;
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 DwgPointReader2004 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 DwgPoint))
29
                        throw new RuntimeException("PointReader 2004 solo puede leer DwgPoint");
30
                DwgPoint pt = (DwgPoint) dwgObj;
31
                pt.inserta();
32

    
33
                int bitPos = offset;
34

    
35
                ArrayList v;
36

    
37
                bitPos = readObjectHeader(data, bitPos, pt);
38

    
39
                v = DwgUtil.getBitDouble(data, bitPos);
40
                bitPos = ((Integer)v.get(0)).intValue();
41
                double x = ((Double)v.get(1)).doubleValue();
42
                v = DwgUtil.getBitDouble(data, bitPos);
43
                bitPos = ((Integer)v.get(0)).intValue();
44
                double y = ((Double)v.get(1)).doubleValue();
45
                v = DwgUtil.getBitDouble(data, bitPos);
46
                bitPos = ((Integer)v.get(0)).intValue();
47
                double z = ((Double)v.get(1)).doubleValue();
48
                double[] coord = new double[]{x, y, z};
49
                pt.setPoint(coord);
50

    
51
                v = DwgUtil.testBit(data, bitPos);
52
                bitPos = ((Integer)v.get(0)).intValue();
53
                boolean flag = ((Boolean)v.get(1)).booleanValue();
54
            double val;
55
                if (flag) {
56
                        val=0.0;
57
                } else {
58
                        v = DwgUtil.getBitDouble(data, bitPos);
59
                        bitPos = ((Integer)v.get(0)).intValue();
60
                        val = ((Double)v.get(1)).doubleValue();
61
                }
62
                pt.setThickness(val);
63

    
64
                v = DwgUtil.testBit(data, bitPos);
65
                bitPos = ((Integer)v.get(0)).intValue();
66
                flag = ((Boolean)v.get(1)).booleanValue();
67
                if (flag) {
68
                         x = y = 0.0;
69
                         z = 1.0;
70
                } else {
71
                        v = DwgUtil.getBitDouble(data, bitPos);
72
                        bitPos = ((Integer)v.get(0)).intValue();
73
                        x = ((Double)v.get(1)).doubleValue();
74
                        v = DwgUtil.getBitDouble(data, bitPos);
75
                        bitPos = ((Integer)v.get(0)).intValue();
76
                        y = ((Double)v.get(1)).doubleValue();
77
                        v = DwgUtil.getBitDouble(data, bitPos);
78
                        bitPos = ((Integer)v.get(0)).intValue();
79
                        z = ((Double)v.get(1)).doubleValue();
80
                }
81
                coord = new double[]{x, y, z};
82
                pt.setExtrusion(coord);
83

    
84
                v = DwgUtil.getBitDouble(data, bitPos);
85
                bitPos = ((Integer)v.get(0)).intValue();
86
                val = ((Double)v.get(1)).doubleValue();
87
                pt.setXAxisAngle(val);
88

    
89
                bitPos = readObjectTailer(data, bitPos, pt);
90
        }
91
}