Statistics
| Revision:

svn-gvsig-desktop / tags / v1_1_Build_1005 / libraries / libFMap / src / com / iver / cit / gvsig / fmap / layers / FLayers.java @ 12355

History | View | Annotate | Download (49.5 KB)

1
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
2
 *
3
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
4
 *
5
 * This program is free software; you can redistribute it and/or
6
 * modify it under the terms of the GNU General Public License
7
 * as published by the Free Software Foundation; either version 2
8
 * of the License, or (at your option) any later version.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with this program; if not, write to the Free Software
17
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
18
 *
19
 * For more information, contact:
20
 *
21
 *  Generalitat Valenciana
22
 *   Conselleria d'Infraestructures i Transport
23
 *   Av. Blasco Ib??ez, 50
24
 *   46010 VALENCIA
25
 *   SPAIN
26
 *
27
 *      +34 963862235
28
 *   gvsig@gva.es
29
 *      www.gvsig.gva.es
30
 *
31
 *    or
32
 *
33
 *   IVER T.I. S.A
34
 *   Salamanca 50
35
 *   46005 Valencia
36
 *   Spain
37
 *
38
 *   +34 963163400
39
 *   dac@iver.es
40
 */
41
package com.iver.cit.gvsig.fmap.layers;
42

    
43
import java.awt.Graphics2D;
44
import java.awt.Point;
45
import java.awt.geom.Rectangle2D;
46
import java.awt.image.BufferedImage;
47
import java.awt.image.WritableRaster;
48
import java.io.File;
49
import java.lang.reflect.Array;
50
import java.util.ArrayList;
51
import java.util.Collection;
52
import java.util.Collections;
53
import java.util.Iterator;
54
import java.util.List;
55
import java.util.Vector;
56

    
57
import javax.print.attribute.PrintRequestAttributeSet;
58
import javax.swing.ImageIcon;
59

    
60
import org.apache.log4j.Logger;
61
import org.cresques.cts.ICoordTrans;
62
import org.cresques.cts.IProjection;
63

    
64
import com.hardcode.driverManager.Driver;
65
import com.hardcode.driverManager.DriverLoadException;
66
import com.iver.cit.gvsig.fmap.DriverException;
67
import com.iver.cit.gvsig.fmap.MapContext;
68
import com.iver.cit.gvsig.fmap.MapControl;
69
import com.iver.cit.gvsig.fmap.ViewPort;
70
import com.iver.cit.gvsig.fmap.crs.CRSFactory;
71
import com.iver.cit.gvsig.fmap.drivers.DefaultJDBCDriver;
72
import com.iver.cit.gvsig.fmap.drivers.DriverIOException;
73
import com.iver.cit.gvsig.fmap.drivers.IVectorialDatabaseDriver;
74
import com.iver.cit.gvsig.fmap.drivers.VectorialDriver;
75
import com.iver.cit.gvsig.fmap.drivers.VectorialFileDriver;
76
import com.iver.cit.gvsig.fmap.layers.layerOperations.ComposedLayer;
77
import com.iver.cit.gvsig.fmap.layers.layerOperations.InfoByPoint;
78
import com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection;
79
import com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData;
80
import com.iver.cit.gvsig.fmap.layers.layerOperations.XMLItem;
81
import com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor;
82
import com.iver.cit.gvsig.fmap.operations.strategies.VisitException;
83
import com.iver.cit.gvsig.fmap.rendering.VectorialLegend;
84
import com.iver.utiles.IPersistance;
85
import com.iver.utiles.XMLEntity;
86
import com.iver.utiles.extensionPoints.ExtensionPoint;
87
import com.iver.utiles.extensionPoints.ExtensionPointsSingleton;
88
import com.iver.utiles.swing.threads.Cancellable;
89

    
90
/**
91
 * Representa un nodo interno en el ?rbol de capas
92
 */
93
public class FLayers extends FLyrDefault implements VectorialData, LayerCollection, InfoByPoint
94
{
95
        //ArrayList de Listener registrados.
96
        protected ArrayList layerCollectionListeners = new ArrayList();
97

    
98

    
99
        protected List layers = Collections.synchronizedList(new ArrayList());
100
        protected MapContext fmap;
101
        protected static Logger logger = Logger.getLogger(FLayers.class.getName());
102
        /**
103
         * Crea un nuevo FLayers.
104
         *
105
         * @param fmap
106
         * @param parent
107
         */
108
        public FLayers(MapContext fmap, FLayers parent) {
109
                setParentLayer(parent);
110
                this.fmap = fmap;
111
        }
112

    
113
        /**
114
         * A?ade un listener de los eventos de la colecci?n de capas
115
         *
116
         * @param listener
117
         */
118
        public void addLayerCollectionListener(LayerCollectionListener listener) {
119
                if (!layerCollectionListeners.contains(listener))
120
                        layerCollectionListeners.add(listener);
121
        }
122

    
123

    
124
        /**
125
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllVisibles(boolean)
126
         */
127
        public void setAllVisibles(boolean visible) {
128
                FLayer lyr;
129

    
130
                for (int i = 0; i < layers.size(); i++) {
131
                        lyr = ((FLayer) layers.get(i));
132
                        lyr.setVisible(visible);
133

    
134
                        if (lyr instanceof LayerCollection) {
135
                                ((LayerCollection) lyr).setAllVisibles(visible);
136
                        }
137
                }
138
        }
139

    
140
        /**
141
         * Elimina un listener de los eventos de la colecci?n de capas
142
         *
143
         * @param listener
144
         */
145
        public void removeLayerCollectionListener(LayerCollectionListener listener) {
146
                layerCollectionListeners.remove(listener);
147
        }
148

    
149
        /**
150
         * A?ade una capa.
151
         *
152
         * @param layer
153
         */
154
//        private void doAddLayer(FLayer layer) {
155
//                layers.add(layer);
156
//                layer.setParentLayer(this);
157
//        }
158
        private void doAddLayer(int pos,FLayer layer) {
159
                layers.add(pos,layer);
160
                layer.setParentLayer(this);
161
        }
162
        public void addLayer(FLayer layer) {
163
                addLayer(layers.size(),layer);
164
        }
165
        /**
166
         * A?ade una capa en la posici?n pos de la lista de subcapas
167
         *
168
         * @param layer
169
         *
170
         * @throws CancelationException
171
         */
172
        public void addLayer(int pos,FLayer layer) throws CancelationException {
173
                //Notificamos a la capa que va a ser a?adida
174
                //FLyrDefault layerDef = (FLyrDefault)layer;
175
                //if (!layerDef.isUnavailable()) {
176
                        if (layer instanceof FLyrDefault)
177
                                ((FLyrDefault)layer).wakeUp();
178

    
179
                        if (layer instanceof FLayers){
180
                                FLayers layers=(FLayers)layer;
181
                                fmap.addAsCollectionListener(layers);
182
                        }
183
                        callLayerAdding(LayerCollectionEvent.createLayerAddingEvent(layer));
184
                //}
185

    
186
                doAddLayer(pos,layer);
187

    
188
                //if (!layerDef.isUnavailable()) {
189
                        callLayerAdded(LayerCollectionEvent.createLayerAddedEvent(layer));
190
                //}
191
        }
192

    
193
        /**
194
         * Mueve una capa de la posici?n from a la posici?n to. (Se supone que
195
         * est?n dentro del mismo nivel). Para mover entre niveles, usar otro
196
         * m?todo (por hacer)
197
         *
198
         * @param from origen.
199
         * @param to destino.
200
         *
201
         * @throws CancelationException
202
         */
203
        public void moveTo(int from, int to) throws CancelationException {
204
                int newfrom=layers.size()-from-1;
205
                int newto=layers.size()-to-1;
206
                if ( newfrom < 0 || newfrom >=layers.size() || newto < 0 || newto >= layers.size()) return;
207
                FLayer aux = (FLayer) layers.get(newfrom);
208
                callLayerMoving(LayerPositionEvent.createLayerMovingEvent(aux, newfrom, newto));
209
                layers.remove(newfrom);
210
                layers.add(newto, aux);
211
                callLayerMoved(LayerPositionEvent.createLayerMovedEvent(aux, newfrom, newto));
212
        }
213

    
214
        /**
215
         * Borra una capa del ArrayList que contiene a las capas.
216
         *
217
         * @param lyr FLayer.
218
         */
219
        private void doRemoveLayer(FLayer lyr) {
220
                        layers.remove(lyr);
221
        }
222

    
223
        /**
224
         * Borra una capa de la colecci?n de capas.
225
         *
226
         * @param lyr FLayer
227
         *
228
         * @throws CancelationException
229
         */
230
        public void removeLayer(FLayer lyr) throws CancelationException {
231
                callLayerRemoving(LayerCollectionEvent.createLayerRemovingEvent(lyr));
232
                doRemoveLayer(lyr);
233
                callLayerRemoved(LayerCollectionEvent.createLayerRemovedEvent(lyr));
234
        }
235

    
236
        /**
237
         * Borra una FLayer del vector a partir del identificador.
238
         *
239
         * @param idLayer
240
         */
241
        public void removeLayer(int idLayer) {
242
                FLayer lyr = (FLayer) layers.get(idLayer);
243
                callLayerRemoving(LayerCollectionEvent.createLayerRemovingEvent(lyr));
244
                layers.remove(idLayer);
245
                callLayerRemoved(LayerCollectionEvent.createLayerRemovedEvent(lyr));
246
        }
247

    
248
        /**
249
         * M?todo de conveniencia para borrar una capa con ese nombre
250
         *
251
         * @param layerName
252
         */
253
        public void removeLayer(String layerName) {
254
                FLayer lyr;
255

    
256
                for (int i = 0; i < layers.size(); i++) {
257
                        lyr = ((FLayer) layers.get(i));
258

    
259
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
260
                                removeLayer(i);
261

    
262
                                break;
263
                        }
264
                }
265
        }
