Statistics
| Revision:

root / trunk / libraries / libDwg / src / com / iver / cit / jdwglib / dwg / readers / objreaders / v15 / DwgSolidReader15.java @ 10820

History | View | Annotate | Download (3.36 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.DwgSolid;
13

    
14
/**
15
 * @author azabala
16
 */
17
public class DwgSolidReader15 extends AbstractDwg15Reader{
18

    
19
        /* (non-Javadoc)
20
         * @see com.iver.cit.jdwglib.dwg.readers.IDwgObjectReader#readSpecificObj(int[], int, com.iver.cit.jdwglib.dwg.DwgObject)
21
         */
22
        public void readSpecificObj(int[] data, int offset, DwgObject dwgObj) throws RuntimeException, CorruptedDwgEntityException {
23
                if(! (dwgObj instanceof DwgSolid))
24
                        throw new RuntimeException("ArcReader 15 solo puede leer DwgSolid");
25
                DwgSolid sol = (DwgSolid) dwgObj;
26
                int bitPos = offset;
27
                bitPos = headTailReader.readObjectHeader(data, bitPos, sol);
28
                ArrayList v = DwgUtil.testBit(data, bitPos);
29
                bitPos = ((Integer)v.get(0)).intValue();
30
                boolean flag = ((Boolean)v.get(1)).booleanValue();
31
            double val;
32
                if (flag) {
33
                        val=0.0;
34
                } else {
35
                        v = DwgUtil.getBitDouble(data, bitPos);
36
                        bitPos = ((Integer)v.get(0)).intValue();
37
                        val = ((Double)v.get(1)).doubleValue();
38
                }
39
                sol.setThickness(val);
40
                
41
                v = DwgUtil.getBitDouble(data, bitPos);
42
                bitPos = ((Integer)v.get(0)).intValue();
43
                val = ((Double)v.get(1)).doubleValue();
44
                sol.setElevation(val);
45
                
46
                
47
                v = DwgUtil.getRawDouble(data, bitPos);
48
                bitPos = ((Integer)v.get(0)).intValue();
49
                double x = ((Double)v.get(1)).doubleValue();
50
                v = DwgUtil.getRawDouble(data, bitPos);
51
                bitPos = ((Integer)v.get(0)).intValue();
52
                double y = ((Double)v.get(1)).doubleValue();
53
                double[] coord = new double[]{x, y, val};
54
                sol.setCorner1(coord);
55
                
56
                
57
                v = DwgUtil.getRawDouble(data, bitPos);
58
                bitPos = ((Integer)v.get(0)).intValue();
59
                x = ((Double)v.get(1)).doubleValue();
60
                v = DwgUtil.getRawDouble(data, bitPos);
61
                bitPos = ((Integer)v.get(0)).intValue();
62
                y = ((Double)v.get(1)).doubleValue();
63
                coord = new double[]{x, y, val};
64
                sol.setCorner2(coord);
65
                
66
                
67
                v = DwgUtil.getRawDouble(data, bitPos);
68
                bitPos = ((Integer)v.get(0)).intValue();
69
                x = ((Double)v.get(1)).doubleValue();
70
                v = DwgUtil.getRawDouble(data, bitPos);
71
                bitPos = ((Integer)v.get(0)).intValue();
72
                y = ((Double)v.get(1)).doubleValue();
73
                coord = new double[]{x, y, val};
74
                sol.setCorner3(coord);
75
                
76
                
77
                v = DwgUtil.getRawDouble(data, bitPos);
78
                bitPos = ((Integer)v.get(0)).intValue();
79
                x = ((Double)v.get(1)).doubleValue();
80
                v = DwgUtil.getRawDouble(data, bitPos);
81
                bitPos = ((Integer)v.get(0)).intValue();
82
                y = ((Double)v.get(1)).doubleValue();
83
                coord = new double[]{x, y, val};
84
                sol.setCorner4(coord);
85
                
86
                
87
                v = DwgUtil.testBit(data, bitPos);
88
                bitPos = ((Integer)v.get(0)).intValue();
89
                flag = ((Boolean)v.get(1)).booleanValue();
90
                double z;
91
            if (flag) {
92
                         x = y = 0.0;
93
                         z = 1.0;
94
                } else {
95
                        v = DwgUtil.getBitDouble(data, bitPos);
96
                        bitPos = ((Integer)v.get(0)).intValue();
97
                        x = ((Double)v.get(1)).doubleValue();
98
                        v = DwgUtil.getBitDouble(data, bitPos);
99
                        bitPos = ((Integer)v.get(0)).intValue();
100
                        y = ((Double)v.get(1)).doubleValue();
101
                        v = DwgUtil.getBitDouble(data, bitPos);
102
                        bitPos = ((Integer)v.get(0)).intValue();
103
                        z = ((Double)v.get(1)).doubleValue();
104
                }
105
                coord = new double[]{x, y, z};
106
                sol.setExtrusion(coord);
107
                
108
                bitPos = headTailReader.readObjectTailer(data, bitPos, sol);
109
        }
110
}