Revision 390

View differences:

org.gvsig.dxf/tags/org.gvsig.dxf-2.0.88/org.gvsig.dxf.lib/src/main/java/org/gvsig/dxf/io/DxfGroup.java
1
/*
2
 * Cresques Mapping Suite. Graphic Library for constructing mapping applications.
3
 *
4
 * Copyright (C) 2004-5.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 2
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
19
 *
20
 * For more information, contact:
21
 *
22
 * cresques@gmail.com
23
 */
24
package org.gvsig.dxf.io;
25

  
26
import java.io.BufferedReader;
27
import java.io.IOException;
28
import java.text.DecimalFormat;
29
import java.text.DecimalFormatSymbols;
30
import java.util.Locale;
31

  
32

  
33
/**
34
 * Grupo Dxf (code, data). Auxiliar para leer ficheros dxf
35
 *
36
 * @author "Luis W. Sevilla" <sevilla_lui@gva.es>
37
 * @author "Michel Michaud" (code from)
38
 */
39
public class DxfGroup {
40
    /*
41
    def get_group(handle):
42
    _code = int(handle.readline())
43
    _dfun = get_data_type(_code)
44
    _data = _dfun(handle.readline())
45
    return (_code, _data)
46
     */
47
    private static final DecimalFormatSymbols dfs = new DecimalFormatSymbols(Locale.US);
48
    private static final DecimalFormat[] decimalFormats = new DecimalFormat[] {
49
                                                              new DecimalFormat("#0",
50
                                                                                dfs),
51
                                                              new DecimalFormat("#0.0",
52
                                                                                dfs),
53
                                                              new DecimalFormat("#0.00",
54
                                                                                dfs),
55
                                                              new DecimalFormat("#0.000",
56
                                                                                dfs),
57
                                                              new DecimalFormat("#0.0000",
58
                                                                                dfs),
59
                                                              new DecimalFormat("#0.00000",
60
                                                                                dfs),
61
                                                              new DecimalFormat("#0.000000",
62
                                                                                dfs),
63
                                                              new DecimalFormat("#0.0000000",
64
                                                                                dfs),
65
                                                              new DecimalFormat("#0.00000000",
66
                                                                                dfs),
67
                                                              new DecimalFormat("#0.000000000",
68
                                                                                dfs),
69
                                                              new DecimalFormat("#0.0000000000",
70
                                                                                dfs),
71
                                                              new DecimalFormat("#0.00000000000",
72
                                                                                dfs),
73
                                                              new DecimalFormat("#0.000000000000",
74
                                                                                dfs)
75
                                                          };
76
    int code;
77
    Object data;
78
    
79
    /**
80
     * Constructor por defecto.
81
     */
82
    public DxfGroup() {
83
        code = -1;
84
        data = null;
85
    }
86
    
87
    /**
88
     * Constructor habitual. Representa una entidad individual dentro del DXF
89
     * @param code, �ndice del dato dentro del DxfGroup
90
     * @param data, el propio dato que queda almacenado en el DxfGroup
91
     */
92
    public DxfGroup(int code, String data) {
93
        this.code = code;
94
        this.data = data;
95
    }
96
    
97
    /**
98
     * Lee una entidad del DXF y la empaqueta en un DxfGroup.
99
     * @param fi, BufferedReader mediante el cual accedemos al DXF
100
     * @return DxfGroup con la informaci�n procedente del DXF
101
     * @throws NumberFormatException
102
     * @throws IOException
103
     */
104
    public static DxfGroup read(BufferedReader fi)
105
                         throws NumberFormatException, IOException {
106
        DxfGroup grp = null;
107
        String txt = fi.readLine();
108

  
109
        if (txt != null) {
110
            if (!txt.equals("")) {
111
                grp = new DxfGroup();
112
                grp.code = Integer.parseInt(txt.trim());
113
                grp.readData(fi);
114
            } else {
115
                // Se trata de una linea en blanco y no se hace nada.
116
            }
117
        }
118

  
119
        return grp;
120
    }
121
    
122
    /**
123
     * Devuelve el code
124
     * @return
125
     */
126
    public int getCode() {
127
        return code;
128
    }
129
    
130
    /**
131
     * Devuelve data
132
     * @return
133
     */
134
    public Object getData() {
135
        return data;
136
    }
137
    
138
    /**
139
     * Lee un dato individual dentro de un DxfGroup
140
     * @param fi, BufferedReader
141
     * @throws IOException
142
     */
143
    private void readData(BufferedReader fi) throws IOException {
144
        String txt = fi.readLine().trim();
145

  
146
        if ((0 <= code) && (code <= 9)) {
147
            data = txt; //_dfun = string_data
148
        } else if ((10 <= code) && (code <= 59)) {
149
            data = new Double(Double.parseDouble(txt)); //_dfun = float_data
150
        } else if ((60 <= code) && (code <= 79)) {
151
            try {
152
                data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // 16-bit int
153
            } catch (java.lang.NumberFormatException e) {
154
                data = new Integer((int) Double.parseDouble(txt));
155
            }
156
        } else if ((90 <= code) && (code <= 99)) {
157
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // 32-bit int
158
        } else if (code == 100) {
159
            data = txt; //_dfun = unicode_data
160
        } else if (code == 102) {
161
            // Fran: Comentado para ganar velocidad.
162
            //System.err. ("Dxf: codigo " + code + " no implementado."); //_dfun = unicode_data
163
        } else if (code == 105) {
164
            data = txt;
165
            ; //_dfun = handle_data
166
        } else if ((110 <= code) && (code <= 139)) {
167
            data = new Double(Double.parseDouble(txt)); //_dfun = float_data // not in dxf spec
168
        } else if ((140 <= code) && (code <= 149)) { // says 147 in dxf spec
169
            data = new Double(Double.parseDouble(txt)); //_dfun = float_data
170
        } else if ((170 <= code) && (code <= 179)) { // says 175 in dxf spec
171
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // 16-bit int
172
        } else if ((210 <= code) && (code <= 239)) {
173
            data = new Double(Double.parseDouble(txt)); //_dfun = float_data // del TEXT procendente de exportacion de microstation 
174
        } else if ((270 <= code) && (code <= 279)) {
175
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // not in dxf spec
176
        } else if ((280 <= code) && (code <= 289)) {
177
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // 8-bit int
178
        } else if ((290 <= code) && (code <= 299)) {
179
            data = new Boolean(Boolean.getBoolean(txt)); //_dfun = bool_data
180
        } else if ((300 <= code) && (code <= 309)) {
181
            data = txt; //_dfun = string_data
182
        } else if ((310 <= code) && (code <= 319)) {
183
            //_dfun = bin_data
184
            //throw new IOException("Dxf: codigo "+code+" no implementado.");
185
        } else if ((320 <= code) && (code <= 329)) {
186
            //_dfun = handle_data
187
            //throw new IOException("Dxf: codigo "+code+" no implementado.");
188
        } else if ((330 <= code) && (code <= 369)) {
189
            // Fran: Comentado para ganar velocidad.
190
            //System.err.   ("Dxf: codigo " + code + " no implementado."); //_dfun = hex_data
191
        } else if ((370 <= code) && (code <= 379)) {
192
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // 8-bit int
193
        } else if ((380 <= code) && (code <= 389)) {
194
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // 8-bit int
195
        } else if ((390 <= code) && (code <= 399)) {
196
            data = txt; //_dfun = handle_data
197
        } else if ((400 <= code) && (code <= 409)) {
198
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // 16-bit int
199
        } else if ((410 <= code) && (code <= 419)) {
200
            data = txt; //_dfun = string_data
201
        } else if (code == 999) {
202
            data = txt; //_dfun = string_data // comment
203
        } else if ((1000 <= code) && (code <= 1009)) {
204
            data = txt; //_dfun = string_data
205
        } else if ((1010 <= code) && (code <= 1059)) {
206
            data = new Double(Double.parseDouble(txt)); //_dfun = float_data
207
        } else if ((1060 <= code) && (code <= 1070)) {
208
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data // 16-bit int
209
        } else if (code == 1071) {
210
            data = new Integer(Integer.parseInt(txt)); //_dfun = int_data # 32-bit int
211
        } else {
212
            throw new IOException("DxfReader: c�digo " + code +
213
                                  " desconocido.");
214

  
215
            //raise ValueError, "Unexpected code: %d" % code
216
        }
217

  
218
        //return _dfun
219
    }
220
    
221
    /**
222
     * Permite comparar dos objetos de la clase DxfGroup
223
     * @param c, code
224
     * @param s, data
225
     * @return boolean
226
     */
227
    public boolean equals(int c, String s) {
228
        if ((c == code) && (s.compareTo((String) data) == 0)) {
229
            return true;
230
        }
231

  
232
        return false;
233
    }
234
    
235
    /**
236
     * Devuelve un dato concreto en forma de String tabulado
237
     * @param code
238
     * @return String
239
     */
240
    public static String int34car(int code) {
241
        if (code < 10) {
242
            return "  " + Integer.toString(code);
243
        } else if (code < 100) {
244
            return " " + Integer.toString(code);
245
        } else {
246
            return Integer.toString(code);
247
        }
248
    }
249
    
250
    /**
251
     * Devuelve un dato concreto en forma de String tabulado
252
     * @param value
253
     * @return String
254
     */
255
    public static String int6car(int value) {
256
        String s = "     " + Integer.toString(value);
257

  
258
        return s.substring(s.length() - 6, s.length());
259
    }
260
    
261
    /**
262
     * Convierte a String un dato del DxfGroup
263
     * @param code
264
     * @param value
265
     * @return String
266
     */
267
    public static String toString(int code, String value) {
268
        return int34car(code) + "\r\n" + value + "\r\n";
269
    }
270
    
271
    /**
272
     * Convierte a String un dato del DxfGroup
273
     * @param code
274
     * @param value
275
     * @return String
276
     */
277
    public static String toString(int code, int value) {
278
        return int34car(code) + "\r\n" + int6car(value) + "\r\n";
279
    }
280
    
281
    /**
282
     * Convierte a String un dato del DxfGroup
283
     * @param code
284
     * @param value
285
     * @param decimalPartLength
286
     * @return String
287
     */
288
    public static String toString(int code, float value, int decimalPartLength) {
289
        return int34car(code) + "\r\n" +
290
               decimalFormats[decimalPartLength].format((double) value) +
291
               "\r\n";
292
    }
293
    
294
    /**
295
     * Convierte a String un dato del DxfGroup
296
     * @param code
297
     * @param value
298
     * @param decimalPartLength
299
     * @return String
300
     */
301
    public static String toString(int code, double value, int decimalPartLength) {
302
        return int34car(code) + "\r\n" +
303
               decimalFormats[decimalPartLength].format(value) + "\r\n";
304
    }
305
    
306
    /**
307
     * Convierte a String un dato del DxfGroup
308
     * @param code
309
     * @param value
310
     * @return String
311
     */
312
    public static String toString(int code, Object value) {
313
        if (value instanceof String) {
314
            return toString(code, (String) value);
315
        } else if (value instanceof Integer) {
316
            return toString(code, ((Integer) value).intValue());
317
        } else if (value instanceof Double) {
318
            return toString(code, ((Double) value).floatValue(), 3);
319
        } else if (value instanceof Double) {
320
            return toString(code, ((Double) value).doubleValue(), 6);
321
        } else {
322
            return toString(code, value.toString());
323
        }
324
    }
325
    
326
    /**
327
     * Convierte a String un dato del DxfGroup
328
     */
329
    public String toString() {
330
        return toString(code, data);
331
    }
332

  
333
    /**
334
     * jmorell: Permite rellenar los datos. �til en la escritura de DXFs.
335
     * @param data The data to set.
336
     */
337
    public void setData(Object data) {
338
        this.data = data;
339
    }
340

  
341
    /**
342
     * jmorell: Permite rellenar los c�digos. �til en la escritura de DXFs.
343
     * @param code The code to set.
344
     */
345
    public void setCode(int code) {
346
        this.code = code;
347
    }
348
}
org.gvsig.dxf/tags/org.gvsig.dxf-2.0.88/org.gvsig.dxf.lib/src/main/java/org/gvsig/dxf/io/ZipFileFolder.java
1
/*
2
 * Cresques Mapping Suite. Graphic Library for constructing mapping applications.
3
 *
4
 * Copyright (C) 2004-5.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 2
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
19
 *
20
 * For more information, contact:
21
 *
22
 * cresques@gmail.com
23
 */