266
        /**
267
         * M?todo de conveniencia para reemplazar una capa con ese nombre
268
         *
269
         * @param layerName
270
         */
271
        public void replaceLayer(String layerName, FLayer layer)
272
        {
273
                FLayer lyr;
274
                FLayer parent;
275
                for (int i = 0; i < layers.size(); i++) {
276
                        lyr = ((FLayer) layers.get(i));
277

    
278
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
279
                                parent = lyr.getParentLayer();
280
                                removeLayer(i);
281
                                if (parent != null)
282
                                //Notificamos a la capa que va a ser a?adida
283
                                if (layer instanceof FLyrDefault)
284
                                        ((FLyrDefault)layer).wakeUp();
285

    
286
                                if (layer instanceof FLayers){
287
                                        FLayers layers=(FLayers)layer;
288
                                        fmap.addAsCollectionListener(layers);
289
                                }
290
                                callLayerAdding(LayerCollectionEvent.createLayerAddingEvent(layer));
291

    
292
                                layers.add(i,layer);
293
                                layer.setParentLayer(this);
294

    
295
                                callLayerAdded(LayerCollectionEvent.createLayerAddedEvent(layer));
296
                                break;
297
                        }
298
                }
299
        }
300

    
301

    
302
        /**
303
         * Obtiene el array de capas visibles que penden del arbol cuya ra?z es
304
         * este nodo
305
         *
306
         * @return Vector de FLayer.
307
         */
308
        public FLayer[] getVisibles() {
309
                ArrayList array = new ArrayList();
310
                LayersIterator iter = new LayersIterator(this) {
311
                        public boolean evaluate(FLayer layer) {
312
                                return layer.isVisible();
313
                        }
314

    
315
                };
316

    
317
                while (iter.hasNext()) {
318
                        array.add(iter.nextLayer());
319
                }
320

    
321
                return (FLayer[]) array.toArray(new FLayer[0]);
322
        }
323

    
324
        /**
325
         * Obtiene el hijo i-?simo (de abajo a arriba) directo de esta colecci?n.
326
         *
327
         * @param index ?ndice.
328
         *
329
         * @return capa seleccionada.
330
         */
331
        public FLayer getLayer(int index) {
332
                return (FLayer) layers.get(index);
333
        }
334

    
335
        /**
336
         * M?todo de conveniencia para buscar una capa por su nombre Es conveniente
337
         * usar getLayer(int) siempre que se pueda, es m?s directo.
338
         *
339
         * @param layerName nombre.
340
         *
341
         * @return capa seleccionada.
342
         */
343
        public FLayer getLayer(String layerName) {
344
                FLayer lyr;
345
                FLayer lyr2;
346
                ArrayList layerList;
347

    
348
                for (int i = 0; i < layers.size(); i++) {
349
                        lyr = ((FLayer) layers.get(i));
350

    
351
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
352
                                        return lyr;
353
                        }
354

    
355
                        layerList = new ArrayList();
356
                        getLayerFromGroup(lyr,layerList);
357

    
358
                        for(int j = 0; j<layerList.size(); j++ )
359
                        {
360
                                lyr2 = ((FLayer)layerList.get(j));
361
                                if (lyr2.getName().compareToIgnoreCase(layerName) == 0) {
362
                                        return lyr2;
363
                                }
364
                        }
365

    
366
                }
367

    
368
                return null;
369
        }
370
    // looks in the layertree including FLayers
371
        private void getLayerFromGroup(FLayer layer, ArrayList result){
372
                int i;
373
                FLayers layerGroup;
374
                if (layer instanceof FLayers)
375
                {
376
                        result.add(layer);
377
                        layerGroup = (FLayers)layer;
378
                        for (i=0; i < layerGroup.getLayersCount(); i++ )
379
                        {
380
                                getLayerFromGroup(layerGroup.getLayer(i),result);
381
                        }
382
                }
383
                else
384
                {
385
                        result.add(layer);
386
                }
387
        }
388

    
389

    
390
        // this is to to split up a layer group in order to get a layer by name
391
        // when there are layergroups.
392
        private void splitLayerGroup(FLayer layer, ArrayList result)
393
        {
394
                int i;
395
                FLayers layerGroup;
396
                if (layer instanceof FLayers)
397
                {
398
                        layerGroup = (FLayers)layer;
399
                        for (i=0; i < layerGroup.getLayersCount(); i++ )
400
                        {
401
                                splitLayerGroup(layerGroup.getLayer(i),result);
402
                        }
403
                }
404
                else
405
                {
406
                        result.add(layer);
407
                }
408
        }
409

    
410
        /**
411
         * Obtiene el n?mero de capas que hay en su mismo nivel Es decir, no cuenta
412
         * las subcapas de un FLayers
413
         *
414
         * @return n?mero de capas.
415
         */
416
        public int getLayersCount() {
417
                return layers.size();
418
        }
419

    
420
        /**
421
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#draw(java.awt.image.BufferedImage,
422
         *                 java.awt.Graphics2D, com.iver.cit.gvsig.fmap.ViewPort)
423
         */
424
        public void draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
425
                        Cancellable cancel,double scale) throws DriverException {
426
                draw(image,g,viewPort,cancel, scale, null);
427
        }
428

    
429

    
430
        public ComposedLayer draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
