Statistics
| Revision:

svn-gvsig-desktop / branches / v10 / libraries / libDwg / src / com / iver / cit / jdwglib / dwg / readers / objreaders / v15 / DwgPointReader15.java @ 10539

History | View | Annotate | Download (2.65 KB)

1
/*
2
 * Created on 25-ene-2007 by azabala
3
 *
4
 */
5
package com.iver.cit.jdwglib.dwg.readers.objreaders.v15;
6

    
7
import java.util.ArrayList;
8

    
9
import com.iver.cit.jdwglib.dwg.CorruptedDwgEntityException;
10
import com.iver.cit.jdwglib.dwg.DwgObject;
11
import com.iver.cit.jdwglib.dwg.DwgUtil;
12
import com.iver.cit.jdwglib.dwg.objects.DwgPoint;
13

    
14
/**
15
 * @author alzabord
16
 *
17
 * TODO To change the template for this generated type comment go to
18
 * Window - Preferences - Java - Code Style - Code Templates
19
 */
20
public class DwgPointReader15 extends AbstractDwg15Reader{
21

    
22
        /* (non-Javadoc)
23
         * @see com.iver.cit.jdwglib.dwg.readers.IDwgObjectReader#readSpecificObj(int[], int, com.iver.cit.jdwglib.dwg.DwgObject)
24
         */
25
        public void readSpecificObj(int[] data, int offset, DwgObject dwgObj) throws RuntimeException, CorruptedDwgEntityException {
26
                if(! (dwgObj instanceof DwgPoint))
27
                        throw new RuntimeException("ArcReader 15 solo puede leer DwgPoint");
28
                DwgPoint pt = (DwgPoint) dwgObj;
29
                int bitPos = offset;
30
                bitPos = headTailReader.readObjectHeader(data, bitPos, pt);
31
                ArrayList v = DwgUtil.getBitDouble(data, bitPos);
32
                bitPos = ((Integer)v.get(0)).intValue();
33
                double x = ((Double)v.get(1)).doubleValue();
34
                v = DwgUtil.getBitDouble(data, bitPos);
35
                bitPos = ((Integer)v.get(0)).intValue();
36
                double y = ((Double)v.get(1)).doubleValue();
37
                v = DwgUtil.getBitDouble(data, bitPos);
38
                bitPos = ((Integer)v.get(0)).intValue();
39
                double z = ((Double)v.get(1)).doubleValue();
40
                double[] coord = new double[]{x, y, z};
41
                pt.setPoint(coord);
42
                v = DwgUtil.testBit(data, bitPos);
43
                bitPos = ((Integer)v.get(0)).intValue();
44
                boolean flag = ((Boolean)v.get(1)).booleanValue();
45
            double val;
46
                if (flag) {
47
                        val=0.0;
48
                } else {
49
                        v = DwgUtil.getBitDouble(data, bitPos);
50
                        bitPos = ((Integer)v.get(0)).intValue();
51
                        val = ((Double)v.get(1)).doubleValue();
52
                }
53
                pt.setThickness(val);
54
                v = DwgUtil.testBit(data, bitPos);
55
                bitPos = ((Integer)v.get(0)).intValue();
56
                flag = ((Boolean)v.get(1)).booleanValue();
57
                if (flag) {
58
                         x = y = 0.0;
59
                         z = 1.0;
60
                } else {
61
                        v = DwgUtil.getBitDouble(data, bitPos);
62
                        bitPos = ((Integer)v.get(0)).intValue();
63
                        x = ((Double)v.get(1)).doubleValue();
64
                        v = DwgUtil.getBitDouble(data, bitPos);
65
                        bitPos = ((Integer)v.get(0)).intValue();
66
                        y = ((Double)v.get(1)).doubleValue();
67
                        v = DwgUtil.getBitDouble(data, bitPos);
68
                        bitPos = ((Integer)v.get(0)).intValue();
69
                        z = ((Double)v.get(1)).doubleValue();
70
                }
71
                coord = new double[]{x, y, z};
72
                pt.setExtrusion(coord);
73
                v = DwgUtil.getBitDouble(data, bitPos);
74
                bitPos = ((Integer)v.get(0)).intValue();
75
                val = ((Double)v.get(1)).doubleValue();
76
                pt.setXAxisAngle(val);
77
                bitPos = headTailReader.readObjectTailer(data, bitPos, pt);
78
        }
79
}