Statistics
| Revision:

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

History | View | Annotate | Download (3.07 KB)

1
/*
2
 * Created on 03-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: DwgPFaceReader1314.java 28969 2009-05-25 13:23:12Z jmvivo $
47
* $Log$
48
* Revision 1.1.2.2  2007-03-21 19:49:16  azabala
49
* implementation of dwg 12, 13, 14.
50
*
51
* Revision 1.3  2007/03/20 19:57:09  azabala
52
* source code cleaning
53
*
54
* Revision 1.2  2007/03/01 19:56:52  azabala
55
* refactor of names
56
*
57
* Revision 1.1  2007/02/05 07:03:22  azabala
58
* *** empty log message ***
59
*
60
*
61
*/
62
package org.gvsig.dwg.lib.readers.v1314;
63

    
64
import java.util.List;
65

    
66
import org.gvsig.dwg.lib.CorruptedDwgEntityException;
67
import org.gvsig.dwg.lib.DwgHandleReference;
68
import org.gvsig.dwg.lib.DwgObject;
69
import org.gvsig.dwg.lib.DwgUtil;
70
import org.gvsig.dwg.lib.objects.DwgPFacePolyline;
71

    
72

    
73
public class DwgPFaceReader1314 extends AbstractDwg1314Reader {
74

    
75
        public void readSpecificObj(int[] data, int offset, DwgObject dwgObj)
76
                        throws RuntimeException, CorruptedDwgEntityException {
77
                
78
                if(! (dwgObj instanceof DwgPFacePolyline))
79
                    throw new RuntimeException("ArcReader 14 solo puede leer DwgPFacePolyline");
80
                DwgPFacePolyline pface = (DwgPFacePolyline) dwgObj;
81
                int bitPos = offset;
82
                bitPos = headTailReader.readObjectHeader(data, bitPos, pface);
83
                
84
                List val = DwgUtil.getBitShort(data, bitPos);
85
                bitPos = ((Integer) val.get(0)).intValue();
86
                int vertexCount = ((Integer) val.get(1)).intValue();
87
                pface.setVertexCount(vertexCount);
88
                
89
                val = DwgUtil.getBitShort(data, bitPos);
90
                bitPos = ((Integer) val.get(0)).intValue();
91
                int faceCount = ((Integer) val.get(1)).intValue();
92
                pface.setFaceCount(faceCount);
93
                
94
                bitPos = headTailReader.readObjectTailer(data, bitPos, pface);
95
                
96
                DwgHandleReference handle = new DwgHandleReference();
97
                bitPos = handle.read(data, bitPos);
98
                pface.setFirstVertexHandle(handle);
99
                
100
                handle = new DwgHandleReference();
101
                bitPos = handle.read(data, bitPos);
102
                pface.setLastVertexHandle(handle);
103
                
104
                handle = new DwgHandleReference();
105
                bitPos = handle.read(data, bitPos);
106
                pface.setSeqendHandle(handle);
107
        }
108

    
109
}
110