431
                        Cancellable cancel,double scale, ComposedLayer group) throws DriverException {
432
            //double scale = getFMap().getScaleView();
433
//                Iterator iter = layers.iterator();
434
//        try
435
//        {
436
                boolean bNeedRecalculateCache = false;
437

    
438
                           ///// CHEMA ComposedLayer
439
                    long tg1 = System.currentTimeMillis();
440
                           ///// CHEMA ComposedLayer
441

    
442

    
443

    
444
//                    while (iter.hasNext())
445
//                    {
446
                     for (int i=0; i < layers.size(); i++) {
447
                if (cancel.isCanceled())
448
                    break; // M?s que nada porque las capas raster no son interrumpibles por ahora.
449
//                            FLayer lyr = (FLayer) iter.next();
450
                            FLayer lyr = (FLayer) layers.get(i);
451

    
452

    
453

    
454
                    /*        if (lyr instanceof FLyrVect && ((FLyrVect)lyr).isBroken()){
455
                                    continue;
456
                            }
457
                    */
458
                            LayerDrawEvent beforeEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_BEFORE_DRAW);
459
                            fmap.fireLayerDrawingEvent(beforeEvent);
460
                        if ((lyr.isDirty()) && (lyr.isCachingDrawnLayers() == false))
461
                                bNeedRecalculateCache = true;
462

    
463
                            if (lyr.isVisible()) {
464

    
465
                                    long t1 = System.currentTimeMillis();
466
                                    System.err.println("Layer " + lyr.getName() + " dirty=" + lyr.isDirty()+ " isCachingDrawnLayers= "+lyr.isCachingDrawnLayers());
467
                                    // synchronized (this) {
468
                                            //Sincronizaci?n del m?todo dibujar de cada Layer, esto es posible hacerlo de otra forma,
469
                                            //pero de momento se queda as?, para solucionar el refresco de una misma vista que est? a?adida en el Layout.
470
                                    try{
471
                                            /* if (lyr instanceof IComposedDrawing)
472
                                            {
473
                                                    // Acumulamos las peticiones hasta que sea
474
                                                    // otro servidor o otro tipo de capa o la ?ltima
475
                                                    // Si hay que dibujar:
476
                                                    lyr.draw(image, g, viewPort, cancel,scale);
477
                                                    // Si hay que acumlar:
478
                                                    lyr.acumulateDrawing(antLayer);
479

480
                                            }
481
                                            else */
482

    
483
                                             if (lyr.isCachingDrawnLayers())
484
                                            {
485
                                                    if ((bNeedRecalculateCache) || (lyr.getCacheImageDrawnLayers()==null))
486
                                                    {
487
                                                    //if (bNeedRecalculateCache)
488
                                                    // {
489

    
490
                                                               ///// CHEMA ComposedLayer
491
                                                            if (group != null) {
492
                                                                    //si tenemos un grupo pendiente de pintar, pintamos
493
                                                                    // para que la cache sea fiable
494
                                                                    group.draw(image, g, viewPort, cancel,scale);
495
                                                                    group = null;
496
                                                            }
497
                                                               ///// CHEMA ComposedLayer
498

    
499

    
500
                                                            // Copiamos la imagen actual
501
                                                            BufferedImage buff = new BufferedImage(image.getWidth(), image.getHeight(), image.getType());
502
                                                            WritableRaster w = buff.getRaster();
503
                                                            image.copyData(w);
504
                                                            lyr.setCacheImageDrawnLayers(buff);
505
                                                            System.err.println("RECALCULO LA CACHE CON LO QUE HABIA ANTES DE " + lyr.getName());
506
                                                    }
507
//                                                    }
508
//                                                    else
509
//                                                    {
510
                                                            if (lyr.getCacheImageDrawnLayers() != null)
511
                                                            {
512
                                                                    // Previo a esto hemos tenido que fijar
513
                                                                    // la imagen que queremos usar, en el
514
                                                                    // prepareDrawing de FMap.
515
                                                                    if (lyr.isDirty())
516
                                                                    {
517

    
518

    
519
                                                                               ///// CHEMA ComposedLayer
520
                                                                            // Checks for draw group (ComposedLayer)
521
                                                                        if (group != null) {
522
                                                                                // it's going to load a cache image,
523
                                                                                // the current draw isn't needed
524
                                                                                group = null;
525
                                                                        }
526
                                                                           ///// CHEMA ComposedLayer
527

    
528

    
529
                                                                            g.drawImage(lyr.getCacheImageDrawnLayers(), 0, 0, null);
530
                                                                            System.err.println("Pinto con acelerado lo que hab?a antes de " + lyr.getName());
531
                                                                    }
532
                                                            }
533
//                                                    }
534
                                            }
535
                                            // Si la capa est? "sucia" o alguna de las de abajo est? sucia
536
                                            // hay que volver a dibujar.
537
                                                   if (lyr.isDirty() || bNeedRecalculateCache)
538
                                                   {
539
                                                           if (!lyr.getFLayerStatus().isDriverLoaded())
540
                                                           {
541
                                                                   continue;
542
                                                           }
543

    
544
                                                           ///// CHEMA ComposedLayer
545
                                                           //lyr.draw(image, g, viewPort, cancel,scale);
546
                                                           //bNeedRecalculateCache = true;
547
                                                           //System.err.println("Pinto sin acelerado " + lyr.getName());
548
                                                           ///// CHEMA ComposedLayer
549

    
550
                                                           ///// CHEMA ComposedLayer
551
                                                           // Checks for draw group (ComposedLayer)
552
                                                           if (group != null) {
553
                                                                   if (lyr instanceof FLayers){
554
                                                                           group = ((FLayers)lyr).draw(image, g, viewPort, cancel,scale,group);
555
                                                                           LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
556
                                                                           fmap.fireLayerDrawingEvent(afterEvent);
557
                                                                   } else {
558
                                                                           // If layer can be added to the group, does it
559
                                                                           if (group.canAdd(lyr)) {
560
                                                                                   group.add(lyr);
561
                                                                           } else {
562
                                                                                   // draw the 'pending to draw' layer group
563
                                                                                   group.draw(image, g, viewPort, cancel,scale);
564

    
565
                                                                                   // gets a new group instance
566
                                                                                   group = lyr.newComposedLayer();
567
                                                                                   // if layer hasn't group, draws it inmediately
568
                                                                                   if (group == null) {
569
                                                                                           if (lyr instanceof FLayers){
570
                                                                                                   group = ((FLayers)lyr).draw(image, g, viewPort, cancel,scale,group);
571
                                                                                           } else {
572
                                                                                                   lyr.draw(image, g, viewPort, cancel,scale);
573
                                                                                           }
574
                                                                                           LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
575
                                                                                           fmap.fireLayerDrawingEvent(afterEvent);
576
                                                                                   } else {
577
                                                                                           // add the layer to the group
578
                                                                                           group.setMapContext(fmap);
579
                                                                                           group.add(lyr);
580

    
581
                                                                                   }
582
                                                                           }
583
                                                                   }
584
                                                           } else {
585
                                                                   // gets a new group instance
586
                                                                   group = lyr.newComposedLayer();
587
                                                                   // if layer hasn't group, draws it inmediately
588
                                                                   if (group == null) {
589
                                                                           if (lyr instanceof FLayers){
590
                                                                                   group = ((FLayers)lyr).draw(image, g, viewPort, cancel,scale,group);
591
                                                                           } else {
592
                                                                                   lyr.draw(image, g, viewPort, cancel,scale);
593
                                                                           }
594
                                                                           LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
595
                                                                           fmap.fireLayerDrawingEvent(afterEvent);
596
                                                                   } else {
597
                                                                           // adds the layer to the group
598
                                                                           group.setMapContext(fmap);
599
                                                                           group.add(lyr);
600
                                                                   }
601
                                                           }
602
                                                           ///// CHEMA ComposedLayer
603
                                                                bNeedRecalculateCache = true;
604
                                                   }
605
                                    } catch (DriverException e){
606
                                            // fmap.callNewErrorEvent(new ErrorEvent(lyr.getName(), e));
607
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
608
                                            e.printStackTrace();
609
                                            lyr.setAvailable(false);
610
                                            // this.removeLayer(lyr);
611
                                    } catch (Exception e) {
612
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
613
                                            e.printStackTrace();
614
                                            lyr.setAvailable(false);
615
                                    }
616
                                            // }
617
                                            long t2 = System.currentTimeMillis();
618
                                            System.out.println("Layer " + lyr.getName() + " "
619
                                                    + (t2-t1) + " milisecs.");
620
                                            if (!cancel.isCanceled())
621
                                                    lyr.setDirty(false);
622
                            }
623

    
624
                    }
