Statistics
| Revision:

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

History | View | Annotate | Download (47.1 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.util.ArrayList;
50
import java.util.Collection;
51
import java.util.Collections;
52
import java.util.Iterator;
53
import java.util.List;
54
import java.util.Vector;
55

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

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

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

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

    
97

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

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

    
122

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

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

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

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

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

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

    
185
                doAddLayer(pos,layer);
186

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

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

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

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

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

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

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

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

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

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

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

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

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

    
300

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

    
314
                };
315

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

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

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

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

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

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

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

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

    
365
                }
366

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

    
388

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

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

    
419
        /**
420
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#draw(java.awt.image.BufferedImage,
421
         *                 java.awt.Graphics2D, com.iver.cit.gvsig.fmap.ViewPort)
422
         */
423
        public void draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
424
                        Cancellable cancel,double scale) throws DriverException {
425
                draw(image,g,viewPort,cancel, scale, null);
426
        }
427
        
428
        
429
        public ComposedLayer draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
430
                        Cancellable cancel,double scale, ComposedLayer group) throws DriverException {
431
            //double scale = getFMap().getScaleView();
432
//                Iterator iter = layers.iterator();
433
//        try
434
//        {
435
                boolean bNeedRecalculateCache = false;
436

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

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

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

    
462
                            if (lyr.isVisible()) {
463

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

479
                                            }
480
                                            else */
481

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

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

    
499
                                                            // Copiamos la imagen actual
500
                                                            BufferedImage buff = new BufferedImage(image.getWidth(), image.getHeight(), image.getType());
501
                                                            WritableRaster w = buff.getRaster();
502
                                                            image.copyData(w);
503
                                                            lyr.setCacheImageDrawnLayers(buff);
504
                                                            System.err.println("RECALCULO LA CACHE CON LO QUE HABIA ANTES DE " + lyr.getName());
505
                                                    }
506
//                                                    }
507
//                                                    else
508
//                                                    {
509
                                                            if (lyr.getCacheImageDrawnLayers() != null)
510
                                                            {
511
                                                                    // Previo a esto hemos tenido que fijar
512
                                                                    // la imagen que queremos usar, en el
513
                                                                    // prepareDrawing de FMap.
514
                                                                    if (lyr.isDirty())
515
                                                                    {
516
                                                                    
517
                                                                               
518
                                                                               ///// CHEMA ComposedLayer
519
                                                                            // Checks for draw group (ComposedLayer)
520
                                                                        if (group != null) {
521
                                                                                // it's going to load a cache image,
522
                                                                                // the current draw isn't needed
523
                                                                                group = null;
524
                                                                        }
525
                                                                           ///// CHEMA ComposedLayer
526
                                                                           
527

    
528
                                                                            g.drawImage(lyr.getCacheImageDrawnLayers(), 0, 0, null);
529
                                                                            System.err.println("Pinto con acelerado lo que hab?a antes de " + lyr.getName());
530
                                                                    }
531
                                                            }
532
//                                                    }
533
                                            }
534
                                            // Si la capa est? "sucia" o alguna de las de abajo est? sucia
535
                                            // hay que volver a dibujar.
536
                                                   if (lyr.isDirty() || bNeedRecalculateCache)
