svn-gvsig-desktop / branches / v2_0_0_prep / libraries / libDwg / src / org / gvsig / dwg / lib / readers / v2004 / DwgPolyline2DReader2004.java @ 28969
History | View | Annotate | Download (3.37 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.DwgPolyline2D; |
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 DwgPolyline2DReader2004 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 DwgPolyline2D)) |
29 |
throw new RuntimeException(this.getClass().getName()+" solo puede leer DwgPolyline2D"); |
30 |
DwgPolyline2D ln = (DwgPolyline2D) dwgObj; |
31 |
int bitPos = offset;
|
32 |
boolean dontRead = false; |
33 |
ArrayList v;
|
34 |
|
35 |
|
36 |
bitPos = readObjectHeader(data, bitPos, ln); |
37 |
|
38 |
v = DwgUtil.getBitShort(data, bitPos); |
39 |
bitPos = ((Integer)v.get(0)).intValue(); |
40 |
int flags = ((Integer)v.get(1)).intValue(); |
41 |
ln.setFlags(flags); |
42 |
|
43 |
v = DwgUtil.getBitShort(data, bitPos); |
44 |
bitPos = ((Integer)v.get(0)).intValue(); |
45 |
int ctype = ((Integer)v.get(1)).intValue(); |
46 |
ln.setCurveType(ctype); |
47 |
|
48 |
v = DwgUtil.getBitDouble(data, bitPos); |
49 |
bitPos = ((Integer)v.get(0)).intValue(); |
50 |
double sw = ((Double)v.get(1)).doubleValue(); |
51 |
ln.setInitWidth(sw); |
52 |
|
53 |
v = DwgUtil.getBitDouble(data, bitPos); |
54 |
bitPos = ((Integer)v.get(0)).intValue(); |
55 |
double ew = ((Double)v.get(1)).doubleValue(); |
56 |
ln.setEndWidth(ew); |
57 |
|
58 |
v = DwgUtil.testBit(data, bitPos); |
59 |
bitPos = ((Integer)v.get(0)).intValue(); |
60 |
boolean flag = ((Boolean)v.get(1)).booleanValue(); |
61 |
double th = 0.0; |
62 |
if (!flag) {
|
63 |
v = DwgUtil.getBitDouble(data, bitPos); |
64 |
bitPos = ((Integer)v.get(0)).intValue(); |
65 |
th = ((Double)v.get(1)).doubleValue(); |
66 |
} |
67 |
ln.setThickness(th); |
68 |
|
69 |
v = DwgUtil.getBitDouble(data, bitPos); |
70 |
bitPos = ((Integer)v.get(0)).intValue(); |
71 |
double elev = ((Double)v.get(1)).doubleValue(); |
72 |
ln.setElevation(elev); |
73 |
|
74 |
v = DwgUtil.testBit(data, bitPos); |
75 |
bitPos = ((Integer)v.get(0)).intValue(); |
76 |
flag = ((Boolean)v.get(1)).booleanValue(); |
77 |
double ex, ey, ez = 0.0; |
78 |
if (flag) {
|
79 |
ex = 0.0;
|
80 |
ey = 0.0;
|
81 |
ez = 1.0;
|
82 |
} else {
|
83 |
v = DwgUtil.getBitDouble(data, bitPos); |
84 |
bitPos = ((Integer)v.get(0)).intValue(); |
85 |
ex = ((Double)v.get(1)).doubleValue(); |
86 |
v = DwgUtil.getBitDouble(data, bitPos); |
87 |
bitPos = ((Integer)v.get(0)).intValue(); |
88 |
ey = ((Double)v.get(1)).doubleValue(); |
89 |
v = DwgUtil.getBitDouble(data, bitPos); |
90 |
bitPos = ((Integer)v.get(0)).intValue(); |
91 |
ez = ((Double)v.get(1)).doubleValue(); |
92 |
} |
93 |
ln.setExtrusion(new double[]{ex, ey, ez}); |
94 |
|
95 |
v = DwgUtil.getBitLong(data, bitPos); //OWNED OBJECT COUNT
|
96 |
bitPos = ((Integer)v.get(0)).intValue(); |
97 |
int OwnedObj = ((Integer)v.get(1)).intValue(); |
98 |
|
99 |
bitPos = readObjectTailer(data, bitPos, ln); |
100 |
|
101 |
DwgHandleReference hr; |
102 |
if (OwnedObj>0) { |
103 |
for (int i=0;i<OwnedObj;i++) { |
104 |
hr = new DwgHandleReference();
|
105 |
bitPos = hr.read(data, bitPos); |
106 |
ln.addVertexHandle(hr); |
107 |
} |
108 |
} |
109 |
|
110 |
hr = new DwgHandleReference();
|
111 |
bitPos = hr.read(data, bitPos); |
112 |
ln.setSeqendHandle(hr); |
113 |
ln.inserta(); |
114 |
|
115 |
} |
116 |
|
117 |
} |