24
package org.gvsig.dxf.io;
25

  
26
import java.io.IOException;
27
import java.io.InputStream;
28
import java.util.Enumeration;
29
import java.util.zip.ZipEntry;
30
import java.util.zip.ZipFile;
31

  
32

  
33
/**
34
 * @author "Luis W. Sevilla" <sevilla_lui@gva.es>* @author administrador
35
 */
36
public class ZipFileFolder extends FileFolder {
37
    String zName = null;
38
    public ZipFile file = null;
39

  
40
    public ZipFileFolder() {
41
        super();
42
    }
43

  
44
    /**
45
     * Constructor.
46
     *
47
     * @param fname
48
     */
49
    public ZipFileFolder(String fName) throws IOException {
50
        fName = DataSource.normalize(fName);
51

  
52
        if (isUrl(fName)) {
53
            zName = getZName(fName);
54
        } else {
55
            zName = fName;
56
        }
57

  
58
        file = new ZipFile(zName);
59
    }
60

  
61
    /**
62
     * Analiza un nombre de fichero en formato zip://zipname.zip?file.ext
63
     * @param urlName
64
     */
65
    public static boolean isUrl(String name) {
66
        String str = name.substring(0, 3);
67
        str.toLowerCase();
68

  
69
        if (str.compareTo("zip") == 0) {
70
            return true;
71
        }
72

  
73
        return false;
74
    }
75

  
76
    private String getZName(String urlName) {
77
        return urlName.substring(6, urlName.indexOf("?"));
78
    }
79

  
80
    private String getFName(String urlName) {
81
        return urlName.substring(urlName.indexOf("?") + 1);
82
    }
83

  
84
    public ZipEntry getZipEntry(String fName) throws IOException {
85
        InputStream is = null;
86

  
87
        if (isUrl(fName)) {
88
            fName = getFName(fName);
89
        }
90

  
91
        return file.getEntry(fName);
92
    }
93

  
94
    public InputStream getInputStream(String fName) throws IOException {
95
        return file.getInputStream(getZipEntry(fName));
96
    }
97

  
98
    public InputStream getInputStream(ZipEntry ze) throws IOException {
99
        return file.getInputStream(ze);
100
    }
101

  
102
    public int count() {
103
        return file.size();
104
    }
105

  
106
    public Enumeration entries() {
107
        return file.entries();
108
    }
109
}
org.gvsig.dxf/tags/org.gvsig.dxf-2.0.88/org.gvsig.dxf.lib/src/main/java/org/gvsig/dxf/io/DxfFile.java
1
/*
2
 * Cresques Mapping Suite. Graphic Library for constructing mapping applications.
3
 *
4
 * Copyright (C) 2004-5.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 2
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
19
 *
20
 * For more information, contact:
21
 *
22
 * cresques@gmail.com
23
 */
24
package org.gvsig.dxf.io;
25

  
26
import java.io.BufferedReader;
27
import java.io.FileReader;
28
import java.io.FileWriter;
29
import java.io.IOException;
30
import java.io.InputStream;
31
import java.io.InputStreamReader;
32
import java.io.Reader;
33
import java.util.Date;
34
import java.util.Hashtable;
35
import java.util.Vector;
36

  
37
import org.cresques.cts.ICoordTrans;
38
import org.cresques.cts.IProjection;
39
import org.cresques.geo.Projected;
40
import org.cresques.px.Extent;
41
import org.gvsig.dxf.px.IObjList;
42
import org.gvsig.dxf.px.dxf.DxfEntityMaker;
43
import org.gvsig.dxf.px.dxf.DxfHeaderManager;
44
import org.gvsig.dxf.px.dxf.DxfHeaderVariables;
45
import org.slf4j.Logger;
46
import org.slf4j.LoggerFactory;
47

  
48
/**
49
 * Clase que representa un fichero en formato DXF. Contiene los interfaces y
50
 * m�todos necesarios para acceder a la informaci�n almacenada en su
51
 * interior.
52
 *
53
 * @author jmorell
54
 */