537
                                                   {                                                           
538
                                                           if (!lyr.getFLayerStatus().isDriverLoaded())
539
                                                           {
540
                                                                   continue;
541
                                                           }
542
                                                           
543
                                                           ///// CHEMA ComposedLayer
544
                                                           //lyr.draw(image, g, viewPort, cancel,scale);
545
                                                           //bNeedRecalculateCache = true;
546
                                                           //System.err.println("Pinto sin acelerado " + lyr.getName());
547
                                                           ///// CHEMA ComposedLayer
548
                                                           
549
                                                           ///// CHEMA ComposedLayer
550
                                                           // Checks for draw group (ComposedLayer)
551
                                                           if (group != null) {                                                                   
552
                                                                   if (lyr instanceof FLayers){
553
                                                                           group = ((FLayers)lyr).draw(image, g, viewPort, cancel,scale,group);
554
                                                                           LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
555
                                                                           fmap.fireLayerDrawingEvent(afterEvent);
556
                                                                   } else {
557
                                                                           // If layer can be added to the group, does it
558
                                                                           if (group.canAdd(lyr)) {
559
                                                                                   group.add(lyr);
560
                                                                           } else {
561
                                                                                   // draw the 'pending to draw' layer group
562
                                                                                   group.draw(image, g, viewPort, cancel,scale);
563
                                                                                   
564
                                                                                   // gets a new group instance
565
                                                                                   group = lyr.newComposedLayer();                                                                                   
566
                                                                                   // if layer hasn't group, draws it inmediately 
567
                                                                                   if (group == null) {
568
                                                                                           if (lyr instanceof FLayers){
569
                                                                                                   group = ((FLayers)lyr).draw(image, g, viewPort, cancel,scale,group);
570
                                                                                           } else {
571
                                                                                                   lyr.draw(image, g, viewPort, cancel,scale);
572
                                                                                           }
573
                                                                                           LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
574
                                                                                           fmap.fireLayerDrawingEvent(afterEvent);                                                                                              
575
                                                                                   } else {
576
                                                                                           // add the layer to the group
577
                                                                                           group.setMapContext(fmap);
578
                                                                                           group.add(lyr);
579
                                                                                           
580
                                                                                   }
581
                                                                           }
582
                                                                   }
583
                                                           } else {
584
                                                                   // gets a new group instance
585
                                                                   group = lyr.newComposedLayer();
586
                                                                   // if layer hasn't group, draws it inmediately 
587
                                                                   if (group == null) {
588
                                                                           if (lyr instanceof FLayers){
589
                                                                                   group = ((FLayers)lyr).draw(image, g, viewPort, cancel,scale,group);
590
                                                                           } else {
591
                                                                                   lyr.draw(image, g, viewPort, cancel,scale);
592
                                                                           }
593
                                                                           LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
594
                                                                           fmap.fireLayerDrawingEvent(afterEvent);                                                                           
595
                                                                   } else {
596
                                                                           // adds the layer to the group
597
                                                                           group.setMapContext(fmap);
598
                                                                           group.add(lyr);
599
                                                                   }
600
                                                           }
601
                                                           ///// CHEMA ComposedLayer
602
                                                                bNeedRecalculateCache = true;
603
                                                   }
604
                                    } catch (DriverException e){
605
                                            // fmap.callNewErrorEvent(new ErrorEvent(lyr.getName(), e));
606
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
607
                                            e.printStackTrace();
608
                                            lyr.setAvailable(false);
609
                                            // this.removeLayer(lyr);
610
                                    } catch (Exception e) {
611
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
612
                                            e.printStackTrace();
613
                                            lyr.setAvailable(false);
614
                                    }
615
                                            // }
616
                                            long t2 = System.currentTimeMillis();
617
                                            System.out.println("Layer " + lyr.getName() + " "
618
                                                    + (t2-t1) + " milisecs.");
619
                                            if (!cancel.isCanceled())
620
                                                    lyr.setDirty(false);
621
                            }
622

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

    
630
                         }
631
                        ///// CHEMA ComposedLayer                    
632
                    if (getVirtualLayers() != null) {
633
                            getVirtualLayers().draw(image, g, viewPort, cancel,scale);
634
                    }
635
                    
636
                    ///// CHEMA ComposedLayer
637
                    return group;
638
                    ///// CHEMA ComposedLayer
639
                    
640
//        }
641
//        catch (ConcurrentModificationException e)
642
//        {
643
//            System.err.println(e.getMessage());
644
//        }
645
        }
646
                
647
        /**
648
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#print(java.awt.Graphics2D,
649
         *                 com.iver.cit.gvsig.fmap.ViewPort,
650
         *                 com.iver.utiles.swing.threads.Cancellable)
651
         */
652
        public void print(Graphics2D g, ViewPort viewPort, Cancellable cancel, double scale, PrintRequestAttributeSet properties)
653
                throws DriverException {
654

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

    
662
                }
663
                 if (getVirtualLayers() != null) {
664
            getVirtualLayers().print( g, viewPort, cancel, scale, properties);
665
        }
666
        }
667

    
668
        /**
669
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getFullExtent()
670
         */
671
        public Rectangle2D getFullExtent() throws DriverException {
672
                Rectangle2D rAux = null;
673
                boolean first = true;
674

    
675

    
676
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
677
                        FLayer capa = (FLayer) iter.next();
678
                        try{
679
                        if (first) {
680
                                rAux = capa.getFullExtent();
681
                                first=false;
682
                        } else {
683
                                rAux.add(capa.getFullExtent());
684
                        }
685
                        }catch (Exception e) {
686
                                e.printStackTrace();//TODO hay que revisar para determinar el comportamiento que espera el usuario.
687
                        }
688
                }
689

    
690
                return rAux;
691
        }
692

    
693
        /**
694
         * Llama al m?todo layerAdding de los listeners dados de alta.
695
         *
696
         * @param event
697
         *
698
         * @throws CancelationException
699
         */
700
        protected void callLayerAdding(LayerCollectionEvent event)
701
                throws CancelationException {
702
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
703
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
704
                        ((LayerCollectionListener) iter.next()).layerAdding(event);
705
                }
706
        }