625
                    ///// CHEMA ComposedLayer
626
                    if (group != null && this.getParentLayer() == null) {
627
                                 //si tenemos un grupo pendiente de pintar, pintamos
628
                                 group.draw(image, g, viewPort, cancel,scale);
629
                                 group = null;
630

    
631
                         }
632
                        ///// CHEMA ComposedLayer
633
                    if (getVirtualLayers() != null) {
634
                            getVirtualLayers().draw(image, g, viewPort, cancel,scale);
635
                    }
636

    
637
                    ///// CHEMA ComposedLayer
638
                    return group;
639
                    ///// CHEMA ComposedLayer
640

    
641
//        }
642
//        catch (ConcurrentModificationException e)
643
//        {
644
//            System.err.println(e.getMessage());
645
//        }
646
        }
647

    
648
        /**
649
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#print(java.awt.Graphics2D,
650
         *                 com.iver.cit.gvsig.fmap.ViewPort,
651
         *                 com.iver.utiles.swing.threads.Cancellable)
652
         */
653
        public ComposedLayer print(Graphics2D g, ViewPort viewPort, Cancellable cancel, double scale, PrintRequestAttributeSet properties, ComposedLayer group)
654
                throws DriverException {
655

    
656
        // TODO: A la hora de imprimir, isWithinScale falla, porque est?
657
        // calculando la escala en pantalla, no para el layout.
658
        // Revisar esto.
659
                for (int i=0; i < layers.size(); i++) {
660
                        FLayer lyr = (FLayer) layers.get(i);
661

    
662
                        try{
663

    
664
                                ///// CHEMA ComposedLayer
665
                                // Checks for draw group (ComposedLayer)
666
                                if (group != null) {
667
                                        if (lyr instanceof FLayers){
668
                                                group = ((FLayers)lyr).print(g, viewPort, cancel,scale,properties,group);
669
                                        } else {
670
                                                // If layer can be added to the group, does it
671
                                                if (group.canAdd(lyr)){
672
                                                        group.add(lyr);
673
                                                } else {
674
                                                        // draw the 'pending to draw' layer group
675
                                                        group.print(g,viewPort,cancel,scale,properties);
676

    
677
                                                        // gets a new group instance
678
                                                        group = lyr.newComposedLayer();
679
                                                        // if layer hasn't group, draws it inmediately
680
                                                        if (group == null) {
681
                                                                if (lyr instanceof FLayers){
682
                                                                        group = ((FLayers)lyr).print(g, viewPort, cancel,scale,properties,group);
683
                                                                } else {
684
                                                                        lyr.print(g, viewPort, cancel,scale,properties);
685
                                                                }
686
                                                        } else {
687
                                                                // add the layer to the group
688
                                                                group.setMapContext(fmap);
689
                                                                group.add(lyr);
690

    
691
                                                        }
692

    
693
                                                }
694
                                        }
695
                                } else {
696
                                        // gets a new group instance
697
                                        group = lyr.newComposedLayer();
698
                                        // if layer hasn't group, draws it inmediately
699
                                        if (group == null) {
700
                                                if (lyr instanceof FLayers){
701
                                                        group = ((FLayers)lyr).print(g, viewPort, cancel,scale,properties,group);
702
                                                } else {
703
                                                        lyr.print(g, viewPort, cancel,scale,properties);
704
                                                }
705
                                        } else {
706
                                                // add the layer to the group
707
                                                group.setMapContext(fmap);
708
                                                group.add(lyr);
709

    
710
                                        }
711
                                }
712
                                ///// CHEMA ComposedLayer
713

    
714
                        } catch (Exception e){
715
                                fmap.addLayerError("Error en la impresion de la capa " + lyr.getName() + ": " + e.getMessage());
716
                                e.printStackTrace();
717
                        }
718

    
719
                }
720

    
721
                ///// CHEMA ComposedLayer
722
                if (group != null && this.getParentLayer() == null) {
723
                                //si tenemos un grupo pendiente de pintar, pintamos
724
                                group.print(g, viewPort, cancel,scale,properties);
725
                                group = null;
726

    
727
                }
728
                ///// CHEMA ComposedLayer
729

    
730
                if (getVirtualLayers() != null) {
731
                        getVirtualLayers().print( g, viewPort, cancel, scale, properties);
732
                }
733

    
734
                ///// CHEMA ComposedLayer
735
                return group;
736
                ///// CHEMA ComposedLayer
737

    
738
        }
739

    
740
        public void print(Graphics2D g, ViewPort viewPort, Cancellable cancel, double scale, PrintRequestAttributeSet properties)
741
        throws DriverException {
742
                this.print(g, viewPort, cancel, scale, properties, null);
743
        }
744
        /**
745
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getFullExtent()
746
         */
747
        public Rectangle2D getFullExtent() throws DriverException {
748
                Rectangle2D rAux = null;
749
                boolean first = true;
750

    
751

    
752
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
753
                        FLayer capa = (FLayer) iter.next();
754
                        try{
755
                        if (first) {
756
                                rAux = capa.getFullExtent();
757
                                first=false;
758
                        } else {
759
                                rAux.add(capa.getFullExtent());
760
                        }
761
                        }catch (Exception e) {
762
                                e.printStackTrace();//TODO hay que revisar para determinar el comportamiento que espera el usuario.
763
                        }
764
                }
765

    
766
                return rAux;
767
        }
768

    
769
        /**
770
         * Llama al m?todo layerAdding de los listeners dados de alta.
771
         *
772
         * @param event
773
         *
774
         * @throws CancelationException
775
         */
776
        protected void callLayerAdding(LayerCollectionEvent event)
777
                throws CancelationException {
778
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
779
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
780
                        ((LayerCollectionListener) iter.next()).layerAdding(event);
781
                }
782
        }
783

    
784
        /**
785
         * Llama al m?todo layerRemoving de los listeners dados de alta.
786
         *
787
         * @param event
788
         *
789
         * @throws CancelationException
790
         */
791
        protected void callLayerRemoving(LayerCollectionEvent event)
792
                throws CancelationException {
793
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
794
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
795
                        ((LayerCollectionListener) iter.next()).layerRemoving(event);
796
                }
797
        }
798

    
799

    
800
        /**
801
         * Llama al m?todo layerMoving de los listeners dados de alta.
802
         *
803
         * @param event
804
         *
805
         * @throws CancelationException
806
         */
807
        protected void callLayerMoving(LayerPositionEvent event)
808
                throws CancelationException {
809
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
810
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
811
                        ((LayerCollectionListener) iter.next()).layerMoving(event);
812
                }
813
        }
814

    
815
        /**
816
         * Llama al m?todo layerAdded de los listeners dados de alta.
817
         *
818
         * @param event
819
         */
