Statistics
| Revision:

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

History | View | Annotate | Download (3.24 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.DwgHandleReference;
11
import com.iver.cit.jdwglib.dwg.DwgObject;
12
import com.iver.cit.jdwglib.dwg.DwgUtil;
13
import com.iver.cit.jdwglib.dwg.objects.DwgPolyline2D;
14

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

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

    
83
            bitPos = headTailReader.readObjectTailer(data, bitPos, ln);
84
                DwgHandleReference hr = new DwgHandleReference();
85
                bitPos = hr.read(data, bitPos);
86
                ln.setFirstVertexHandle(hr);
87

    
88
                hr = new DwgHandleReference();
89
                bitPos = hr.read(data, bitPos);
90
                ln.setLastVertexHandle(hr);
91

    
92
                hr = new DwgHandleReference();
93
                bitPos = hr.read(data, bitPos);
94
            ln.setSeqendHandle(hr);
95

    
96
        }
97

    
98
}