55
public class DxfFile extends GeoFile {
56

  
57
    public static Logger logger = LoggerFactory.getLogger(DxfFile.class);
58

  
59
    private boolean cadFlag = true;
60

  
61
    long lineNr = 0;
62

  
63
    String buf = null;
64

  
65
    BufferedReader fi;
66
    long l = 0;
67
    int count = 0;
68
    DxfGroup grp = null;
69

  
70
    EntityFactory entityMaker = null;
71
    VarSettings headerManager;
72
    private boolean dxf3DFlag;
73

  
74
    /**
75
     * Crea los objetos en el Modelo correspondiente.
76
     *
77
     * @author "Luis W. Sevilla" <sevilla_lui@gva.es>
78
     */
79
    public interface EntityFactory extends Projected {
80

  
81
        /**
82
         * Permite saber si se est�n a�adiendo elementos a un bloque
83
         *
84
         * @param booleano que indica si se est�n a�adiendo elementos a un
85
         * bloque
86
         */
87
        public void setAddingToBlock(boolean a);
88

  
89
        /**
90
         * Crea una nueva capa partiendo de la informaci�n almacenada en el
91
         * DXF
92
         *
93
         * @param DxfGroupVector con informaci�n para la construcci�n de la
94
         * nueva capa
95
         * @throws Exception
96
         */
97
        public void createLayer(DxfGroupVector v) throws Exception;
98

  
99
        /**
100
         * Crea una nueva polil�nea partiendo de la informaci�n almacenada
101
         * en el DXF
102
         *
103
         * @param DxfGroupVector con informaci�n para la construcci�n de la
104
         * nueva polil�nea
105
         * @throws Exception
106
         */
107
        public void createPolyline(DxfGroupVector v) throws Exception;
108

  
109
        /**
110
         * A�ade un v�rtice a la polil�nea que se est� creando
111
         *
112
         * @param DxfGroupVector con la informaci�n necesaria para la
113
         * adici�n del v�rtice
114
         * @throws Exception
115
         */
116
        public void addVertex(DxfGroupVector v) throws Exception;
117

  
118
        /**
119
         * Fin de secuencia
120
         *
121
         * @throws Exception
122
         */
123
        public void endSeq() throws Exception;
124

  
125
        /**
126
         * Crea una nueva LwPolyline partiendo de la informaci�n almacenada en
127
         * el DXF
128
         *
129
         * @param DxfGroupVector con informaci�n para la construcci�n de la
130
         * nueva polil�nea
131
         * @throws Exception
132
         */
133
        public void createLwPolyline(DxfGroupVector v) throws Exception;
134

  
135
        /**
136
         * Crea una nueva l�nea partiendo de la informaci�n almacenada en el
137
         * DXF
138
         *
139
         * @param DxfGroupVector con informaci�n para la construcci�n de la
140
         * nueva l�nea
141
         * @throws Exception
142
         */
143
        public void createLine(DxfGroupVector v) throws Exception;
144

  
145
        /**
146
         * Crea un nuevo texto partiendo de la informaci�n almacenada en el
147
         * DXF
148
         *
149
         * @param DxfGroupVector con informaci�n para la construcci�n del
150
         * nuevo texto
151
         * @throws Exception
152
         */
153
        public void createText(DxfGroupVector v) throws Exception;
154

  
155
        /**
156
         * Crea un nuevo MText partiendo de la informaci�n almacenada en el
157
         * DXF
158
         *
159
         * @param DxfGroupVector con informaci�n para la construcci�n del
160
         * nuevo MText
161
         * @throws Exception
162
         */
163
        public void createMText(DxfGroupVector v) throws Exception;
164

  
165
        /**
166
         * Crea un nuevo punto partiendo de la informaci�n almacenada en el
167
         * DXF
168
         *
169
         * @param DxfGroupVector con informaci�n para la construcci�n del
170
         * nuevo punto
171
         * @throws Exception
172
         */
173
        public void createPoint(DxfGroupVector v) throws Exception;
174

  
175
        /**
176
         * Crea un nuevo c�rculo partiendo de la informaci�n almacenada en
177
         * el DXF
178
         *
179
         * @param DxfGroupVector con informaci�n para la construcci�n del
180
         * nuevo c�rculo
181
         * @throws Exception
182
         */
183
        public void createCircle(DxfGroupVector v) throws Exception;
184

  
185
        /**
186
         * Crea una nueva elipse partiendo de la informaci�n almacenada en el
187
         * DXF
188
         *
189
         * @param DxfGroupVector con informaci�n para la construcci�n de la
190
         * nueva elipse
191
         * @throws Exception
192
         */
193
        public void createEllipse(DxfGroupVector v) throws Exception;
194

  
195
        /**
196
         * Crea un nuevo arco partiendo de la informaci�n almacenada en el DXF
197
         *
198
         * @param DxfGroupVector con informaci�n para la construcci�n del
199
         * nuevo arco
200
         * @throws Exception
201
         */
202
        public void createArc(DxfGroupVector v) throws Exception;
203

  
204
        /**
205
         * Crea un nuevo punto de inserci�n partiendo de la informaci�n
206
         * almacenada en el DXF
207
         *
208
         * @param DxfGroupVector con informaci�n para la construcci�n del
209
         * nuevo punto de inserci�n
210
         * @throws Exception
211
         */
212
        public void createInsert(DxfGroupVector v) throws Exception;
213

  
214
        /**
215
         * Crea un nuevo s�lido 2D partiendo de la informaci�n almacenada en
216
         * el DXF
217
         *
218
         * @param DxfGroupVector con informaci�n para la construcci�n del
219
         * nuevo s�lido
220
         * @throws Exception
221
         */
222
        public void createSolid(DxfGroupVector v) throws Exception;
223

  
224
        /**
225
         * Crea un nuevo Spline partiendo de la informaci�n almacenada en el
226
         * DXF
227
         *
228
         * @param DxfGroupVector con informaci�n para la construcci�n del
229
         * nuevo Spline
230
         * @throws Exception
231
         */
232
        public void createSpline(DxfGroupVector v) throws Exception;
233

  
234
        /**
235
         * Construye la definici�n de un nuevo atributo partiendo de la
236
         * informaci�n almacenada en el DXF
237
         *
238
         * @param DxfGroupVector con informaci�n para la construcci�n de la
239
         * definici�n del nuevo atributo
240
         * @throws Exception
241
         */
242
        public void createAttdef(DxfGroupVector v) throws Exception;
243

  
244
        /**
245
         * Crea un nuevo atributo partiendo de la informaci�n almacenada en el
246
         * DXF
247
         *
248
         * @param DxfGroupVector con informaci�n para la creaci�n del nuevo
249
         * atributo
250
         * @throws Exception
251
         */
252
        public void createAttrib(DxfGroupVector v) throws Exception;
253

  
254
        /**
255
         * Crea un bloque
256
         *
257
         * @param DxfGroupVector con informaci�n para la creaci�n del nuevo
258
         * elemento
259
         * @throws Exception
260
         */
261
        public void createBlock(DxfGroupVector v) throws Exception;
262

  
263
        /**
264
         * Fin de la definici�n de un bloqe
265
         *
266
         * @param DxfGroupVector con informaci�n referente al final de un
267
         * bloque
268
         * @throws Exception
269
         */
270
        public void endBlk(DxfGroupVector v) throws Exception;
271

  
272
        /**
273
         * Gestiona los bloques que no se han tratado en la primera vuelta
274
         */
275
        void testBlocks();
276

  
277
        /**
278
         * Devuelve el extent
279
         *
280
         * @return el extent
281
         */
282
        public Extent getExtent();
283

  
284
        /**
285
         * Devuelve la lista de bloques
286
         *
287
         * @return la lista de bloques
288
         */
289
        public Vector getBlkList();
290

  
291
        /**
292
         * Permite la gesti�n de los atributos almacenados en unn DXF
293
         *
294
         * @return un Vector con la lista de atributos
295
         */
296
        public Vector getAttributes();
297

  
298
        /**
299
         * Borra los atributos repetidos
300
         */
301
        public void depureAttributes();
302

  
303
        /**
304
         * Devuelve los objetos almacenados en el DXF
305
         *
306
         * @return IObjList con los objetos procedentes del DXF
307
         */
308
        public IObjList getObjects();
309

  
310
        /**
311
         * Permite saber si se trata de un fichero DXF en 2D o en 3D
312
         *
313
         * @return booleano que indica si se trata de un fichero DXF 3D
314
         */
315
        public boolean isDxf3DFile();
316
    };
317

  
318
    /**
319
     * Establece el estado de las variables propias de un DXF que est�n
320
     * definidas en la secci�n HEADER. Por ejemplo, la versi�n del DXF.
321
     *
322
     * @author jmorell (jose.morell@gmail.com)
323
     * @version 15-dic-2004
324
     */
325
    public interface VarSettings {
326

  
327
        /**
328
         * Establece la versi�n de Autocad en la que fue generado el DXF.
329
         *
330
         * @param informaci�n de base
331
         * @throws Exception
332
         */
333
        public void setAcadVersion(DxfGroupVector v) throws Exception;
334

  
335
        /**
336
         * Devuelve la versi�n de Autocad en la que fue generado el DXF.
337
         *
338
         * @return
339
         */
340
        public String getAcadVersion();
341

  
342
        /**
343
         * Devuelve el estado de las variables propias de un DXF
344
         *
345
         * @return
346
         */
347
        public DxfHeaderVariables getDxfHeaderVars();
348

  
349
        public boolean isWritedDxf3D();
350

  
351
        public void loadMinZFromHeader(double d);
352

  
353
        public void loadMaxZFromHeader(double d);
354
    };
355

  
356
    /**
357
     * Constructor de la clase
358
     *
359
     * @param proj, la proyecci�n cartogr�fica
360
     * @param name, el path absoluto hasta el fichero DXF
361
     * @param maker, el interface que permite la construcci�n de las entidades
362
     * procedentes del DXF
363
     */
364
    public DxfFile(IProjection proj, String name, EntityFactory maker) {
365
        super(proj, name);
366
        entityMaker = maker;
367
        headerManager = new DxfHeaderManager();
368
    }
369

  
370
    /**
371
     * Constructor de la clase que adem�s incorpora la capacidad de leer una
372
     * porci�n del HEADER
373
     *
374
     * @param proj, la proyecci�n cartogr�fica
375
     * @param name, el path absoluto hasta el fichero DXF
376
     * @param maker, el interface que permite la construcci�n de las entidades
377
     * procedentes del DXF
378
     * @param dxfVars, el interface que permite la lectura del HEADER de un DXF
379
     */
380
    public DxfFile(IProjection proj, String name, EntityFactory maker, VarSettings dxfVars) {
381
        super(proj, name);
382
        entityMaker = maker;
383
        headerManager = dxfVars;
384
    }
385

  
386
    /**
387
     * Carga un fichero en formato DXF
388
     *
389
     * @throws Exception
390
     */
391
    public GeoFile load() throws Exception {
392
        logger.debug("Dxf: Cargando " + name + " ...");
393
        if (ZipFileFolder.isUrl(name)) {
394
            ZipFileFolder zFolder = new ZipFileFolder(name);
395
            InputStream is = zFolder.getInputStream(name);
396
            return load(new InputStreamReader(is));
397
        } else {
398
            return load(new FileReader(name));
399
        }
400

  
401
    }
402

  
403
    /**
404
     * Carga un fichero en formato DXF tomando un Reader como par�metro
405
     *
406
     * @param fr, Reader que se le pasa como par�metro
407
     * @return devuelve un objeto GeoFile, padre de DxfFile
408
     * @throws Exception
409
     * @throws Exception
410
     */
411
    public GeoFile load(Reader fr) throws Exception {
412
        logger.debug("Dxf: Cargando '" + name + "' ...");
413
        fi = new BufferedReader(fr);
414
        while ((grp = readGrp()) != null) {
415
            l += 2;
416

  
417
            if (grp.equals(0, "EOF")) {
418
                break;
419
            }
420
            if (grp.equals(0, "SECTION")) {
421
                readSection();
422
            }
423
        }
424
        fi.close();
425
        extent.add(entityMaker.getExtent());
426
        logger.debug("Dxf: '" + name + "' cargado. (" + l + " l�neas).");
427
        this.lineNr = l;
428
        return this;
429
    }
430

  
431
    /**
432
     * El fichero DXF se divide en grupos. Este m�todo permite leer cada grupo
433
     * individualmente
434
     *
435
     * @return devuelve la informaci�n del DXF en forma de objetos de la clase
436
     * DxfGroup
437
     * @throws NumberFormatException
438
     * @throws IOException
439
     */
440
    private DxfGroup readGrp() throws NumberFormatException, IOException {
441
        DxfGroup g = DxfGroup.read(fi);
442
        if (g != null) {
443
            l += 2;
444
        }
445
        /*if (g.code == 8)
446
         if (((String) g.data).length() < 1) {
447
         logger.error("a que un layer no puede ser ''?");
448
         System.exit(1);
449
         }*/
450
        return g;
451
    }
452

  
453
    /**
454
     * El fichero DXF se divide en varias secciones. Este m�todo se encarga de
455
     * leer cada una de ellas
456
     *
457
     * @throws NumberFormatException
458
     * @throws Exception
459
     */
460
    private void readSection() throws NumberFormatException, Exception {
461
        while (true) {
462
            grp = readGrp();
463
            logger.debug("-1:" + grp);
464
            if (grp.code == 2) {
465
                if (((String) grp.data).compareTo("HEADER") == 0) {
466
                    readHeader();
467
                } else if (((String) grp.data).compareTo("CLASSES") == 0) {
468
                    readAnySection();
469
                } else if (((String) grp.data).compareTo("TABLES") == 0) {
470
                    readTables();
471
                } else if (((String) grp.data).compareTo("BLOCKS") == 0) {
472
                    readBlocks();
473
                } else if (((String) grp.data).compareTo("ENTITIES") == 0) {
474
                    readEntities();
475
                } else if (((String) grp.data).compareTo("OBJECTS") == 0) {
476
                    readAnySection();
477
                } else {
478
                    logger.debug("DxfRead: Seccion " + grp.data);
479
                    readAnySection();
480
                }
481
            } else {
482
                logger.debug("Dxf: Codigo/Seccion desconocidos" + grp);
483
            }
484
            if (grp.equals(0, "EOF")) {
485
                break;
486
            }
487
            if (grp.equals(0, "ENDSEC")) {
488
                break;
489
            }
490
        }
491
    }
492

  
493
    /**
494
     * Habilita la lectura de la secci�n de TABLES
495
     *
496
     * @throws NumberFormatException
497
     * @throws Exception
498
     */
499
    private void readTables() throws NumberFormatException, Exception {
500
        logger.debug("Dxf: Seccion TABLAS, linea " + l + "grp =" + grp);
501
        int layerCnt = 0;
502
        String tableAct = "NONAME";
503

  
504
        Hashtable tables = new Hashtable();
505
        Vector table = new Vector();
506
        DxfGroupVector v = new DxfGroupVector();
507

  
508
        grp = readGrp();
509
        // logger.debug("0:"+grp);
510
        while (true) {
511
            if (grp.code == 0) {
512
                String data = (String) grp.getData();
513
                if (data.compareTo("ENDSEC") == 0 || data.compareTo("EOF") == 0) {
514
                    break;
515
                } else if (data.compareTo("ENDTAB") == 0) {
516
                    tables.put(tableAct, table);
517
                    table = new Vector();
518
                    grp = readGrp();
519
					// logger.debug("1:"+grp);
520

  
521
                    /**/                    if (tableAct.compareTo("LAYER") == 0 && v.size() > 0) {
522
                        entityMaker.createLayer(v);
523
                        logger.debug("Dxf: Layer " + v.getDataAsString(2));
524
                        layerCnt++;
525
                        v.clear();
526
                    }/**/
527

  
528
                    continue;
529
                } else {
530
                    if (table.size() == 1) {
531
                        tableAct = v.getDataAsString(2);
532
                        logger.debug("Dxf: Tabla " + tableAct);
533
                    } else if (tableAct.compareTo("LAYER") == 0 && v.size() > 0) {
534
                        entityMaker.createLayer(v);
535
                        logger.debug("Dxf: Layer " + v.getDataAsString(2));
536
                        layerCnt++;
537
                    }
538

  
539
                    v.clear();
540
                    v.add(grp);
541
                }
542
                while (true) {
543
                    grp = readGrp();
544
                    // logger.debug("2:"+grp);
545
                    if (grp.code == 0) {
546
                        break;
547
                    }
548
                    v.add(grp);
549
                }
550
                table.add(v);
551
            } else {
552
                logger.debug("Dxf: Error de secuencia");
553
                grp = readGrp();
554
                //logger.debug("3:"+grp);
555
            }
556
        }
557
        logger.debug("Dxf: Seccion TABLAS: " + layerCnt + " Capas. ");
558
    }
559

  
560
    /**
561
     * M�todo de lectura de secci�n por defecto. Se utiliza mientras se
562
     * realiza la implementaci�n correspondiente
563
     *
564
     * @throws NumberFormatException
565
     * @throws IOException
566
     */
567
    private void readAnySection() throws NumberFormatException, IOException {
568
        logger.debug("Dxf: Seccion '" + ((String) grp.getData()) + "', linea " + l);
569
        while (true) {
570
            grp = readGrp();
571
            if (grp.equals(0, "ENDSEC")) {
572
                break;
573
            } else if (grp.equals(0, "EOF")) {
574
                break;
575
            }
576
        }
577
    }
578

  
579
    /**
580
     * Primera aproximaci�n a la implementaci�n de la lectura del HEADER. En
581
     * principio interesa que se lea la versi�n del DXF. Para implementar esta
582
     * parte del lector se ha optado por incluir el m�todo setAcadVersion en
583
     * el interface EntityFactory. A lo mejor conviene implementar un nuevo
584
     * interface VarSettings.
585
     *
586
     * @throws NumberFormatException
587
     * @throws Exception
588
     */
589
    private void readHeader() throws NumberFormatException, Exception {
590
        logger.debug("Dxf: Seccion HEADER, linea " + l);
591
        int variableCnt = 0;
592
        int cntVeces = 0;
593
        DxfGroupVector v = new DxfGroupVector();
594
        grp = readGrp();
595
        while (true) {
596
            if (grp.equals(0, "EOF")) {
597
                break;
598
            } else if (grp.code == 9 || grp.code == 0) {
599
                if (v.size() > 0) {
600
                    String lastVariable = (String) ((DxfGroup) v.get(0)).data;
601
                    //logger.debug(lastVariable);
602
                    if (lastVariable.compareTo("$ACADVER") == 0) {
603
                        //logger.debug("Aqui llega.");
604
                        headerManager.setAcadVersion(v);
605
                    } else if (lastVariable.compareTo("$EXTMIN") == 0) {
606
                        if (v.hasCode(30)) {
607
                            headerManager.loadMinZFromHeader((Double)v.getData(30));
608
                        }
609
                    } else if (lastVariable.compareTo("$EXTMAX") == 0) {
610
                        if (v.hasCode(30)) {
611
                            headerManager.loadMaxZFromHeader((Double)v.getData(30));
612
                        }
613
                    } else if (lastVariable.compareTo("ENDSEC") == 0) {
614
                        //logger.debug("Llega al ENDSEC.");
615
                        break;
616
                    } /*else
617
                     logger.debug("Dxf: Variable "+lastVariable+" desconocida.");*/
618

  
619
                }
620
                v.clear();
621
                v.add(grp);
622
                while (true) {
623
                    grp = readGrp();
624
                    if (grp.code == 9 || grp.code == 0) {
625
                        break;
626
                    }
627
                    v.add(grp);
628
                }
629
                variableCnt++;
630
            }
631
            cntVeces++;
632
        }
633
        logger.debug("Dxf: Seccion HEADER, " + variableCnt + " variables, " + cntVeces + " veces.");
634
        //logger.debug("Seccion HEADER, linea "+ l+ " (SALGO)");
635
        logger.debug("readHeader: ACAD Version: " + headerManager.getDxfHeaderVars().getAcadVersion());
636
    }
637

  
638
    /**
639
     * Permite leer la secci�n ENTITIES del DXF, donde se encuentran las
640
     * entidades geom�tricas del DXF que no aparecen dentro de ning�n bloque
641
     *
642
     * @throws NumberFormatException
643
     * @throws Exception
644
     */
645
    private void readEntities() throws NumberFormatException, Exception {
646
        logger.debug("Dxf: Seccion ENTITIES, linea " + l);
647
        int entityCnt = 0;
648
        int cntVeces = 0;
649
        DxfGroupVector v = new DxfGroupVector();
650
        grp = readGrp();
651
        while (true) {
652
            if (grp.equals(0, "EOF")) {
653
                break;
654
            } else if (grp.code == 0) {
655
                if (v.size() > 0) {
656
                    String lastEntity = (String) ((DxfGroup) v.get(0)).data;
657
                    if (lastEntity.compareTo("POLYLINE") == 0) {
658
                        entityMaker.createPolyline(v);
659
                    } else if (lastEntity.compareTo("VERTEX") == 0) {
660
                        entityMaker.addVertex(v);
661
                    } else if (lastEntity.compareTo("SEQEND") == 0) {
662
                        entityMaker.endSeq();
663
                    } else if (lastEntity.compareTo("LWPOLYLINE") == 0) {
664
                        entityMaker.createLwPolyline(v);
665
                    } else if (lastEntity.compareTo("LINE") == 0) {
666
                        entityMaker.createLine(v);
667
                    } else if (lastEntity.compareTo("TEXT") == 0) {
668
                        entityMaker.createText(v);
669
                    } else if (lastEntity.compareTo("MTEXT") == 0) {
670
                        entityMaker.createMText(v);
671
                    } else if (lastEntity.compareTo("POINT") == 0) {
672
                        entityMaker.createPoint(v);
673
                    } else if (lastEntity.compareTo("CIRCLE") == 0) {
674
                        entityMaker.createCircle(v);
675
                    } else if (lastEntity.compareTo("ELLIPSE") == 0) {
676
                        entityMaker.createEllipse(v);
677
                    } else if (lastEntity.compareTo("ARC") == 0) {
678
                        entityMaker.createArc(v);
679
                    } else if (lastEntity.compareTo("INSERT") == 0) {
680
                        entityMaker.createInsert(v);
681
                    } else if (lastEntity.compareTo("SOLID") == 0) {
682
                        entityMaker.createSolid(v);
683
                    } else if (lastEntity.compareTo("SPLINE") == 0) {
684
                        entityMaker.createSpline(v);
685
                    } else if (lastEntity.compareTo("ATTRIB") == 0) {
686
                        entityMaker.createAttrib(v);
687
                    } else if (lastEntity.compareTo("ENDSEC") == 0) {
688
                        break;
689
                    } else {
690
                        logger.debug("Dxf: Entidad " + lastEntity + " desconocida.");
691
                    }
692
                }
693
                v.clear();
694
                v.add(grp);
695
                while (true) {
696
                    grp = readGrp();
697
                    if (grp.code == 0) {
698
                        break;
699
                    }
700
                    v.add(grp);
701
                }
702
                entityCnt++;
703
            }
704
            cntVeces++;
705
        }
706
        logger.debug("Dxf: Seccion ENTITIES, " + entityCnt + " entidades, " + cntVeces + " veces.");
707
        //logger.debug("Seccion ENTITIES, linea "+ l+ " (SALGO)");
708
    }
709

  
710
    /**
711
     * Permite la secci�n BLOCKS del DXF, donde se encuentran las definiciones
712
     * de los bloques que componen el DXF
713
     *
714
     * @throws NumberFormatException
715
     * @throws Exception
716
     */
717
    private void readBlocks() throws NumberFormatException, Exception {
718
        logger.debug("Dxf: Seccion BLOCKS, linea " + l);
719
        int blkCnt = 0;
720
        int cntVeces = 0;
721
        DxfGroupVector v = new DxfGroupVector();
722
        grp = readGrp();
723
        while (true) {
724
            if (grp.equals(0, "EOF")) {
725
                break;
726
            } else if (grp.code == 0) {
727
                if (v.size() > 0) {
728
                    String lastEntity = (String) ((DxfGroup) v.get(0)).data;
729
                    if (lastEntity.compareTo("BLOCK") == 0) {
730
                        //logger.debug("readBlocks(): Empezamos a leer un bloque");
731
                        entityMaker.createBlock(v);
732
                    } else if (lastEntity.compareTo("POLYLINE") == 0) {
733
                        //logger.debug("readBlocks(): A�adimos una polilinea al bloque");
734
                        entityMaker.createPolyline(v);
735
                    } else if (lastEntity.compareTo("VERTEX") == 0) {
736
                        //logger.debug("readBlocks(): A�adimos un vertice a la polilinea");
737
                        entityMaker.addVertex(v);
738
                    } else if (lastEntity.compareTo("SEQEND") == 0) {
739
                        //logger.debug("readBlocks(): Cerramos una polilinea");
740
                        entityMaker.endSeq();
741
                    } else if (lastEntity.compareTo("LWPOLYLINE") == 0) {
742
                        //logger.debug("readBlocks(): A�adimos una lwpolilinea al bloque");
743
                        entityMaker.createLwPolyline(v);
744
                    } else if (lastEntity.compareTo("LINE") == 0) {
745
                        //logger.debug("readBlocks(): A�adimos una linea al bloque");
746
                        entityMaker.createLine(v);
747
                    } else if (lastEntity.compareTo("TEXT") == 0) {
748
                        //logger.debug("readBlocks(): A�adimos un texto al bloque");
749
                        entityMaker.createText(v);
750
                    } else if (lastEntity.compareTo("MTEXT") == 0) {
751
                        //logger.debug("readBlocks(): A�adimos un m-texto al bloque");
752
                        entityMaker.createMText(v);
753
                    } else if (lastEntity.compareTo("POINT") == 0) {
754
                        //logger.debug("readBlocks(): A�adimos un punto al bloque");
755
                        entityMaker.createPoint(v);
756
                    } else if (lastEntity.compareTo("CIRCLE") == 0) {
757
                        //logger.debug("readBlocks(): A�adimos un circulo al bloque");
758
                        entityMaker.createCircle(v);
759
                    } else if (lastEntity.compareTo("ARC") == 0) {
760
                        //logger.debug("readBlocks(): A�adimos un arco al bloque");
761
                        entityMaker.createArc(v);
762
                    } else if (lastEntity.compareTo("INSERT") == 0) {
763
                        //logger.debug("readBlocks(): A�adimos un insert al bloque");
764
                        entityMaker.createInsert(v);
765
                    } else if (lastEntity.compareTo("SOLID") == 0) {
766
                        //logger.debug("readBlocks(): A�adimos un solido al bloque");
767
                        entityMaker.createSolid(v);
768
                    } else if (lastEntity.compareTo("SPLINE") == 0) {
769
                        entityMaker.createSpline(v);
770
                    } else if (lastEntity.compareTo("ATTDEF") == 0) {
771
                        entityMaker.createAttdef(v);
772
                    } else if (lastEntity.compareTo("ENDBLK") == 0) {
773
                        //logger.debug("readBlocks(): Cerramos un bloque"+v);
774
                        entityMaker.endBlk(v);
775
                    } else if (lastEntity.compareTo("ENDSEC") == 0) {
776
                        break;
777
                    } else {
778
                        logger.debug("Dxf: Entidad de bloque " + lastEntity + " desconocida.");
779
                    }
780
                }
781
                v.clear();
782
                v.add(grp);
783
                while (true) {
784
                    grp = readGrp();
785
                    if (grp.code == 0) {
786
                        break;
787
                    }
788
                    v.add(grp);
789
                }
790
                blkCnt++;
791
            }
792
            cntVeces++;
793
        }
794

  
795
        entityMaker.testBlocks();
796
		// Cuando termina de leer la secci�n de bloques se asegura de que todos los campos
797
        // son distintos.
798
        //logger.debug("readBlocks(): entityMaker.getAttributes().size() = " + entityMaker.getAttributes().size());
799
        entityMaker.depureAttributes();
800
        //logger.debug("readBlocks(): entityMaker.getAttributes().size() = " + entityMaker.getAttributes().size());
801
        logger.debug("Dxf: Seccion BLOCKS, " + blkCnt + " elementos de bloque. " + cntVeces + " veces.");
802
    }
803

  
804
    /**
805
     * Devuelve los objetos geom�tricos obtenidos de un DXF
806
     */
807
    public IObjList getObjects() {
808
        return this.entityMaker.getObjects();
809
    }
810

  
811
    /**
812
     * jmorell: M�todo que permite salvar capas al formato DXF2000. Este
813
     * m�todo ha sido actualizado en el proceso de implementaci�n del piloto
814
     * de CAD. En este piloto deb�a existir soporte para elipses, y este es
815
     * uno de los motivos que nos llevan a implementar ahora para DXF2000,
816
     * puesto que el DXF R12 no soporta elipses.
817
     *
818
     * @param fName
819
     * @throws IOException
820
     */
821
    public void save(String fName) throws IOException {
822
        logger.debug("save: fName = " + fName);
823
        long t2, t1;
824
        t1 = getTime();
825
        fName = DataSource.normalize(fName);
826
        FileWriter fw = new FileWriter(fName);
827
        // COMMENTAIRES DU TRADUCTEUR
828
//		fw.write(DxfGroup.toString(999, Integer.toString(features.size()) + " features"));
829
        fw.write(DxfGroup.toString(999, "TRANSLATION BY geo.cresques.io.DxfFile"));
830
        fw.write(DxfGroup.toString(999, "DATE : " + (new Date()).toString()));
831
        writeHeader(fw);
832
        writeTables(fw);
833
        writeBlocks(fw);
834
        writeEntities(fw);
835
        writeObjects(fw);
836
        fw.write(DxfGroup.toString(0, "EOF"));
837
        fw.flush();
838
        fw.close();
839
        t2 = getTime();
840
        logger.debug("DxfFile.save(): Tiempo salvando: " + (t2 - t1) / 1000 + " seg.");
841
    }
842

  
843
    /**
844
     * Escritor de la cabecera de un DXF. jmorell: Actualizaci�n del escritor
845
     * de DXF de R12 a 2000.
846
     *
847
     * @param fw, un FileWriter para escribir ficheros
848
     * @throws IOException
849
     */
850
    public void writeHeader(FileWriter fw) throws IOException {
851
        fw.write(DxfGroup.toString(0, "SECTION"));
852
        fw.write(DxfGroup.toString(2, "HEADER"));
853
        fw.write(DxfGroup.toString(9, "$ACADVER"));
854
        //fw.write(DxfGroup.toString(1, "AC1009"));			// DXF R12
855
        fw.write(DxfGroup.toString(1, "AC1015"));			// DXF 2000
856
        fw.write(DxfGroup.toString(9, "$INSBASE"));
857
        fw.write(DxfGroup.toString(10, 0.0, 1));
858
        fw.write(DxfGroup.toString(20, 0.0, 1));
859
        fw.write(DxfGroup.toString(30, 0.0, 1));
860
        fw.write(DxfGroup.toString(9, "$EXTMIN"));
861
        fw.write(DxfGroup.toString(10, extent.minX(), 6));
862
        fw.write(DxfGroup.toString(20, extent.minY(), 6));
863
        if (dxf3DFlag) {
864
            fw.write(DxfGroup.toString(30, extent.minX(), 6));
865
        } else {
866
            fw.write(DxfGroup.toString(30, 0.0, 6));
867
        }
868
        fw.write(DxfGroup.toString(9, "$EXTMAX"));
869
        fw.write(DxfGroup.toString(10, extent.maxX(), 6));
870
        fw.write(DxfGroup.toString(20, extent.maxY(), 6));
871
        if (dxf3DFlag) {
872
            fw.write(DxfGroup.toString(30, extent.maxX(), 6));
873
        } else {
874
            fw.write(DxfGroup.toString(30, 0.0, 6));
875
        }
876
        fw.write(DxfGroup.toString(9, "$LIMMIN"));
877
        fw.write(DxfGroup.toString(10, extent.minX(), 6));
878
        fw.write(DxfGroup.toString(20, extent.minY(), 6));
879
        fw.write(DxfGroup.toString(9, "$LIMMAX"));
880
        fw.write(DxfGroup.toString(10, extent.maxX(), 6));
881
        fw.write(DxfGroup.toString(20, extent.maxY(), 6));
882
        fw.write(DxfGroup.toString(9, "$ORTHOMODE") + DxfGroup.toString(70, 0));
883
        fw.write(DxfGroup.toString(9, "$REGENMODE") + DxfGroup.toString(70, 1));
884
        fw.write(DxfGroup.toString(9, "$FILLMODE") + DxfGroup.toString(70, 1));
885
        fw.write(DxfGroup.toString(9, "$QTEXTMODE") + DxfGroup.toString(70, 0));
886
        fw.write(DxfGroup.toString(9, "$MIRRTEXT") + DxfGroup.toString(70, 1));
887
        fw.write(DxfGroup.toString(9, "$DRAGMODE") + DxfGroup.toString(70, 2));
888
        fw.write(DxfGroup.toString(9, "$LTSCALE") + DxfGroup.toString(40, 1.0, 1));
889
        fw.write(DxfGroup.toString(9, "$OSMODE") + DxfGroup.toString(70, 0));
890
        fw.write(DxfGroup.toString(9, "$ATTMODE") + DxfGroup.toString(70, 1));
891
        fw.write(DxfGroup.toString(9, "$TEXTSIZE") + DxfGroup.toString(40, 0.2, 1));
892
        fw.write(DxfGroup.toString(9, "$TRACEWID") + DxfGroup.toString(40, 0.05, 2));
893
        fw.write(DxfGroup.toString(9, "$TEXTSTYLE") + DxfGroup.toString(7, "STANDARD"));
894
        fw.write(DxfGroup.toString(9, "$CLAYER") + DxfGroup.toString(8, "0"));
895
        fw.write(DxfGroup.toString(9, "$CELTYPE") + DxfGroup.toString(6, "CONTINUOUS"));
896
        fw.write(DxfGroup.toString(9, "$CECOLOR") + DxfGroup.toString(62, 256));
897
        fw.write(DxfGroup.toString(9, "$DIMSCALE") + DxfGroup.toString(40, 1.0, 1));
898
        fw.write(DxfGroup.toString(9, "$DIMASZ") + DxfGroup.toString(40, 0.18, 2));
899
        fw.write(DxfGroup.toString(9, "$DIMEXO") + DxfGroup.toString(40, 0.0625, 4));
900
        fw.write(DxfGroup.toString(9, "$DIMDLI") + DxfGroup.toString(40, 0.38, 2));
901
        fw.write(DxfGroup.toString(9, "$DIMRND") + DxfGroup.toString(40, 0.0, 1));
902
        fw.write(DxfGroup.toString(9, "$DIMDLE") + DxfGroup.toString(40, 0.0, 1));
903
        fw.write(DxfGroup.toString(9, "$DIMEXE") + DxfGroup.toString(40, 0.18, 2));
904
        fw.write(DxfGroup.toString(9, "$DIMTP") + DxfGroup.toString(40, 0.0, 1));
905
        fw.write(DxfGroup.toString(9, "$DIMTM") + DxfGroup.toString(40, 0.0, 1));
906
        fw.write(DxfGroup.toString(9, "$DIMTXT") + DxfGroup.toString(40, 0.18, 2));
907
        fw.write(DxfGroup.toString(9, "$DIMCEN") + DxfGroup.toString(40, 0.09, 2));
908
        fw.write(DxfGroup.toString(9, "$DIMTSZ") + DxfGroup.toString(40, 0.0, 1));
909
        fw.write(DxfGroup.toString(9, "$DIMTOL") + DxfGroup.toString(70, 0));
910
        fw.write(DxfGroup.toString(9, "$DIMLIM") + DxfGroup.toString(70, 0));
911
        fw.write(DxfGroup.toString(9, "$DIMTIH") + DxfGroup.toString(70, 1));
912
        fw.write(DxfGroup.toString(9, "$DIMTOH") + DxfGroup.toString(70, 1));
913
        fw.write(DxfGroup.toString(9, "$DIMSE1") + DxfGroup.toString(70, 0));
914
        fw.write(DxfGroup.toString(9, "$DIMSE2") + DxfGroup.toString(70, 0));
915
        fw.write(DxfGroup.toString(9, "$DIMTAD") + DxfGroup.toString(70, 0));
916
        fw.write(DxfGroup.toString(9, "$DIMZIN") + DxfGroup.toString(70, 0));
917
        fw.write(DxfGroup.toString(9, "$DIMBLK") + DxfGroup.toString(1, ""));
918
        fw.write(DxfGroup.toString(9, "$DIMASO") + DxfGroup.toString(70, 1));
919
        fw.write(DxfGroup.toString(9, "$DIMSHO") + DxfGroup.toString(70, 1));
920
        fw.write(DxfGroup.toString(9, "$DIMPOST") + DxfGroup.toString(1, ""));
921
        fw.write(DxfGroup.toString(9, "$DIMAPOST") + DxfGroup.toString(1, ""));
922
        fw.write(DxfGroup.toString(9, "$DIMALT") + DxfGroup.toString(70, 0));
923
        fw.write(DxfGroup.toString(9, "$DIMALTD") + DxfGroup.toString(70, 2));
924
        fw.write(DxfGroup.toString(9, "$DIMALTF") + DxfGroup.toString(40, 25.4, 1));
925
        fw.write(DxfGroup.toString(9, "$DIMLFAC") + DxfGroup.toString(40, 1.0, 1));
926
        fw.write(DxfGroup.toString(9, "$DIMTOFL") + DxfGroup.toString(70, 0));
927
        fw.write(DxfGroup.toString(9, "$DIMTVP") + DxfGroup.toString(40, 0.0, 1));
928
        fw.write(DxfGroup.toString(9, "$DIMTIX") + DxfGroup.toString(70, 0));
929
        fw.write(DxfGroup.toString(9, "$DIMSOXD") + DxfGroup.toString(70, 0));
930
        fw.write(DxfGroup.toString(9, "$DIMSAH") + DxfGroup.toString(70, 0));
931
        fw.write(DxfGroup.toString(9, "$DIMBLK1") + DxfGroup.toString(1, ""));
932
        fw.write(DxfGroup.toString(9, "$DIMBLK2") + DxfGroup.toString(1, ""));
933
        fw.write(DxfGroup.toString(9, "$DIMSTYLE") + DxfGroup.toString(2, "STANDARD"));
934
        fw.write(DxfGroup.toString(9, "$DIMCLRD") + DxfGroup.toString(70, 0));
935
        fw.write(DxfGroup.toString(9, "$DIMCLRE") + DxfGroup.toString(70, 0));
936
        fw.write(DxfGroup.toString(9, "$DIMCLRT") + DxfGroup.toString(70, 0));
937
        fw.write(DxfGroup.toString(9, "$DIMTFAC") + DxfGroup.toString(40, 1.0, 1));
938
        fw.write(DxfGroup.toString(9, "$DIMGAP") + DxfGroup.toString(40, 0.09, 2));
939
        fw.write(DxfGroup.toString(9, "$LUNITS") + DxfGroup.toString(70, 2));
940
        fw.write(DxfGroup.toString(9, "$LUPREC") + DxfGroup.toString(70, 4));
941
        fw.write(DxfGroup.toString(9, "$AXISMODE") + DxfGroup.toString(70, 0));
942
        fw.write(DxfGroup.toString(9, "$AXISUNIT"));
943
        fw.write(DxfGroup.toString(10, 0.0, 1));
944
        fw.write(DxfGroup.toString(20, 0.0, 1));
945
        fw.write(DxfGroup.toString(9, "$SKETCHINC") + DxfGroup.toString(40, 0.1, 1));
946
        fw.write(DxfGroup.toString(9, "$FILLETRAD") + DxfGroup.toString(40, 0.0, 1));
947
        fw.write(DxfGroup.toString(9, "$AUNITS") + DxfGroup.toString(70, 0));
948
        fw.write(DxfGroup.toString(9, "$AUPREC") + DxfGroup.toString(70, 0));
949
        fw.write(DxfGroup.toString(9, "$MENU") + DxfGroup.toString(1, "acad"));
950
        fw.write(DxfGroup.toString(9, "$ELEVATION") + DxfGroup.toString(40, 0.0, 1));
951
        fw.write(DxfGroup.toString(9, "$PELEVATION") + DxfGroup.toString(40, 0.0, 1));
952
        fw.write(DxfGroup.toString(9, "$THICKNESS") + DxfGroup.toString(40, 0.0, 1));
953
        fw.write(DxfGroup.toString(9, "$LIMCHECK") + DxfGroup.toString(70, 0));
954
        fw.write(DxfGroup.toString(9, "$BLIPMODE") + DxfGroup.toString(70, 1));
955
        fw.write(DxfGroup.toString(9, "$CHAMFERA") + DxfGroup.toString(40, 0.0, 1));
956
        fw.write(DxfGroup.toString(9, "$CHAMFERB") + DxfGroup.toString(40, 0.0, 1));
957
        fw.write(DxfGroup.toString(9, "$SKPOLY") + DxfGroup.toString(70, 0));
958
        fw.write(DxfGroup.toString(9, "$TDCREATE") + DxfGroup.toString(40, 2453116.436828704, 9));
959
        fw.write(DxfGroup.toString(9, "$TDUPDATE") + DxfGroup.toString(40, 2453116.436828704, 9));
960
        fw.write(DxfGroup.toString(9, "$TDINDWG") + DxfGroup.toString(40, 0.0000000000, 10));
961
        fw.write(DxfGroup.toString(9, "$TDUSRTIMER") + DxfGroup.toString(40, 0.0000000000, 10));
962
        fw.write(DxfGroup.toString(9, "$USRTIMER") + DxfGroup.toString(70, 1));
963
        fw.write(DxfGroup.toString(9, "$ANGBASE") + DxfGroup.toString(50, 0.0, 1));
964
        fw.write(DxfGroup.toString(9, "$ANGDIR") + DxfGroup.toString(70, 0));
965
        fw.write(DxfGroup.toString(9, "$PDMODE") + DxfGroup.toString(70, 0));
966
        fw.write(DxfGroup.toString(9, "$PDSIZE") + DxfGroup.toString(40, 0.0, 1));
967
        fw.write(DxfGroup.toString(9, "$PLINEWID") + DxfGroup.toString(40, 0.0, 1));
968
        fw.write(DxfGroup.toString(9, "$COORDS") + DxfGroup.toString(70, 0));
969
        fw.write(DxfGroup.toString(9, "$SPLFRAME") + DxfGroup.toString(70, 0));
970
        fw.write(DxfGroup.toString(9, "$SPLINETYPE") + DxfGroup.toString(70, 6));
971
        fw.write(DxfGroup.toString(9, "$SPLINESEGS") + DxfGroup.toString(70, 10));
972
        fw.write(DxfGroup.toString(9, "$ATTDIA") + DxfGroup.toString(70, 0));
973
        fw.write(DxfGroup.toString(9, "$ATTREQ") + DxfGroup.toString(70, 1));
974
        fw.write(DxfGroup.toString(9, "$HANDLING") + DxfGroup.toString(70, 1));
975
        fw.write(DxfGroup.toString(9, "$HANDSEED") + DxfGroup.toString(5, "394B"));
976
        fw.write(DxfGroup.toString(9, "$SURFTAB1") + DxfGroup.toString(70, 6));
977
        fw.write(DxfGroup.toString(9, "$SURFTAB2") + DxfGroup.toString(70, 6));
978
        fw.write(DxfGroup.toString(9, "$SURFTYPE") + DxfGroup.toString(70, 6));
979
        fw.write(DxfGroup.toString(9, "$SURFU") + DxfGroup.toString(70, 6));
980
        fw.write(DxfGroup.toString(9, "$SURFV") + DxfGroup.toString(70, 6));
981
        fw.write(DxfGroup.toString(9, "$UCSNAME") + DxfGroup.toString(2, ""));
982
        fw.write(DxfGroup.toString(9, "$UCSORG"));
983
        fw.write(DxfGroup.toString(10, 0.0, 1));
984
        fw.write(DxfGroup.toString(20, 0.0, 1));
985
        fw.write(DxfGroup.toString(30, 0.0, 1));
986
        fw.write(DxfGroup.toString(9, "$UCSXDIR"));
987
        fw.write(DxfGroup.toString(10, 1.0, 1));
988
        fw.write(DxfGroup.toString(20, 0.0, 1));
989
        fw.write(DxfGroup.toString(30, 0.0, 1));
990
        fw.write(DxfGroup.toString(9, "$UCSYDIR"));
991
        fw.write(DxfGroup.toString(10, 0.0, 1));
992
        fw.write(DxfGroup.toString(20, 1.0, 1));
993
        fw.write(DxfGroup.toString(30, 0.0, 1));
994
        fw.write(DxfGroup.toString(9, "$PUCSNAME") + DxfGroup.toString(2, ""));
995
        fw.write(DxfGroup.toString(9, "$PUCSORG"));
996
        fw.write(DxfGroup.toString(10, 0.0, 1));
997
        fw.write(DxfGroup.toString(20, 0.0, 1));
998
        fw.write(DxfGroup.toString(30, 0.0, 1));
999
        fw.write(DxfGroup.toString(9, "$PUCSXDIR"));
1000
        fw.write(DxfGroup.toString(10, 1.0, 1));
1001
        fw.write(DxfGroup.toString(20, 0.0, 1));
1002
        fw.write(DxfGroup.toString(30, 0.0, 1));
1003
        fw.write(DxfGroup.toString(9, "$PUCSYDIR"));
1004
        fw.write(DxfGroup.toString(10, 0.0, 1));
1005
        fw.write(DxfGroup.toString(20, 1.0, 1));
1006
        fw.write(DxfGroup.toString(30, 0.0, 1));
1007
        fw.write(DxfGroup.toString(9, "$USERI1") + DxfGroup.toString(70, 0));
1008
        fw.write(DxfGroup.toString(9, "$USERI2") + DxfGroup.toString(70, 0));
1009
        fw.write(DxfGroup.toString(9, "$USERI3") + DxfGroup.toString(70, 0));
1010
        fw.write(DxfGroup.toString(9, "$USERI4") + DxfGroup.toString(70, 0));
1011
        fw.write(DxfGroup.toString(9, "$USERI5") + DxfGroup.toString(70, 0));
1012
        fw.write(DxfGroup.toString(9, "$USERR1") + DxfGroup.toString(40, 0.0, 1));
1013
        fw.write(DxfGroup.toString(9, "$USERR2") + DxfGroup.toString(40, 0.0, 1));
1014
        fw.write(DxfGroup.toString(9, "$USERR3") + DxfGroup.toString(40, 0.0, 1));
1015
        fw.write(DxfGroup.toString(9, "$USERR4") + DxfGroup.toString(40, 0.0, 1));
1016
        fw.write(DxfGroup.toString(9, "$USERR5") + DxfGroup.toString(40, 0.0, 1));
1017
        fw.write(DxfGroup.toString(9, "$WORLDVIEW") + DxfGroup.toString(70, 1));
1018
        fw.write(DxfGroup.toString(9, "$SHADEDGE") + DxfGroup.toString(70, 3));
1019
        fw.write(DxfGroup.toString(9, "$SHADEDIF") + DxfGroup.toString(70, 70));
1020
        fw.write(DxfGroup.toString(9, "$TILEMODE") + DxfGroup.toString(70, 1));
1021
        fw.write(DxfGroup.toString(9, "$MAXACTVP") + DxfGroup.toString(70, 16));
1022
        fw.write(DxfGroup.toString(9, "$PINSBASE"));
1023
        fw.write(DxfGroup.toString(10, 0.0, 1));
1024
        fw.write(DxfGroup.toString(20, 0.0, 1));
1025
        fw.write(DxfGroup.toString(30, 0.0, 1));
1026
        fw.write(DxfGroup.toString(9, "$PLIMCHECK") + DxfGroup.toString(70, 0));
1027
        fw.write(DxfGroup.toString(9, "$PEXTMIN"));
1028
        fw.write(DxfGroup.toString(10, "-1.000000E+20"));
1029
        fw.write(DxfGroup.toString(20, "-1.000000E+20"));
... This diff was truncated because it exceeds the maximum size that can be displayed.

Also available in: Unified diff