820
        protected void callLayerAdded(LayerCollectionEvent event) {
821
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
822
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
823
                        ((LayerCollectionListener) iter.next()).layerAdded(event);
824
                }
825
        }
826

    
827
        /**
828
         * Llama al m?todo layerRemoved de los listeners dados de alta.
829
         *
830
         * @param event
831
         */
832
        protected void callLayerRemoved(LayerCollectionEvent event) {
833
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
834
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
835
                        ((LayerCollectionListener) iter.next()).layerRemoved(event);
836
                }
837
        }
838

    
839
        /**
840
         * Llama al m?todo layerMoved de los listeners dados de alta.
841
         *
842
         * @param event
843
         */
844
        protected void callLayerMoved(LayerPositionEvent event) {
845
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
846
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
847
                        ((LayerCollectionListener) iter.next()).layerMoved(event);
848
                }
849
        }
850

    
851
        /**
852
         * @throws XMLException
853
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getProperties()
854
         */
855
        public XMLEntity getXMLEntity() throws XMLException {
856
                XMLEntity xml = super.getXMLEntity();
857
                
858
                ArrayList names = new ArrayList();
859
                
860

    
861
                FLayer layer;                
862
                for (int i = 0; i < layers.size(); i++) {
863
                        layer = (FLayer)layers.get(i);
864
                        // XXX: Parche para no guardar capas raster de memoria en el proyecto
865
                        if (layer instanceof FLyrRaster){
866
                                if (((FLyrRaster)layer).getSource() instanceof RasterFileAdapter){
867
                                        if (((RasterFileAdapter)((FLyrRaster)layer).getSource()).getFile() == null){
868
                                                continue;
869
                                        }
870
                                }
871
                        }
872
            // XXX: Parche para no guardar capas raster de memoria en el proyecto
873
                        try{
874
                                names.add(layer.getName());
875
                                xml.addChild(layer.getXMLEntity());
876
                        }catch (XMLException e) {
877
                                e.printStackTrace();
878
                        }
879
                }
880

    
881
                String[] s = new String[names.size()]; 
882
                System.arraycopy(names.toArray(),0,s,0,names.size()); 
883
                xml.putProperty("numLayers", names.size());
884
                xml.putProperty("LayerNames", s);
885
                
886
                return xml;
887
        }
888

    
889
        /**
890
         * DOCUMENT ME!
891
         *
892
         * @param xml DOCUMENT ME!
893
         *
894
         * @throws XMLException
895
         *
896
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
897
         */
898
        public void setXMLEntity03(XMLEntity xml) throws XMLException{
899
                super.setXMLEntity03(xml);
900
                int numLayers = xml.getIntProperty("numLayers");
901

    
902
                String[] s = xml.getStringArrayProperty("LayerNames");
903
                try {
904
                        for (int i = 0; i < numLayers; i++) {
905
                                FLayer layer = null;
906

    
907
                                String className = xml.getChild(i).getStringProperty("className");
908

    
909
                                if (className.equals(FLyrVect.class.getName())) {
910
                                        if (xml.getChild(i).contains("file")) {
911

    
912
                                                        layer = LayerFactory.createLayer(s[i],
913
                                                                        (VectorialFileDriver)LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName")),
914
                                                                        new File(xml.getChild(i).getStringProperty("file")),
915
                                                                        this.getMapContext().getViewPort().getProjection());
916

    
917
                                        } else if (true) {
918
                                                //TODO falta por implementar
919
                                        } else if (true) {
920
                                                //TODO falta por implementar
921
                                        }
922

    
923
                                        layer.setXMLEntity03(xml.getChild(i));
924
                                        // Comprobar que la proyecci?n es la misma que la de FMap
925
                                        // Si no lo es, es una capa que est? reproyectada al vuelo
926
                                        IProjection proj = layer.getProjection();
927
                                        if (proj != null)
928
                                            if (proj != fmap.getProjection())
929
                                            {
930
                                                        ICoordTrans ct = proj.getCT(fmap.getProjection());
931
                                                        layer.setCoordTrans(ct);
932
                                                        System.err.println("coordTrans = " +
933
                                                                proj.getAbrev() + " " +
934
                                                                fmap.getProjection().getAbrev());
935
                                            }
936

    
937
//                                } else if (className.equals(FLyrWMS.class.getName())) {
938
//                                        try {
939
//                                                layer = LayerFactory.createLayer(s[i],
940
//                                                                StringUtilities.string2Rect(
941
//                                                                        xml.getChild(i).getStringProperty("fullExtent")),
942
//                                                                new URL(xml.getChild(i).getStringProperty("host")),
943
//                                                                xml.getChild(i).getStringProperty("format"),
944
//                                                                xml.getChild(i).getStringProperty("layerQuery"),
945
//                                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
946
//                                                                xml.getChild(i).getStringProperty("srs"));
947
//                                        } catch (MalformedURLException e) {
948
//                                                throw new XMLException(e);
949
//                                        }
950
                                } else if (className.equals((FLyrRaster.class.getName()))) {
951
                                        //if (xml.getChild(i).contains("file")) {
952
                                        /*layer = LayerFactory.createLayer(s[i],
953
                                                        xml.getChild(i).getStringProperty("driverName"),
954
                                                        new File(xml.getChild(i).getStringProperty("file")),
955
                                                        this.getFMap().getViewPort().getProjection());*/
956
                                        layer = new FLyrRaster();
957
                                        layer.setName(s[i]);
958
                                        if (!xml.getChild(i).contains("proj"))
959
                                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
960
                                        layer.setXMLEntity03(xml.getChild(i));
961
                                        try {
962
                                                        layer.load();
963

    
964
                                        } catch (DriverIOException e) {
965
                                                throw new XMLException(e);
966
                                        }
967

    
968
                                }else if (className.equals((FLayers.class.getName()))) {
969
                                        layer = new FLayers(getMapContext(),this);
970
                                        layer.setXMLEntity(xml.getChild(i));
971
                                } else {
972
                                        // Capas Nuevas (externas)
973
                                        try {
974
                                                Class clase = Class.forName(className);
975
                                                layer = (FLayer) clase.newInstance();
976
                                                layer.setName(s[i]);
977
                                                layer.setXMLEntity03(xml.getChild(i));
978
                                                try {
979
                                                                layer.load();
980
                                                } catch (DriverIOException e) {
981
                                                        throw new XMLException(e);
982
                                                }
983
                                        } catch (Exception e) {
984
                                                //e.printStackTrace();
985
                                                throw new XMLException(e);
986
                                        }
987
                                }
988

    
989
                                this.addLayer(layer);
990
                        }
991
                } /*azabala-modificaciones en layerfactory-
992
                catch (DriverException e) {
993
                        throw new XMLException(e);
994
                }*/
995
                catch (DriverLoadException e) {
996
            throw new XMLException(e);
997
        }
998

    
999
        }
1000

    
1001
        /**
1002
         * DOCUMENT ME!
1003
         *
1004
         * @param xml DOCUMENT ME!
1005
         *
1006
         * @throws XMLException
1007
         *
1008
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
1009
         */
1010
        public void setXMLEntity(XMLEntity xml) throws XMLException{
1011
                super.setXMLEntity(xml);
1012
                //LoadLayerException loadLayerException=new LoadLayerException();
1013
                int numLayers = xml.getIntProperty("numLayers");
1014

    
1015
                String[] s = xml.getStringArrayProperty("LayerNames");
1016
                // try {
1017
                fmap.clearErrors();
1018
                        for (int i = 0; i < numLayers; i++) {
1019
                                this.addLayerFromXML(xml.getChild(i),s[i]);
1020

    
1021

    
1022
                        }
1023
                /* } catch (DriverException e) {
1024
                        throw new XMLException(e);
1025
                } */
1026
                /*if (loadLayerException.getExceptions().size()>0){
1027
                        throw loadLayerException;
1028
                }*/
1029
        }