707

    
708
        /**
709
         * Llama al m?todo layerRemoving de los listeners dados de alta.
710
         *
711
         * @param event
712
         *
713
         * @throws CancelationException
714
         */
715
        protected void callLayerRemoving(LayerCollectionEvent event)
716
                throws CancelationException {
717
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
718
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
719
                        ((LayerCollectionListener) iter.next()).layerRemoving(event);
720
                }
721
        }
722

    
723

    
724
        /**
725
         * Llama al m?todo layerMoving de los listeners dados de alta.
726
         *
727
         * @param event
728
         *
729
         * @throws CancelationException
730
         */
731
        protected void callLayerMoving(LayerPositionEvent event)
732
                throws CancelationException {
733
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
734
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
735
                        ((LayerCollectionListener) iter.next()).layerMoving(event);
736
                }
737
        }
738

    
739
        /**
740
         * Llama al m?todo layerAdded de los listeners dados de alta.
741
         *
742
         * @param event
743
         */
744
        protected void callLayerAdded(LayerCollectionEvent event) {
745
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
746
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
747
                        ((LayerCollectionListener) iter.next()).layerAdded(event);
748
                }
749
        }
750

    
751
        /**
752
         * Llama al m?todo layerRemoved de los listeners dados de alta.
753
         *
754
         * @param event
755
         */
756
        protected void callLayerRemoved(LayerCollectionEvent event) {
757
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
758
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
759
                        ((LayerCollectionListener) iter.next()).layerRemoved(event);
760
                }
761
        }
762

    
763
        /**
764
         * Llama al m?todo layerMoved de los listeners dados de alta.
765
         *
766
         * @param event
767
         */
768
        protected void callLayerMoved(LayerPositionEvent event) {
769
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
770
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
771
                        ((LayerCollectionListener) iter.next()).layerMoved(event);
772
                }
773
        }
774

    
775
        /**
776
         * @throws XMLException
777
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getProperties()
778
         */
779
        public XMLEntity getXMLEntity() throws XMLException {
780
                XMLEntity xml = super.getXMLEntity();
781
                xml.putProperty("numLayers", layers.size());
782

    
783
                String[] s = new String[layers.size()];
784

    
785
                for (int i = 0; i < layers.size(); i++) {
786
                        s[i] = ((FLayer) layers.get(i)).getName();
787
                }
788

    
789
                xml.putProperty("LayerNames", s);
790

    
791
                for (int i = 0; i < layers.size(); i++) {
792
                        try{
793
                                xml.addChild(((FLayer) layers.get(i)).getXMLEntity());
794
                        }catch (XMLException e) {
795
                                e.printStackTrace();
796
                        }
797
                }
798

    
799
                return xml;
800
        }
801

    
802
        /**
803
         * DOCUMENT ME!
804
         *
805
         * @param xml DOCUMENT ME!
806
         *
807
         * @throws XMLException
808
         *
809
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
810
         */
