Statistics
| Revision:

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

History | View | Annotate | Download (4.47 KB)

1 10103 azabala
/*
2
 * Created on 02-feb-2007
3
 *
4
 * gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
5
 *
6
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
7
 *
8
 * This program is free software; you can redistribute it and/or
9
 * modify it under the terms of the GNU General Public License
10
 * as published by the Free Software Foundation; either version 2
11
 * of the License, or (at your option) any later version.
12
 *
13
 * This program is distributed in the hope that it will be useful,
14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16
 * GNU General Public License for more details.
17
 *
18
 * You should have received a copy of the GNU General Public License
19
 * along with this program; if not, write to the Free Software
20
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
21
 *
22
 * For more information, contact:
23
 *
24
 *  Generalitat Valenciana
25
 *   Conselleria d'Infraestructures i Transport
26
 *   Av. Blasco Ib??ez, 50
27
 *   46010 VALENCIA
28
 *   SPAIN
29
 *
30
 *      +34 963862235
31
 *   gvsig@gva.es
32
 *      www.gvsig.gva.es
33
 *
34
 *    or
35
 *
36
 *   IVER T.I. S.A
37
 *   Salamanca 50
38
 *   46005 Valencia
39
 *   Spain
40
 *
41
 *   +34 963163400
42
 *   dac@iver.es
43
 */
44
/* CVS MESSAGES:
45
*
46
* $Id$
47
* $Log$
48 10847 azabala
* Revision 1.2.2.2  2007-03-21 19:49:16  azabala
49
* implementation of dwg 12, 13, 14.
50 10539 jmvivo
*
51
* Revision 1.2  2007/02/07 12:45:21  fdiaz
52 10103 azabala
* *** empty log message ***
53
*
54 10175 fdiaz
* Revision 1.1  2007/02/05 07:03:22  azabala
55
* *** empty log message ***
56 10103 azabala
*
57 10175 fdiaz
*
58 10103 azabala
*/
59 28969 jmvivo
package org.gvsig.dwg.lib.readers.v1314;
60 10103 azabala
61
import java.util.List;
62
63 28969 jmvivo
import org.gvsig.dwg.lib.CorruptedDwgEntityException;
64
import org.gvsig.dwg.lib.DwgHandleReference;
65
import org.gvsig.dwg.lib.DwgObject;
66
import org.gvsig.dwg.lib.DwgUtil;
67
import org.gvsig.dwg.lib.objects.DwgInsert;
68
import org.gvsig.dwg.lib.objects.DwgMinsert;
69 10103 azabala
70 28969 jmvivo
71 10103 azabala
public class DwgMinsertReader1314 extends AbstractDwg1314Reader {
72
73
        public void readSpecificObj(int[] data, int offset, DwgObject dwgObj)
74
                        throws RuntimeException, CorruptedDwgEntityException {
75
                if(! (dwgObj instanceof DwgInsert))
76
                    throw new RuntimeException("ArcReader 14 solo puede leer DwgMInsert");
77
                DwgMinsert insert = (DwgMinsert) dwgObj;
78
                int bitPos = offset;
79
                bitPos = headTailReader.readObjectHeader(data, bitPos, insert);
80
81
                List val = DwgUtil.getBitDouble(data, bitPos);
82
                bitPos = ((Integer)val.get(0)).intValue();
83
                double x = ((Double)val.get(1)).doubleValue();
84
85
                val = DwgUtil.getBitDouble(data, bitPos);
86
                bitPos = ((Integer)val.get(0)).intValue();
87
                double y = ((Double)val.get(1)).doubleValue();
88
89
                val = DwgUtil.getBitDouble(data, bitPos);
90
                bitPos = ((Integer)val.get(0)).intValue();
91
                double z = ((Double)val.get(1)).doubleValue();
92
                insert.setInsertionPoint(new double[]{x, y, z});
93
94
                val = DwgUtil.getBitDouble(data, bitPos);
95
                bitPos = ((Integer)val.get(0)).intValue();
96
                x = ((Double)val.get(1)).doubleValue();
97
98
                val = DwgUtil.getBitDouble(data, bitPos);
99
                bitPos = ((Integer)val.get(0)).intValue();
100
                y = ((Double)val.get(1)).doubleValue();
101
102
                val = DwgUtil.getBitDouble(data, bitPos);
103
                bitPos = ((Integer)val.get(0)).intValue();
104
                z = ((Double)val.get(1)).doubleValue();
105
                insert.setScale(new double[]{x, y, z});
106
107
                val = DwgUtil.getBitDouble(data, bitPos);
108
                bitPos = ((Integer)val.get(0)).intValue();
109
                double rotation = ((Double)val.get(1)).doubleValue();
110
                insert.setRotation(rotation);
111
112
                val = DwgUtil.getBitDouble(data, bitPos);
113
                bitPos = ((Integer)val.get(0)).intValue();
114
                x = ((Double)val.get(1)).doubleValue();
115
116
                val = DwgUtil.getBitDouble(data, bitPos);
117
                bitPos = ((Integer)val.get(0)).intValue();
118
                y = ((Double)val.get(1)).doubleValue();
119
120
                val = DwgUtil.getBitDouble(data, bitPos);
121
                bitPos = ((Integer)val.get(0)).intValue();
122
                z = ((Double)val.get(1)).doubleValue();
123
                insert.setExtrusion(new double[]{x, y, z});
124
125
                val = DwgUtil.testBit(data, bitPos);
126
                bitPos = ((Integer)val.get(0)).intValue();
127
                boolean hasAttr = ((Boolean)val.get(1)).booleanValue();
128
129
                bitPos = headTailReader.readObjectTailer(data, bitPos, insert);
130
131
                DwgHandleReference handle = new DwgHandleReference();
132
                bitPos = handle.read(data, bitPos);
133
                insert.setBlockHeaderHandle(handle);
134
135
                if(hasAttr){
136
                        handle = new DwgHandleReference();
137
                        bitPos = handle.read(data, bitPos);
138
                        insert.setFirstAttribHandle(handle);
139
140
                        handle = new DwgHandleReference();
141
                        bitPos = handle.read(data, bitPos);
142
                        insert.setLastAttribHandle(handle);
143
144
                        handle = new DwgHandleReference();
145
                        bitPos = handle.read(data, bitPos);
146 10175 fdiaz
                        insert.setSeqEndHandle(handle);
147 10103 azabala
                }//if
148
        }
149
150
}