1030

    
1031
        /**
1032
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor,
1033
         *                 FBitSet)
1034
         */
1035
        public void process(FeatureVisitor visitor, FBitSet subset)
1036
                throws DriverException, VisitException {
1037
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1038
                        FLayer layer = (FLayer) iter.next();
1039

    
1040
                        if (layer instanceof VectorialData) {
1041
                                ((VectorialData) layer).process(visitor, subset);
1042
                        }
1043
                }
1044
        }
1045

    
1046
        /**
1047
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor)
1048
         */
1049
        public void process(FeatureVisitor visitor)
1050
                throws DriverException, VisitException {
1051
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1052
                        FLayer layer = (FLayer) iter.next();
1053

    
1054
                        if (layer instanceof FLayers){
1055
                                FLayers lyrs=(FLayers)layer;
1056
                                for (int i=0;i<lyrs.getLayersCount();i++){
1057
                                        FLayer lyr=lyrs.getLayer(i);
1058
                                        if (lyr.isActive()) {
1059
                                                if (lyr instanceof VectorialData) {
1060
                                                        ((VectorialData) lyr).process(visitor);
1061
                                                }
1062
                                        }
1063
                                }
1064
                        }
1065
                        if (layer.isActive()) {
1066
                                if (layer instanceof VectorialData) {
1067
                                        ((VectorialData) layer).process(visitor);
1068
                                }
1069
                        }
1070
                }
1071
        }
1072
        /**
1073
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor, Rectangle2D)
1074
         */
1075
        public void process(FeatureVisitor visitor, Rectangle2D rect) throws DriverException, VisitException {
1076
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1077
                        FLayer layer = (FLayer) iter.next();
1078

    
1079
                        if (layer.isActive()) {
1080
                                if (layer instanceof VectorialData) {
1081
                                        ((VectorialData) layer).process(visitor, rect);
1082
                                }
1083
                        }
1084
                }
1085

    
1086
        }
1087

    
1088
        /**
1089
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMapContext()
1090
         */
1091
        public MapContext getMapContext() {
1092
                return fmap;
1093
        }
1094

    
1095
        /* (non-Javadoc)
1096
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#setCoordTrans(org.cresques.cts.ICoordTrans)
1097
         */
1098
        public void setCoordTrans(ICoordTrans ct) {
1099
                super.setCoordTrans(ct);
1100

    
1101
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1102
                        FLayer layer = (FLayer) iter.next();
1103
                        layer.setCoordTrans(ct);
1104
                }
1105
        }
1106

    
1107
        /**
1108
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllActives(boolean)
1109
         */
1110
        public void setAllActives(boolean active) {
1111
                FLayer lyr;
1112

    
1113
                for (int i = 0; i < layers.size(); i++) {
1114
                        lyr = ((FLayer) layers.get(i));
1115
                        lyr.setActive(active);
1116

    
1117
                        if (lyr instanceof LayerCollection) {
1118
                                ((LayerCollection) lyr).setAllActives(active);
1119
                        }
1120
                }
1121
        }
1122

    
1123
        /**
1124
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#getActives()
1125
         */
1126
        public FLayer[] getActives() {
1127
                ArrayList ret = new ArrayList();
1128
                LayersIterator it = new LayersIterator(this) {
1129

    
1130
                        public boolean evaluate(FLayer layer) {
1131
                                return layer.isActive();
1132
                        }
1133

    
1134
                };
1135

    
1136
                while (it.hasNext())
1137
                {
1138
                        ret.add(it.next());
1139
                }
1140
                return (FLayer[]) ret.toArray(new FLayer[0]);
1141
        }
1142

    
1143
    /* (non-Javadoc)
1144
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMinScale()
1145
     */
1146
    public double getMinScale() {
1147
        return -1; // La visibilidad o no la controla cada capa
1148
                // dentro de una colecci?n
1149
    }
1150

    
1151
    /* (non-Javadoc)
1152
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMaxScale()
1153
     */
1154
    public double getMaxScale() {
1155
        return -1;
1156
    }
1157
    public void setMinScale(double minScale)
1158
    {
1159
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1160
                        FLayer lyr = (FLayer) iter.next();
1161
                        lyr.setMinScale(minScale);
1162
                }
1163
    }
1164
    public void setMaxScale(double maxScale)
1165
    {
1166
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1167
                        FLayer lyr = (FLayer) iter.next();
1168
                        lyr.setMinScale(maxScale);
1169
                }
1170
    }
1171
    public void setActive(boolean b){
1172
            super.setActive(b);
1173
            for (int i=0;i<layers.size();i++){
1174
                    ((FLayer)layers.get(i)).setActive(b);
1175
            }
1176
    }
1177

    
1178
        /* (non-Javadoc)
1179
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#addLayerListener(com.iver.cit.gvsig.fmap.layers.LayerListener)
1180
         */
1181
        public boolean addLayerListener(LayerListener o) {
1182
                for (int i = 0; i < layers.size(); i++)
1183
                        ((FLayer) layers.get(i)).addLayerListener(o);
1184
                return true;
1185
        }
1186

    
1187
        public XMLItem[] getInfo(Point p, double tolerance, Cancellable cancel) throws DriverException {
1188
                int i;
1189
                Vector items = new Vector();
1190
                FLayer layer;
1191
                XMLItem[] aux;
1192
                for (i = 0; i < this.layers.size(); i++){
1193
                        layer = (FLayer)layers.get(i);
1194
                        if (layer instanceof InfoByPoint){
1195
                                InfoByPoint queryable_layer = (InfoByPoint) layer;
1196
                                aux = queryable_layer.getInfo(p, tolerance, null);
1197
                                if (!(queryable_layer instanceof FLayers)){
1198
                                        for(int j = 0; j < aux.length; j++){
1199
                                                items.add(aux[j]);
1200
                                        }
1201
                                }
1202
                        }
1203
                }
1204
                return (XMLItem[])items.toArray(new XMLItem[0]);
1205

    
1206
//                for (i = 0; i < this.layers.size(); i++){
1207
//                        FLayer laCapa = (FLayer) layers.get(i);
1208
//                        if (laCapa instanceof FLyrVect){
1209
//                        }
1210
//                        else if (laCapa instanceof RasterOperations) {
1211
//                                try {
1212
//                                        RasterOperations layer = (RasterOperations) laCapa;
1213
//                                        sb.append(layer.getInfo(p, tolerance));
1214
//                                } catch (DriverException e) {
1215
//                                        e.printStackTrace();
1216
//                                }
1217
//                        }
1218
//                        else if (laCapa instanceof InfoByPoint) {
1219
//                                try {
1220
//                                        InfoByPoint layer = (InfoByPoint) laCapa;
1221
//                                        sb.append(layer.getInfo(p, tolerance));
1222
//                                } catch (DriverException e) {
1223
//                                        e.printStackTrace();
1224
//                                }
1225
//                        }
1226
//                }
1227

    
1228
        }
1229

    
1230
        public ImageIcon getTocImageIcon() {
1231
                return new ImageIcon(MapControl.class.getResource("images/layerGroup.png"));
1232
        }
1233

    
1234
        public boolean isDirty() {
1235
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1236
                        FLayer lyr = (FLayer) iter.next();
1237
                        if (lyr.isDirty())
1238
                                return true;
1239
                }
1240
                return false;
1241
        }
1242

    
1243
        public void setDirty(boolean dirty) {
1244
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1245
                        FLayer lyr = (FLayer) iter.next();
1246
                        lyr.setDirty(dirty);
1247
                }