811
        public void setXMLEntity03(XMLEntity xml) throws XMLException{
812
                super.setXMLEntity03(xml);
813
                int numLayers = xml.getIntProperty("numLayers");
814

    
815
                String[] s = xml.getStringArrayProperty("LayerNames");
816
                try {
817
                        for (int i = 0; i < numLayers; i++) {
818
                                FLayer layer = null;
819

    
820
                                String className = xml.getChild(i).getStringProperty("className");
821

    
822
                                if (className.equals(FLyrVect.class.getName())) {
823
                                        if (xml.getChild(i).contains("file")) {
824

    
825
                                                        layer = LayerFactory.createLayer(s[i],
826
                                                                        (VectorialFileDriver)LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName")),
827
                                                                        new File(xml.getChild(i).getStringProperty("file")),
828
                                                                        this.getMapContext().getViewPort().getProjection());
829

    
830
                                        } else if (true) {
831
                                                //TODO falta por implementar
832
                                        } else if (true) {
833
                                                //TODO falta por implementar
834
                                        }
835

    
836
                                        layer.setXMLEntity03(xml.getChild(i));
837
                                        // Comprobar que la proyecci?n es la misma que la de FMap
838
                                        // Si no lo es, es una capa que est? reproyectada al vuelo
839
                                        IProjection proj = layer.getProjection();
840
                                        if (proj != null)
841
                                            if (proj != fmap.getProjection())
842
                                            {
843
                                                        ICoordTrans ct = proj.getCT(fmap.getProjection());
844
                                                        layer.setCoordTrans(ct);
845
                                                        System.err.println("coordTrans = " +
846
                                                                proj.getAbrev() + " " +
847
                                                                fmap.getProjection().getAbrev());
848
                                            }
849

    
850
//                                } else if (className.equals(FLyrWMS.class.getName())) {
851
//                                        try {
852
//                                                layer = LayerFactory.createLayer(s[i],
853
//                                                                StringUtilities.string2Rect(
854
//                                                                        xml.getChild(i).getStringProperty("fullExtent")),
855
//                                                                new URL(xml.getChild(i).getStringProperty("host")),
856
//                                                                xml.getChild(i).getStringProperty("format"),
857
//                                                                xml.getChild(i).getStringProperty("layerQuery"),
858
//                                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
859
//                                                                xml.getChild(i).getStringProperty("srs"));
860
//                                        } catch (MalformedURLException e) {
861
//                                                throw new XMLException(e);
862
//                                        }
863
                                } else if (className.equals((FLyrRaster.class.getName()))) {
864
                                        //if (xml.getChild(i).contains("file")) {
865
                                        /*layer = LayerFactory.createLayer(s[i],
866
                                                        xml.getChild(i).getStringProperty("driverName"),
867
                                                        new File(xml.getChild(i).getStringProperty("file")),
868
                                                        this.getFMap().getViewPort().getProjection());*/
869
                                        layer = new FLyrRaster();
870
                                        layer.setName(s[i]);
871
                                        if (!xml.getChild(i).contains("proj"))
872
                                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
873
                                        layer.setXMLEntity03(xml.getChild(i));
874
                                        try {
875
                                                        layer.load();
876

    
877
                                        } catch (DriverIOException e) {
878
                                                throw new XMLException(e);
879
                                        }
880

    
881
                                }else if (className.equals((FLayers.class.getName()))) {
882
                                        layer = new FLayers(getMapContext(),this);
883
                                        layer.setXMLEntity(xml.getChild(i));
884
                                } else {
885
                                        // Capas Nuevas (externas)
886
                                        try {
887
                                                Class clase = Class.forName(className);
888
                                                layer = (FLayer) clase.newInstance();
889
                                                layer.setName(s[i]);
890
                                                layer.setXMLEntity03(xml.getChild(i));
891
                                                try {
892
                                                                layer.load();
893
                                                } catch (DriverIOException e) {
894
                                                        throw new XMLException(e);
895
                                                }
896
                                        } catch (Exception e) {
897
                                                //e.printStackTrace();
898
                                                throw new XMLException(e);
899
                                        }
900
                                }
901

    
902
                                this.addLayer(layer);
903
                        }
904
                } /*azabala-modificaciones en layerfactory-
905
                catch (DriverException e) {
906
                        throw new XMLException(e);
907
                }*/
908
                catch (DriverLoadException e) {
909
            throw new XMLException(e);
910
        }
911

    
912
        }
913

    
914
        /**
915
         * DOCUMENT ME!
916
         *
917
         * @param xml DOCUMENT ME!
918
         *
919
         * @throws XMLException
920
         *
921
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
922
         */
923
        public void setXMLEntity(XMLEntity xml) throws XMLException{
924
                super.setXMLEntity(xml);
925
                //LoadLayerException loadLayerException=new LoadLayerException();
926
                int numLayers = xml.getIntProperty("numLayers");
927

    
928
                String[] s = xml.getStringArrayProperty("LayerNames");
929
                // try {
930
                fmap.clearErrors();
931
                        for (int i = 0; i < numLayers; i++) {
932
                                this.addLayerFromXML(xml.getChild(i),s[i]);
933

    
934

    
935
                        }
936
                /* } catch (DriverException e) {
937
                        throw new XMLException(e);
938
                } */
939
                /*if (loadLayerException.getExceptions().size()>0){
940
                        throw loadLayerException;
941
                }*/
942
        }
943

    
944
        /**
945
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor,
946
         *                 FBitSet)
947
         */
948
        public void process(FeatureVisitor visitor, FBitSet subset)
949
                throws DriverException, VisitException {
950
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
951
                        FLayer layer = (FLayer) iter.next();
952

    
953
                        if (layer instanceof VectorialData) {
954
                                ((VectorialData) layer).process(visitor, subset);
955
                        }
956
                }
957
        }
958

    
959
        /**
960
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor)
961
         */
962
        public void process(FeatureVisitor visitor)
963
                throws DriverException, VisitException {
964
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
965
                        FLayer layer = (FLayer) iter.next();
966

    
967
                        if (layer instanceof FLayers){
968
                                FLayers lyrs=(FLayers)layer;
969
                                for (int i=0;i<lyrs.getLayersCount();i++){
970
                                        FLayer lyr=lyrs.getLayer(i);
971
                                        if (lyr.isActive()) {
972
                                                if (lyr instanceof VectorialData) {
973
                                                        ((VectorialData) lyr).process(visitor);
974
                                                }
975
                                        }
976
                                }
977
                        }
978
                        if (layer.isActive()) {
979
                                if (layer instanceof VectorialData) {
980
                                        ((VectorialData) layer).process(visitor);
981
                                }
982
                        }
983
                }
984
        }
985
        /**
986
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor, Rectangle2D)
987
         */
988
        public void process(FeatureVisitor visitor, Rectangle2D rect) throws DriverException, VisitException {
989
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
990
                        FLayer layer = (FLayer) iter.next();
991

    
992
                        if (layer.isActive()) {
993
                                if (layer instanceof VectorialData) {
994
                                        ((VectorialData) layer).process(visitor, rect);
995
                                }
996
                        }
997
                }
998

    
999
        }
1000

    
1001
        /**
1002
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMapContext()
1003
         */
1004
        public MapContext getMapContext() {
1005
                return fmap;
1006
        }
1007

    
1008
        /* (non-Javadoc)
1009
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#setCoordTrans(org.cresques.cts.ICoordTrans)
1010
         */
1011
        public void setCoordTrans(ICoordTrans ct) {
1012
                super.setCoordTrans(ct);
1013

    
1014
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1015
                        FLayer layer = (FLayer) iter.next();
1016
                        layer.setCoordTrans(ct);
1017
                }
1018
        }
1019

    
1020
        /**
1021
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllActives(boolean)
1022
         */
1023
        public void setAllActives(boolean active) {
1024
                FLayer lyr;
1025

    
1026
                for (int i = 0; i < layers.size(); i++) {
1027
                        lyr = ((FLayer) layers.get(i));
1028
                        lyr.setActive(active);
1029

    
1030
                        if (lyr instanceof LayerCollection) {
1031
                                ((LayerCollection) lyr).setAllActives(active);
1032
                        }
1033
                }
1034
        }
1035

    
1036
        /**
1037
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#getActives()
1038
         */
1039
        public FLayer[] getActives() {
1040
                ArrayList ret = new ArrayList();
1041
                LayersIterator it = new LayersIterator(this) {
1042

    
1043
                        public boolean evaluate(FLayer layer) {
1044
                                return layer.isActive();
1045
                        }
1046

    
1047
                };
1048

    
1049
                while (it.hasNext())
1050
                {
1051
                        ret.add(it.next());
1052
                }
1053
                return (FLayer[]) ret.toArray(new FLayer[0]);
1054
        }
1055

    
1056
    /* (non-Javadoc)
1057
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMinScale()
1058
     */
1059
    public double getMinScale() {
1060
        return -1; // La visibilidad o no la controla cada capa
1061
                // dentro de una colecci?n
1062
    }
1063

    
1064
    /* (non-Javadoc)
1065
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMaxScale()
1066
     */
1067
    public double getMaxScale() {
1068
        return -1;
1069
    }
1070
    public void setMinScale(double minScale)
1071
    {
1072
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1073
                        FLayer lyr = (FLayer) iter.next();
1074
                        lyr.setMinScale(minScale);
1075
                }
1076
    }
1077
    public void setMaxScale(double maxScale)
1078
    {
1079
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1080
                        FLayer lyr = (FLayer) iter.next();
1081
                        lyr.setMinScale(maxScale);
1082
                }
1083
    }
1084
    public void setActive(boolean b){
1085
            super.setActive(b);
1086
            for (int i=0;i<layers.size();i++){
1087
                    ((FLayer)layers.get(i)).setActive(b);
1088
            }
1089
    }
1090

    
1091
        /* (non-Javadoc)
1092
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#addLayerListener(com.iver.cit.gvsig.fmap.layers.LayerListener)
1093
         */
1094
        public boolean addLayerListener(LayerListener o) {
1095
                for (int i = 0; i < layers.size(); i++)
1096
                        ((FLayer) layers.get(i)).addLayerListener(o);
1097
                return true;
1098
        }
1099

    
1100
        public XMLItem[] getInfo(Point p, double tolerance, Cancellable cancel) throws DriverException {
1101
                int i;
1102
                Vector items = new Vector();
1103
                FLayer layer;
1104
                XMLItem[] aux;
1105
                for (i = 0; i < this.layers.size(); i++){
1106
                        layer = (FLayer)layers.get(i);
1107
                        if (layer instanceof InfoByPoint){
1108
                                InfoByPoint queryable_layer = (InfoByPoint) layer;
1109
                                aux = queryable_layer.getInfo(p, tolerance, null);
1110
                                if (!(queryable_layer instanceof FLayers)){
1111
                                        for(int j = 0; j < aux.length; j++){
1112
                                                items.add(aux[j]);
1113
                                        }
1114
                                }
1115
                        }
1116
                }
1117
                return (XMLItem[])items.toArray(new XMLItem[0]);
1118

    
1119
//                for (i = 0; i < this.layers.size(); i++){
1120
//                        FLayer laCapa = (FLayer) layers.get(i);
1121
//                        if (laCapa instanceof FLyrVect){
1122
//                        }
1123
//                        else if (laCapa instanceof RasterOperations) {
1124
//                                try {
1125
//                                        RasterOperations layer = (RasterOperations) laCapa;
1126
//                                        sb.append(layer.getInfo(p, tolerance));
1127
//                                } catch (DriverException e) {
1128
//                                        e.printStackTrace();
1129
//                                }
1130
//                        }
1131
//                        else if (laCapa instanceof InfoByPoint) {
1132
//                                try {
1133
//                                        InfoByPoint layer = (InfoByPoint) laCapa;
1134
//                                        sb.append(layer.getInfo(p, tolerance));
1135
//                                } catch (DriverException e) {
1136
//                                        e.printStackTrace();
1137
//                                }
1138
//                        }
1139
//                }
1140

    
1141
        }