1248

    
1249
        }
1250

    
1251
        public boolean addLayerFromXMLEntity(XMLEntity xml, String name) {
1252
                fmap.clearErrors();
1253
                this.addLayerFromXML(xml,name);
1254

    
1255
                return (fmap.getLayersError().size() == 0);
1256

    
1257
        }
1258

    
1259
        private void addLayerFromXML(XMLEntity xml, String name) {
1260
                FLayer layer = null;
1261
                long t1 = System.currentTimeMillis();
1262
                try {
1263
                if (name == null) name = xml.getName();
1264

    
1265

    
1266
                String className = xml.getStringProperty("className");
1267
                //TODO VCN FLyrAnnotation es un parche para no tener que duplicar todo el c?digo de aq? y de los diferentes m?todos de LayerFactory,
1268
                //ya que los drivers de una FLyrAnnotation no sabemos cual es puede ser cualquier Driver Vectorial.
1269
                if (className.equals(FLyrVect.class.getName()) || className.equals(FLyrAnnotation.class.getName())) {
1270
                        String type = xml.getStringProperty("type");
1271
                        if ("vectorial".equals(type)){
1272
                                //String recordsetName = xml.getChild(i).getStringProperty("recordset-name");
1273
                IProjection proj = null;
1274
                if (xml.contains("proj")) {
1275
                    proj = CRSFactory.getCRS(xml.getStringProperty("proj"));
1276
                }
1277
                else
1278
                {
1279
                    proj = this.getMapContext().getViewPort().getProjection();
1280
                }
1281
                                if (xml.contains("file")) {
1282
                                        Driver d;
1283
                                        try {
1284
                                                d = LayerFactory.getDM().getDriver(xml.getStringProperty("driverName"));
1285
                                        } catch (DriverLoadException e1) {
1286
                                                throw new XMLException(e1);
1287
                                        }
1288
                                        layer = LayerFactory.createLayer(name, (VectorialFileDriver) d,
1289
                                                                                                        new File(xml.getStringProperty("file")),
1290
                                                                                                        proj);
1291

    
1292

    
1293
                                }
1294
                if (xml.contains("db")) {
1295

    
1296
                    String driverName = xml.getStringProperty("db");
1297
                    IVectorialDatabaseDriver driver;
1298
                    try {
1299
                        driver = (IVectorialDatabaseDriver) LayerFactory.getDM().getDriver(driverName);
1300
                        //Hay que separar la carga de los datos del XMLEntity del load.
1301
                        driver.setXMLEntity(xml.getChild(2));
1302

    
1303
                        boolean loadOk = false;
1304
//                        if (driver instanceof DefaultJDBCDriver) {
1305
                                                        try {
1306
                                                                ((IVectorialDatabaseDriver) driver).load();
1307
                                                                if (((IVectorialDatabaseDriver) driver)
1308
                                                                                .getConnection() != null) {
1309
                                                                        loadOk = true;
1310
                                                                }
1311
                                                        } catch (DriverException e) {
1312
                                                                e.printStackTrace();
1313
                                                                loadOk = false;
1314
                                                        }
1315
//                                                } else {
1316
//                                                        try{
1317
//                                                                ((IVectorialDatabaseDriver)driver).load();
1318
//                                                                loadOk=true;
1319
//                                                        }catch (Exception e) {
1320
//                                                                loadOk=false;
1321
//                                                        }
1322
//                                                }
1323

    
1324
                        layer = LayerFactory.createDBLayer(driver, name, proj);
1325
                        if (!loadOk) {
1326
                                layer.setAvailable(false);
1327
                        }
1328

    
1329
                    } catch (DriverLoadException e) {
1330
                        e.printStackTrace();
1331
                        throw new XMLException(e);
1332
                    }
1333

    
1334
                }
1335
                // Clases con algun driver gen?rico creado por otro
1336
                // programador
1337
                if (xml.contains("other")) {
1338

    
1339
                    String driverName = xml.getStringProperty("other");
1340
                    VectorialDriver driver = null;
1341
                    try {
1342
                        driver = (VectorialDriver) LayerFactory.getDM().getDriver(driverName);
1343
                    } catch (DriverLoadException e) {
1344
                        // Si no existe ese driver, no pasa nada.
1345
                        // Puede que el desarrollador no quiera que
1346
                        // aparezca en el cuadro de di?logo y ha metido
1347
                        // el jar con sus clases en nuestro directorio lib.
1348
                        // Intentamos cargar esa clase "a pelo".
1349
                        if (xml.getChild(2).contains("className"))
1350
                        {
1351
                            String className2 = xml.getChild(2).getStringProperty("className");
1352
                            try {
1353
                                driver = (VectorialDriver) Class.forName(className2).newInstance();
1354
                            } catch (Exception e1) {
1355
                                throw new XMLException(e1);
1356
                            }
1357
                        }
1358
                    } catch (NullPointerException npe) {
1359
                        // Si no existe ese driver, no pasa nada.
1360
                        // Puede que el desarrollador no quiera que
1361
                        // aparezca en el cuadro de di?logo y ha metido
1362
                        // el jar con sus clases en nuestro directorio lib.
1363
                        // Intentamos cargar esa clase "a pelo".
1364
                        if (xml.getChild(2).contains("className"))
1365
                        {
1366
                            String className2 = xml.getChild(2).getStringProperty("className");
1367
                            try {
1368
                                driver = (VectorialDriver) Class.forName(className2).newInstance();
1369
                            } catch (Exception e1) {
1370
                                throw new XMLException(e1);
1371
                            }
1372
                        }
1373
                    }
1374
                    if (driver instanceof IPersistance)
1375
                    {
1376
                        IPersistance persist = (IPersistance) driver;
1377
                        persist.setXMLEntity(xml.getChild(2));
1378
                    }
1379
                    layer = LayerFactory.createLayer(name, driver, proj);
1380
                }
1381

    
1382
                        }
1383

    
1384
                        //TODO VCN FLyrAnnotation es un parche para no tener que duplicar todo el c?digo de aq? y de los diferentes m?todos de LayerFactory,
1385
                        //ya que los drivers de una FLyrAnnotation no sabemos cual es puede ser cualquier Driver Vectorial.
1386
                        if (className.equals(FLyrAnnotation.class.getName())){
1387
                                layer=FLyrAnnotation.createLayerFromVect((FLyrVect)layer);
1388
                        }
1389

    
1390

    
1391
                        layer.setXMLEntity(xml);
1392

    
1393
//                } else if (className.equals(FLyrWMS.class.getName())) {
1394
//                        try {
1395
//                                layer = LayerFactory.createLayer(s[i],
1396
//                                                StringUtilities.string2Rect(
1397
//                                                        xml.getChild(i).getStringProperty("fullExtent")),
1398
//                                                new URL(xml.getChild(i).getStringProperty("host")),
1399
//                                                xml.getChild(i).getStringProperty("format"),
1400
//                                                xml.getChild(i).getStringProperty("layerQuery"),
1401
//                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
1402
//                                                xml.getChild(i).getStringProperty("srs"));
1403
//                                layer.setXMLEntity(xml.getChild(i));
1404
//                        } catch (MalformedURLException e) {
1405
//                                throw new XMLException(e);
1406
//                        }
1407
                } else if (className.equals((FLyrRaster.class.getName()))) {
1408
                        //if (xml.getChild(i).contains("file")) {
1409
                        /*layer = LayerFactory.createLayer(s[i],
1410
                                        xml.getChild(i).getStringProperty("driverName"),
1411
                                        new File(xml.getChild(i).getStringProperty("file")),
1412
                                        this.getFMap().getViewPort().getProjection());*/
1413
                        layer = new FLyrRaster();
1414
                        layer.setName(name);
1415
                        if (!xml.contains("proj"))
1416
                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
1417
                        layer.setXMLEntity(xml);
1418
                        try {
1419
                                layer.load();
1420
                        } catch (DriverIOException e) {
1421
                                throw new XMLException(e);
1422
                        }
1423

    
1424
                }else if (className.equals((FLayers.class.getName()))) {
1425
                        layer = new FLayers(getMapContext(),this);
1426
                        layer.setXMLEntity(xml);
1427
                } else {
1428
                        // Capas Nuevas (externas)
1429
                                Class clase = Class.forName(className);
1430
                                layer = (FLayer) clase.newInstance();
1431
                                layer.setName(name);
1432
                                layer.setXMLEntity(xml);
1433
                                try {
1434
                                        layer.load();
1435
                                }catch (DriverIOException e) {
1436
                                        throw new XMLException(e);
1437
                                }
1438

    
1439
                }
1440

    
1441
                this.addLayer(layer);
1442
                long t2 = System.currentTimeMillis();
1443
                logger.debug("layer: "+ layer.getName() +" loaded. " + (t2-t1) + " msecs.");
1444
                // Comprobar que la proyecci?n es la misma que la de FMap
1445
        // Si no lo es, es una capa que est? reproyectada al vuelo
1446
        IProjection proj = layer.getProjection();
1447
        if ((proj != null))
1448
            if (proj != getMapContext().getProjection())
1449
            {
1450
                ICoordTrans ct = proj.getCT(getMapContext().getProjection());
1451
                // TODO: REVISAR CON LUIS
1452
                // Se lo fijamos a todas, luego cada una que se reproyecte
1453
                // si puede, o que no haga nada
1454
                layer.setCoordTrans(ct);
1455
                // NOTA: DESPU?S DE ESTO DEBER?AMOS CREAR LAS ETIQUETAS
1456
                // SI ES NECESARIO.
1457
                // TODO: REVISAR A FONDO ESTO, PORQUE LAS ETIQUETAS SE CREAN
1458
                // 2 VECES SI HAY REPROYECC?N
1459
                if (layer instanceof FLyrVect)
1460
                {
1461
                    FLyrVect lyrVect = (FLyrVect)layer;
1462
                    VectorialLegend legend = (VectorialLegend) lyrVect.getLegend();
1463
                    if (legend.getLabelField() != null) {
1464
                        lyrVect.createLabelLayer(lyrVect.getRecordset());
1465
                    }
1466

    
1467
                }
1468
            }
1469
        }catch (Exception e) {
1470
                        fmap.addLayerError(xml.getStringProperty("name"));
1471
                                //loadLayerException.addException(e);
1472
                        /*if (layer!=null){
1473
                layer.setActive(false);
1474
                        layer.setVisible(false);
1475
                        this.addLayer(layer);
1476
                }*/
1477
                        //throw new XMLException(e);
1478
            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1479
            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1480
            // logger.debug(e.fillInStackTrace());
1481
            e.printStackTrace();
1482
        }
1483
        }