1142

    
1143
        public ImageIcon getTocImageIcon() {
1144
                return new ImageIcon(MapControl.class.getResource("images/layerGroup.png"));
1145
        }
1146

    
1147
        public boolean isDirty() {
1148
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1149
                        FLayer lyr = (FLayer) iter.next();
1150
                        if (lyr.isDirty())
1151
                                return true;
1152
                }
1153
                return false;
1154
        }
1155

    
1156
        public void setDirty(boolean dirty) {
1157
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1158
                        FLayer lyr = (FLayer) iter.next();
1159
                        lyr.setDirty(dirty);
1160
                }
1161

    
1162
        }
1163

    
1164
        public boolean addLayerFromXMLEntity(XMLEntity xml, String name) {
1165
                fmap.clearErrors();
1166
                this.addLayerFromXML(xml,name);
1167

    
1168
                return (fmap.getLayersError().size() == 0);
1169

    
1170
        }
1171

    
1172
        private void addLayerFromXML(XMLEntity xml, String name) {
1173
                FLayer layer = null;
1174
                long t1 = System.currentTimeMillis();
1175
                try {
1176
                if (name == null) name = xml.getName();
1177

    
1178

    
1179
                String className = xml.getStringProperty("className");
1180
                //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,
1181
                //ya que los drivers de una FLyrAnnotation no sabemos cual es puede ser cualquier Driver Vectorial.
1182
                if (className.equals(FLyrVect.class.getName()) || className.equals(FLyrAnnotation.class.getName())) {
1183
                        String type = xml.getStringProperty("type");
1184
                        if ("vectorial".equals(type)){
1185
                                //String recordsetName = xml.getChild(i).getStringProperty("recordset-name");
1186
                IProjection proj = null;
1187
                if (xml.contains("proj")) {
1188
                    proj = CRSFactory.getCRS(xml.getStringProperty("proj"));
1189
                }
1190
                else
1191
                {
1192
                    proj = this.getMapContext().getViewPort().getProjection();
1193
                }
1194
                                if (xml.contains("file")) {
1195
                                        Driver d;
1196
                                        try {
1197
                                                d = LayerFactory.getDM().getDriver(xml.getStringProperty("driverName"));
1198
                                        } catch (DriverLoadException e1) {
1199
                                                throw new XMLException(e1);
1200
                                        }
1201
                                        layer = LayerFactory.createLayer(name, (VectorialFileDriver) d,
1202
                                                                                                        new File(xml.getStringProperty("file")),
1203
                                                                                                        proj);
1204

    
1205

    
1206
                                }
1207
                if (xml.contains("db")) {
1208

    
1209
                    String driverName = xml.getStringProperty("db");
1210
                    VectorialDatabaseDriver driver;
1211
                    try {
1212
                        driver = (VectorialDatabaseDriver) LayerFactory.getDM().getDriver(driverName);
1213
                        //Hay que separar la carga de los datos del XMLEntity del load.
1214
                        driver.setXMLEntity(xml.getChild(2));
1215

    
1216
                        boolean loadOk = false;
1217
                        try {
1218
                                ((DefaultDBDriver)driver).load();
1219
                                if (((DefaultDBDriver)driver).getConnection() != null) {
1220
                                        loadOk = true;
1221
                                }
1222

    
1223
                        } catch (DriverException e) {
1224
                                e.printStackTrace();
1225
                                loadOk = false;
1226

    
1227
                        }
1228

    
1229
                        layer = LayerFactory.createDBLayer(driver, name, proj);
1230
                        if (!loadOk) {
1231
                                layer.setAvailable(false);
1232
                        }
1233

    
1234
                    } catch (DriverLoadException e) {
1235
                        e.printStackTrace();
1236
                        throw new XMLException(e);
1237
                    }
1238

    
1239
                }
1240
                // Clases con algun driver gen?rico creado por otro
1241
                // programador
1242
                if (xml.contains("other")) {
1243

    
1244
                    String driverName = xml.getStringProperty("other");
1245
                    VectorialDriver driver = null;
1246
                    try {
1247
                        driver = (VectorialDriver) LayerFactory.getDM().getDriver(driverName);
1248
                    } catch (DriverLoadException e) {
1249
                        // Si no existe ese driver, no pasa nada.
1250
                        // Puede que el desarrollador no quiera que
1251
                        // aparezca en el cuadro de di?logo y ha metido
1252
                        // el jar con sus clases en nuestro directorio lib.
1253
                        // Intentamos cargar esa clase "a pelo".
1254
                        if (xml.getChild(2).contains("className"))
1255
                        {
1256
                            String className2 = xml.getChild(2).getStringProperty("className");
1257
                            try {
1258
                                driver = (VectorialDriver) Class.forName(className2).newInstance();
1259
                            } catch (Exception e1) {
1260
                                throw new XMLException(e1);
1261
                            }
1262
                        }
1263
                    } catch (NullPointerException npe) {
1264
                        // Si no existe ese driver, no pasa nada.
1265
                        // Puede que el desarrollador no quiera que
1266
                        // aparezca en el cuadro de di?logo y ha metido
1267
                        // el jar con sus clases en nuestro directorio lib.
1268
                        // Intentamos cargar esa clase "a pelo".
1269
                        if (xml.getChild(2).contains("className"))
1270
                        {
1271
                            String className2 = xml.getChild(2).getStringProperty("className");
1272
                            try {
1273
                                driver = (VectorialDriver) Class.forName(className2).newInstance();
1274
                            } catch (Exception e1) {
1275
                                throw new XMLException(e1);
1276
                            }
1277
                        }
1278
                    }
1279
                    if (driver instanceof IPersistance)
1280
                    {
1281
                        IPersistance persist = (IPersistance) driver;
1282
                        persist.setXMLEntity(xml.getChild(2));
1283
                    }
1284
                    layer = LayerFactory.createLayer(name, driver, proj);
1285
                }
1286

    
1287
                        }
1288

    
1289
                        //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,
1290
                        //ya que los drivers de una FLyrAnnotation no sabemos cual es puede ser cualquier Driver Vectorial.
1291
                        if (className.equals(FLyrAnnotation.class.getName())){
1292
                                layer=FLyrAnnotation.createLayerFromVect((FLyrVect)layer);
1293
                        }
1294

    
1295

    
1296
                        layer.setXMLEntity(xml);
1297

    
1298
//                } else if (className.equals(FLyrWMS.class.getName())) {
1299
//                        try {
1300
//                                layer = LayerFactory.createLayer(s[i],
1301
//                                                StringUtilities.string2Rect(
1302
//                                                        xml.getChild(i).getStringProperty("fullExtent")),
1303
//                                                new URL(xml.getChild(i).getStringProperty("host")),
1304
//                                                xml.getChild(i).getStringProperty("format"),
1305
//                                                xml.getChild(i).getStringProperty("layerQuery"),
1306
//                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
1307
//                                                xml.getChild(i).getStringProperty("srs"));
1308
//                                layer.setXMLEntity(xml.getChild(i));
1309
//                        } catch (MalformedURLException e) {
1310
//                                throw new XMLException(e);
1311
//                        }
1312
                } else if (className.equals((FLyrRaster.class.getName()))) {
1313
                        //if (xml.getChild(i).contains("file")) {
1314
                        /*layer = LayerFactory.createLayer(s[i],
1315
                                        xml.getChild(i).getStringProperty("driverName"),
1316
                                        new File(xml.getChild(i).getStringProperty("file")),
1317
                                        this.getFMap().getViewPort().getProjection());*/
1318
                        layer = new FLyrRaster();
1319
                        layer.setName(name);
1320
                        if (!xml.contains("proj"))
1321
                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
1322
                        layer.setXMLEntity(xml);
1323
                        try {
1324
                                layer.load();
1325
                        } catch (DriverIOException e) {
1326
                                throw new XMLException(e);
1327
                        }
1328

    
1329
                }else if (className.equals((FLayers.class.getName()))) {
1330
                        layer = new FLayers(getMapContext(),this);
1331
                        layer.setXMLEntity(xml);
1332
                } else {
1333
                        // Capas Nuevas (externas)
1334
                                Class clase = Class.forName(className);
1335
                                layer = (FLayer) clase.newInstance();
1336
                                layer.setName(name);
1337
                                layer.setXMLEntity(xml);
1338
                                try {
1339
                                        layer.load();
1340
                                }catch (DriverIOException e) {
1341
                                        throw new XMLException(e);
1342
                                }
1343

    
1344
                }
1345

    
1346
                this.addLayer(layer);
1347
                long t2 = System.currentTimeMillis();
1348
                logger.debug("layer: "+ layer.getName() +" loaded. " + (t2-t1) + " msecs.");
1349
                // Comprobar que la proyecci?n es la misma que la de FMap
1350
        // Si no lo es, es una capa que est? reproyectada al vuelo
1351
        IProjection proj = layer.getProjection();
1352
        if ((proj != null))
1353
            if (proj != getMapContext().getProjection())
1354
            {
1355
                ICoordTrans ct = proj.getCT(getMapContext().getProjection());
1356
                // TODO: REVISAR CON LUIS
1357
                // Se lo fijamos a todas, luego cada una que se reproyecte
1358
                // si puede, o que no haga nada
1359
                layer.setCoordTrans(ct);
1360
                // NOTA: DESPU?S DE ESTO DEBER?AMOS CREAR LAS ETIQUETAS
1361
                // SI ES NECESARIO.
1362
                // TODO: REVISAR A FONDO ESTO, PORQUE LAS ETIQUETAS SE CREAN
1363
                // 2 VECES SI HAY REPROYECC?N
1364
                if (layer instanceof FLyrVect)
1365
                {
1366
                    FLyrVect lyrVect = (FLyrVect)layer;
1367
                    VectorialLegend legend = (VectorialLegend) lyrVect.getLegend();
1368
                    if (legend.getLabelField() != null) {
1369
                        lyrVect.createLabelLayer(lyrVect.getRecordset());
1370
                    }
1371

    
1372
                }
1373
            }
1374
        }catch (Exception e) {
1375
                        fmap.addLayerError(xml.getStringProperty("name"));
1376
                                //loadLayerException.addException(e);
1377
                        /*if (layer!=null){
1378
                layer.setActive(false);
1379
                        layer.setVisible(false);
1380
                        this.addLayer(layer);
1381
                }*/
1382
                        //throw new XMLException(e);
1383
            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1384
            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1385
            // logger.debug(e.fillInStackTrace());
1386
            e.printStackTrace();
1387
        }
1388
        }