1484

    
1485
        private void addLayerFromXMLNew(XMLEntity xml, String name) {
1486
                FLayer layer = null;
1487

    
1488

    
1489
                try {
1490
                String className = xml.getStringProperty("className");
1491

    
1492
                if (className.equals((FLayers.class.getName()))){
1493
                        layer = new FLayers(getMapContext(),this);
1494
                } else {
1495
//                         Por compatibilidad
1496
                        if (className.equals(FLyrVect.class.getName())) {
1497
                                if (xml.contains("file")) {
1498
                                        layer = new FLayerFileVectorial();
1499
                                } else if (xml.contains("db")) {
1500
                                        try {
1501
                                                layer = (FLayer)((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create("com.iver.cit.gvsig.fmap.layers.FLayerJDBCVectorial");
1502
                                        } catch (Exception e) {
1503
                                                throw new XMLException(new Exception("No se tiene registrada la capa de tipo JDBC"));
1504
                                        }
1505
                                        //className = FLayerJDBCVectorial.class.getName();
1506
                                } else if (xml.contains("other")){
1507
                                        layer = new FLayerGenericVectorial();
1508
                                } else {
1509
                                        throw new XMLException(new Exception("Capa vectorial de tipo no reconocido"));
1510
                                }
1511
//                                Fin por compatibilidad
1512
                        } else {
1513
                                try {
1514
                                        layer = (FLayer)(((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create(className));
1515
                                } catch (Exception e) {
1516
                                        //puende que no este registrada como punto de extension
1517
                                        Class clase = Class.forName(className);
1518
                                        layer = (FLayer) clase.newInstance();
1519
                                        // FIXME: Hacemos algo aqui o dejamos que suba el error?
1520
                                }
1521
                        }
1522

    
1523
                }
1524
                layer.setXMLEntity(xml);
1525
                if (name != null) layer.setName(name);
1526
                try {
1527
                        layer.load();
1528
                }catch (DriverIOException e) {
1529
                        throw new XMLException(e);
1530
                }
1531

    
1532
                this.addLayer(layer);
1533
                logger.debug("layer: "+ layer.getName() +" loaded");
1534
                // Comprobar que la proyecci?n es la misma que la de FMap
1535
        // Si no lo es, es una capa que est? reproyectada al vuelo
1536
        IProjection proj = layer.getProjection();
1537
        if ((proj != null))
1538
            if (proj != getMapContext().getProjection())
1539
            {
1540
                ICoordTrans ct = proj.getCT(getMapContext().getProjection());
1541
                // TODO: REVISAR CON LUIS
1542
                // Se lo fijamos a todas, luego cada una que se reproyecte
1543
                // si puede, o que no haga nada
1544
                layer.setCoordTrans(ct);
1545
                // NOTA: DESPU?S DE ESTO DEBER?AMOS CREAR LAS ETIQUETAS
1546
                // SI ES NECESARIO.
1547
                // TODO: REVISAR A FONDO ESTO, PORQUE LAS ETIQUETAS SE CREAN
1548
                // 2 VECES SI HAY REPROYECC?N
1549
                if (layer instanceof FLyrVect)
1550
                {
1551
                    FLyrVect lyrVect = (FLyrVect)layer;
1552
                    VectorialLegend legend = (VectorialLegend) lyrVect.getLegend();
1553
                    if (legend.getLabelField() != null) {
1554
                        lyrVect.createLabelLayer(lyrVect.getRecordset());
1555
                    }
1556

    
1557
                }
1558
            }
1559
        }catch (Exception e) {
1560
                        fmap.addLayerError(xml.getStringProperty("name"));
1561
                                //loadLayerException.addException(e);
1562
                        /*if (layer!=null){
1563
                layer.setActive(false);
1564
                        layer.setVisible(false);
1565
                        this.addLayer(layer);
1566
                }*/
1567
                        //throw new XMLException(e);
1568
            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1569
            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1570
            // logger.debug(e.fillInStackTrace());
1571
            e.printStackTrace();
1572
        }
1573
        }
1574

    
1575
        /**
1576
         * This method calls recursively to its layer children to tell that the layer is going
1577
         * to be removed from the view. This overwrites FLyrDefault.removingThisLayer().
1578
         */
1579
        public void removingThisLayer() {
1580

    
1581
                for (int i=0; i < layers.size(); i++) {
1582
                        FLayer lyr = (FLayer) layers.get(i);
1583
                        if (lyr instanceof FLyrDefault) {
1584
                                ((FLyrDefault) lyr).removingThisLayer();
1585
                        }
1586
                }
1587
        }
1588

    
1589
}