1389

    
1390
        private void addLayerFromXMLNew(XMLEntity xml, String name) {
1391
                FLayer layer = null;
1392

    
1393

    
1394
                try {
1395
                String className = xml.getStringProperty("className");
1396

    
1397
                if (className.equals((FLayers.class.getName()))){
1398
                        layer = new FLayers(getMapContext(),this);
1399
                } else {
1400
//                         Por compatibilidad
1401
                        if (className.equals(FLyrVect.class.getName())) {
1402
                                if (xml.contains("file")) {
1403
                                        layer = new FLayerFileVectorial();
1404
                                } else if (xml.contains("db")) {
1405
                                        try {
1406
                                                layer = (FLayer)((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create("com.iver.cit.gvsig.fmap.layers.FLayerJDBCVectorial");
1407
                                        } catch (Exception e) {
1408
                                                throw new XMLException(new Exception("No se tiene registrada la capa de tipo JDBC"));
1409
                                        }
1410
                                        //className = FLayerJDBCVectorial.class.getName();
1411
                                } else if (xml.contains("other")){
1412
                                        layer = new FLayerGenericVectorial();
1413
                                } else {
1414
                                        throw new XMLException(new Exception("Capa vectorial de tipo no reconocido"));
1415
                                }
1416
//                                Fin por compatibilidad
1417
                        } else {
1418
                                try {
1419
                                        layer = (FLayer)(((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create(className));
1420
                                } catch (Exception e) {
1421
                                        //puende que no este registrada como punto de extension
1422
                                        Class clase = Class.forName(className);
1423
                                        layer = (FLayer) clase.newInstance();
1424
                                        // FIXME: Hacemos algo aqui o dejamos que suba el error?
1425
                                }
1426
                        }
1427

    
1428
                }
1429
                layer.setXMLEntity(xml);
1430
                if (name != null) layer.setName(name);
1431
                try {
1432
                        layer.load();
1433
                }catch (DriverIOException e) {
1434
                        throw new XMLException(e);
1435
                }
1436

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

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

    
1480
        /**
1481
         * This method calls recursively to its layer children to tell that the layer is going
1482
         * to be removed from the view. This overwrites FLyrDefault.removingThisLayer().
1483
         */
1484
        public void removingThisLayer() {
1485

    
1486
                for (int i=0; i < layers.size(); i++) {
1487
                        FLayer lyr = (FLayer) layers.get(i);
1488
                        if (lyr instanceof FLyrDefault) {
1489
                                ((FLyrDefault) lyr).removingThisLayer();
1490
                        }
1491
                }
1492
        }
1493

    
1494
}