Statistics
| Revision:

root / trunk / libraries / libFMap / src / com / iver / cit / gvsig / fmap / layers / FLayers.java @ 7562

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

    
55
import javax.swing.ImageIcon;
56

    
57
import org.apache.log4j.Logger;
58
import org.cresques.cts.ICoordTrans;
59
import org.cresques.cts.IProjection;
60

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

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

    
94

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

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

    
119

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

    
126
                for (int i = 0; i < layers.size(); i++) {
127
                        lyr = ((FLayer) layers.get(i));
128
                        lyr.setVisible(visible);
129

    
130
                        if (lyr instanceof LayerCollection) {
131
                                ((LayerCollection) lyr).setAllVisibles(visible);
132
                        }
133
                }
134
        }
135

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

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

    
175
                        if (layer instanceof FLayers){
176
                                FLayers layers=(FLayers)layer;
177
                                fmap.addAsCollectionListener(layers);
178
                        }
179
                        callLayerAdding(LayerCollectionEvent.createLayerAddingEvent(layer));
180
                //}
181

    
182
                doAddLayer(pos,layer);
183

    
184
                //if (!layerDef.isUnavailable()) {
185
                        callLayerAdded(LayerCollectionEvent.createLayerAddedEvent(layer));
186
                //}
187
        }
188

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

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

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

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

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

    
252
                for (int i = 0; i < layers.size(); i++) {
253
                        lyr = ((FLayer) layers.get(i));
254

    
255
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
256
                                removeLayer(i);
257

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

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

    
282
                                if (layer instanceof FLayers){
283
                                        FLayers layers=(FLayers)layer;
284
                                        fmap.addAsCollectionListener(layers);
285
                                }
286
                                callLayerAdding(LayerCollectionEvent.createLayerAddingEvent(layer));
287

    
288
                                layers.add(i,layer);
289
                                layer.setParentLayer(this);
290

    
291
                                callLayerAdded(LayerCollectionEvent.createLayerAddedEvent(layer));
292
                                break;
293
                        }
294
                }
295
        }
296

    
297

    
298
        /**
299
         * Obtiene el array de capas visibles que penden del arbol cuya ra?z es
300
         * este nodo
301
         *
302
         * @return Vector de FLayer.
303
         */
304
        public FLayer[] getVisibles() {
305
                ArrayList array = new ArrayList();
306

    
307
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
308
                        if (((FLayer) iter.next()).isVisible()) {
309
                                array.add((FLayer) iter.next());
310
                        }
311
                }
312

    
313
                return (FLayer[]) array.toArray(new FLayer[0]);
314
        }
315

    
316
        /**
317
         * Obtiene el hijo i-?simo (de abajo a arriba) directo de esta colecci?n.
318
         *
319
         * @param index ?ndice.
320
         *
321
         * @return capa seleccionada.
322
         */
323
        public FLayer getLayer(int index) {
324
                return (FLayer) layers.get(index);
325
        }
326

    
327
        /**
328
         * M?todo de conveniencia para buscar una capa por su nombre Es conveniente
329
         * usar getLayer(int) siempre que se pueda, es m?s directo.
330
         *
331
         * @param layerName nombre.
332
         *
333
         * @return capa seleccionada.
334
         */
335
        public FLayer getLayer(String layerName) {
336
                FLayer lyr;
337
                FLayer lyr2;
338
                ArrayList layerList;
339

    
340
                for (int i = 0; i < layers.size(); i++) {
341
                        lyr = ((FLayer) layers.get(i));
342

    
343
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
344
                                        return lyr;
345
                        }
346

    
347
                        layerList = new ArrayList();
348
                        splitLayerGroup(lyr,layerList);
349
                        for(int j = 0; j<layerList.size(); j++ )
350
                        {
351
                                lyr2 = ((FLayer)layerList.get(j));
352
                                if (lyr2.getName().compareToIgnoreCase(layerName) == 0) {
353
                                        return lyr2;
354
                                }
355
                        }
356
                }
357

    
358
                return null;
359
        }
360

    
361
        // added by Laura
362
        // this is to to split up a layer group in order to get a layer by name
363
        // when there are layergroups.
364
        private void splitLayerGroup(FLayer layer, ArrayList result)
365
        {
366
                int i;
367
                FLayers layerGroup;
368
                if (layer instanceof FLayers)
369
                {
370
                        layerGroup = (FLayers)layer;
371
                        for (i=0; i < layerGroup.getLayersCount(); i++ )
372
                        {
373
                                splitLayerGroup(layerGroup.getLayer(i),result);
374
                        }
375
                }
376
                else
377
                {
378
                        result.add(layer);
379
                }
380
        }
381

    
382
        /**
383
         * Obtiene el n?mero de capas que hay en su mismo nivel Es decir, no cuenta
384
         * las subcapas de un FLayers
385
         *
386
         * @return n?mero de capas.
387
         */
388
        public int getLayersCount() {
389
                return layers.size();
390
        }
391

    
392
        /**
393
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#draw(java.awt.image.BufferedImage,
394
         *                 java.awt.Graphics2D, com.iver.cit.gvsig.fmap.ViewPort)
395
         */
396
        public void draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
397
                Cancellable cancel,double scale) throws DriverException {
398
            //double scale = getFMap().getScaleView();
399
//                Iterator iter = layers.iterator();
400
//        try
401
//        {
402
                boolean bNeedRecalculateCache = false;
403
//                    while (iter.hasNext())
404
//                    {
405
                     for (int i=0; i < layers.size(); i++) {
406
                if (cancel.isCanceled())
407
                    break; // M?s que nada porque las capas raster no son interrumpibles por ahora.
408
//                            FLayer lyr = (FLayer) iter.next();
409
                            FLayer lyr = (FLayer) layers.get(i);
410
                    /*        if (lyr instanceof FLyrVect && ((FLyrVect)lyr).isBroken()){
411
                                    continue;
412
                            }
413
                    */
414
                            LayerDrawEvent beforeEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_BEFORE_DRAW);
415
                            fmap.fireLayerDrawingEvent(beforeEvent);
416
                        if ((lyr.isDirty()) && (lyr.isCachingDrawnLayers() == false))
417
                                bNeedRecalculateCache = true;
418

    
419
                            if (lyr.isVisible()) {
420

    
421
                                    long t1 = System.currentTimeMillis();
422
                                    System.err.println("Layer " + lyr.getName() + " dirty=" + lyr.isDirty());
423
                                    // synchronized (this) {
424
                                            //Sincronizaci?n del m?todo dibujar de cada Layer, esto es posible hacerlo de otra forma,
425
                                            //pero de momento se queda as?, para solucionar el refresco de una misma vista que est? a?adida en el Layout.
426
                                    try{
427
                                            /* if (lyr instanceof IComposedDrawing)
428
                                            {
429
                                                    // Acumulamos las peticiones hasta que sea
430
                                                    // otro servidor o otro tipo de capa o la ?ltima
431
                                                    // Si hay que dibujar:
432
                                                    lyr.draw(image, g, viewPort, cancel,scale);
433
                                                    // Si hay que acumlar:
434
                                                    lyr.acumulateDrawing(antLayer);
435

436
                                            }
437
                                            else */
438

    
439
                                             if (lyr.isCachingDrawnLayers())
440
                                            {
441
                                                    if ((bNeedRecalculateCache) || (lyr.getCacheImageDrawnLayers()==null))
442
                                                    {
443
                                                    //if (bNeedRecalculateCache)
444
                                                    // {
445
                                                            // Copiamos la imagen actual
446
                                                            BufferedImage buff = new BufferedImage(image.getWidth(), image.getHeight(), image.getType());
447
                                                            WritableRaster w = buff.getRaster();
448
                                                            image.copyData(w);
449
                                                            lyr.setCacheImageDrawnLayers(buff);
450
                                                            System.err.println("RECALCULO LA CACHE CON LO QUE HABIA ANTES DE " + lyr.getName());
451
                                                    }
452
//                                                    }
453
//                                                    else
454
//                                                    {
455
                                                            if (lyr.getCacheImageDrawnLayers() != null)
456
                                                            {
457
                                                                    // Previo a esto hemos tenido que fijar
458
                                                                    // la imagen que queremos usar, en el
459
                                                                    // prepareDrawing de FMap.
460
                                                                    if (lyr.isDirty())
461
                                                                    {
462
                                                                            g.drawImage(lyr.getCacheImageDrawnLayers(), 0, 0, null);
463
                                                                            System.err.println("Pinto con acelerado lo que hab?a antes de " + lyr.getName());
464
                                                                    }
465
                                                            }
466
//                                                    }
467
                                            }
468
                                            // Si la capa est? "sucia" o alguna de las de abajo est? sucia
469
                                            // hay que volver a dibujar.
470
                                                   if (lyr.isDirty() || bNeedRecalculateCache)
471
                                                   {
472
                                                           lyr.draw(image, g, viewPort, cancel,scale);
473
                                                           bNeedRecalculateCache = true;
474
                                                   }
475
                                    } catch (DriverException e){
476
                                            // fmap.callNewErrorEvent(new ErrorEvent(lyr.getName(), e));
477
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
478
                                            e.printStackTrace();
479
                                            lyr.setAvailable(false);
480
                                            // this.removeLayer(lyr);
481
                                    } catch (Exception e) {
482
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
483
                                            e.printStackTrace();
484
                                            lyr.setAvailable(false);
485
                                    }
486
                                            // }
487
                                            long t2 = System.currentTimeMillis();
488
                                            System.out.println("Layer " + lyr.getName() + " "
489
                                                    + (t2-t1) + " milisecs.");
490
                                            lyr.setDirty(false);
491
                            }
492
                            LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
493
                            fmap.fireLayerDrawingEvent(afterEvent);
494

    
495
                    }
496
                    if (getVirtualLayers() != null) {
497
                            getVirtualLayers().draw(image, g, viewPort, cancel,scale);
498
                    }
499
//        }
500
//        catch (ConcurrentModificationException e)
501
//        {
502
//            System.err.println(e.getMessage());
503
//        }
504
        }
505

    
506
        /**
507
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#print(java.awt.Graphics2D,
508
         *                 com.iver.cit.gvsig.fmap.ViewPort,
509
         *                 com.iver.utiles.swing.threads.Cancellable)
510
         */
511
        public void print(Graphics2D g, ViewPort viewPort, Cancellable cancel,double scale)
512
                throws DriverException {
513

    
514
        // TODO: A la hora de imprimir, isWithinScale falla, porque est?
515
        // calculando la escala en pantalla, no para el layout.
516
        // Revisar esto.
517

    
518
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
519
                        FLayer lyr = (FLayer) iter.next();
520
                        lyr.print(g, viewPort, cancel,scale);
521

    
522
                }
523
                 if (getVirtualLayers() != null) {
524
            getVirtualLayers().print( g, viewPort, cancel,scale);
525
        }
526
        }
527

    
528
        /**
529
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getFullExtent()
530
         */
531
        public Rectangle2D getFullExtent() throws DriverException {
532
                Rectangle2D rAux = null;
533
                boolean first = true;
534

    
535

    
536
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
537
                        FLayer capa = (FLayer) iter.next();
538
                        try{
539
                        if (first) {
540
                                rAux = capa.getFullExtent();
541
                                first=false;
542
                        } else {
543
                                rAux.add(capa.getFullExtent());
544
                        }
545
                        }catch (Exception e) {
546
                                e.printStackTrace();//TODO hay que revisar para determinar el comportamiento que espera el usuario.
547
                        }
548
                }
549

    
550
                return rAux;
551
        }
552

    
553
        /**
554
         * Llama al m?todo layerAdding de los listeners dados de alta.
555
         *
556
         * @param event
557
         *
558
         * @throws CancelationException
559
         */
560
        private void callLayerAdding(LayerCollectionEvent event)
561
                throws CancelationException {
562
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
563
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
564
                        ((LayerCollectionListener) iter.next()).layerAdding(event);
565
                }
566
        }
567

    
568
        /**
569
         * Llama al m?todo layerRemoving de los listeners dados de alta.
570
         *
571
         * @param event
572
         *
573
         * @throws CancelationException
574
         */
575
        private void callLayerRemoving(LayerCollectionEvent event)
576
                throws CancelationException {
577
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
578
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
579
                        ((LayerCollectionListener) iter.next()).layerRemoving(event);
580
                }
581
        }
582

    
583

    
584
        /**
585
         * Llama al m?todo layerMoving de los listeners dados de alta.
586
         *
587
         * @param event
588
         *
589
         * @throws CancelationException
590
         */
591
        private void callLayerMoving(LayerPositionEvent event)
592
                throws CancelationException {
593
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
594
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
595
                        ((LayerCollectionListener) iter.next()).layerMoving(event);
596
                }
597
        }
598

    
599
        /**
600
         * Llama al m?todo layerAdded de los listeners dados de alta.
601
         *
602
         * @param event
603
         */
604
        private void callLayerAdded(LayerCollectionEvent event) {
605
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
606
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
607
                        ((LayerCollectionListener) iter.next()).layerAdded(event);
608
                }
609
        }
610

    
611
        /**
612
         * Llama al m?todo layerRemoved de los listeners dados de alta.
613
         *
614
         * @param event
615
         */
616
        private void callLayerRemoved(LayerCollectionEvent event) {
617
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
618
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
619
                        ((LayerCollectionListener) iter.next()).layerRemoved(event);
620
                }
621
        }
622

    
623
        /**
624
         * Llama al m?todo layerMoved de los listeners dados de alta.
625
         *
626
         * @param event
627
         */
628
        private void callLayerMoved(LayerPositionEvent event) {
629
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
630
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
631
                        ((LayerCollectionListener) iter.next()).layerMoved(event);
632
                }
633
        }
634

    
635
        /**
636
         * @throws XMLException
637
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getProperties()
638
         */
639
        public XMLEntity getXMLEntity() throws XMLException {
640
                XMLEntity xml = super.getXMLEntity();
641
                xml.putProperty("numLayers", layers.size());
642

    
643
                String[] s = new String[layers.size()];
644

    
645
                for (int i = 0; i < layers.size(); i++) {
646
                        s[i] = ((FLayer) layers.get(i)).getName();
647
                }
648

    
649
                xml.putProperty("LayerNames", s);
650

    
651
                for (int i = 0; i < layers.size(); i++) {
652
                        xml.addChild(((FLayer) layers.get(i)).getXMLEntity());
653
                }
654

    
655
                return xml;
656
        }
657

    
658
        /**
659
         * DOCUMENT ME!
660
         *
661
         * @param xml DOCUMENT ME!
662
         *
663
         * @throws XMLException
664
         *
665
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
666
         */
667
        public void setXMLEntity03(XMLEntity xml) throws XMLException{
668
                super.setXMLEntity03(xml);
669
                int numLayers = xml.getIntProperty("numLayers");
670

    
671
                String[] s = xml.getStringArrayProperty("LayerNames");
672
                try {
673
                        for (int i = 0; i < numLayers; i++) {
674
                                FLayer layer = null;
675

    
676
                                String className = xml.getChild(i).getStringProperty("className");
677

    
678
                                if (className.equals(FLyrVect.class.getName())) {
679
                                        if (xml.getChild(i).contains("file")) {
680

    
681
                                                        layer = LayerFactory.createLayer(s[i],
682
                                                                        (VectorialFileDriver)LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName")),
683
                                                                        new File(xml.getChild(i).getStringProperty("file")),
684
                                                                        this.getMapContext().getViewPort().getProjection());
685

    
686
                                        } else if (true) {
687
                                                //TODO falta por implementar
688
                                        } else if (true) {
689
                                                //TODO falta por implementar
690
                                        }
691

    
692
                                        layer.setXMLEntity03(xml.getChild(i));
693
                                        // Comprobar que la proyecci?n es la misma que la de FMap
694
                                        // Si no lo es, es una capa que est? reproyectada al vuelo
695
                                        IProjection proj = layer.getProjection();
696
                                        if (proj != null)
697
                                            if (proj != fmap.getProjection())
698
                                            {
699
                                                        ICoordTrans ct = proj.getCT(fmap.getProjection());
700
                                                        layer.setCoordTrans(ct);
701
                                                        System.err.println("coordTrans = " +
702
                                                                proj.getAbrev() + " " +
703
                                                                fmap.getProjection().getAbrev());
704
                                            }
705

    
706
//                                } else if (className.equals(FLyrWMS.class.getName())) {
707
//                                        try {
708
//                                                layer = LayerFactory.createLayer(s[i],
709
//                                                                StringUtilities.string2Rect(
710
//                                                                        xml.getChild(i).getStringProperty("fullExtent")),
711
//                                                                new URL(xml.getChild(i).getStringProperty("host")),
712
//                                                                xml.getChild(i).getStringProperty("format"),
713
//                                                                xml.getChild(i).getStringProperty("layerQuery"),
714
//                                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
715
//                                                                xml.getChild(i).getStringProperty("srs"));
716
//                                        } catch (MalformedURLException e) {
717
//                                                throw new XMLException(e);
718
//                                        }
719
                                } else if (className.equals((FLyrRaster.class.getName()))) {
720
                                        //if (xml.getChild(i).contains("file")) {
721
                                        /*layer = LayerFactory.createLayer(s[i],
722
                                                        xml.getChild(i).getStringProperty("driverName"),
723
                                                        new File(xml.getChild(i).getStringProperty("file")),
724
                                                        this.getFMap().getViewPort().getProjection());*/
725
                                        layer = new FLyrRaster();
726
                                        layer.setName(s[i]);
727
                                        if (!xml.getChild(i).contains("proj"))
728
                                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
729
                                        layer.setXMLEntity03(xml.getChild(i));
730
                                        try {
731
                                                        layer.load();
732

    
733
                                        } catch (DriverIOException e) {
734
                                                throw new XMLException(e);
735
                                        }
736

    
737
                                }else if (className.equals((FLayers.class.getName()))) {
738
                                        layer = new FLayers(getMapContext(),this);
739
                                        layer.setXMLEntity(xml.getChild(i));
740
                                } else {
741
                                        // Capas Nuevas (externas)
742
                                        try {
743
                                                Class clase = Class.forName(className);
744
                                                layer = (FLayer) clase.newInstance();
745
                                                layer.setName(s[i]);
746
                                                layer.setXMLEntity03(xml.getChild(i));
747
                                                try {
748
                                                                layer.load();
749
                                                } catch (DriverIOException e) {
750
                                                        throw new XMLException(e);
751
                                                }
752
                                        } catch (Exception e) {
753
                                                //e.printStackTrace();
754
                                                throw new XMLException(e);
755
                                        }
756
                                }
757

    
758
                                this.addLayer(layer);
759
                        }
760
                } /*azabala-modificaciones en layerfactory-
761
                catch (DriverException e) {
762
                        throw new XMLException(e);
763
                }*/
764
                catch (DriverLoadException e) {
765
            throw new XMLException(e);
766
        }
767

    
768
        }
769

    
770
        /**
771
         * DOCUMENT ME!
772
         *
773
         * @param xml DOCUMENT ME!
774
         *
775
         * @throws XMLException
776
         *
777
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
778
         */
779
        public void setXMLEntity(XMLEntity xml) throws XMLException{
780
                super.setXMLEntity(xml);
781
                //LoadLayerException loadLayerException=new LoadLayerException();
782
                int numLayers = xml.getIntProperty("numLayers");
783

    
784
                String[] s = xml.getStringArrayProperty("LayerNames");
785
                // try {
786
                fmap.clearErrors();
787
                        for (int i = 0; i < numLayers; i++) {
788
                                this.addLayerFromXML(xml.getChild(i),s[i]);
789

    
790

    
791
                        }
792
                /* } catch (DriverException e) {
793
                        throw new XMLException(e);
794
                } */
795
                /*if (loadLayerException.getExceptions().size()>0){
796
                        throw loadLayerException;
797
                }*/
798
        }
799

    
800
        /**
801
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor,
802
         *                 FBitSet)
803
         */
804
        public void process(FeatureVisitor visitor, FBitSet subset)
805
                throws DriverException, VisitException {
806
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
807
                        FLayer layer = (FLayer) iter.next();
808

    
809
                        if (layer instanceof VectorialData) {
810
                                ((VectorialData) layer).process(visitor, subset);
811
                        }
812
                }
813
        }
814

    
815
        /**
816
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor)
817
         */
818
        public void process(FeatureVisitor visitor)
819
                throws DriverException, VisitException {
820
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
821
                        FLayer layer = (FLayer) iter.next();
822

    
823
                        if (layer.isActive()) {
824
                                if (layer instanceof VectorialData) {
825
                                        ((VectorialData) layer).process(visitor);
826
                                }
827
                        }
828
                }
829
        }
830
        /**
831
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor, Rectangle2D)
832
         */
833
        public void process(FeatureVisitor visitor, Rectangle2D rect) throws DriverException, VisitException {
834
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
835
                        FLayer layer = (FLayer) iter.next();
836

    
837
                        if (layer.isActive()) {
838
                                if (layer instanceof VectorialData) {
839
                                        ((VectorialData) layer).process(visitor, rect);
840
                                }
841
                        }
842
                }
843

    
844
        }
845

    
846
        /**
847
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMapContext()
848
         */
849
        public MapContext getMapContext() {
850
                return fmap;
851
        }
852

    
853
        /* (non-Javadoc)
854
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#setCoordTrans(org.cresques.cts.ICoordTrans)
855
         */
856
        public void setCoordTrans(ICoordTrans ct) {
857
                super.setCoordTrans(ct);
858

    
859
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
860
                        FLayer layer = (FLayer) iter.next();
861
                        layer.setCoordTrans(ct);
862
                }
863
        }
864

    
865
        /**
866
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllActives(boolean)
867
         */
868
        public void setAllActives(boolean active) {
869
                FLayer lyr;
870

    
871
                for (int i = 0; i < layers.size(); i++) {
872
                        lyr = ((FLayer) layers.get(i));
873
                        lyr.setActive(active);
874

    
875
                        if (lyr instanceof LayerCollection) {
876
                                ((LayerCollection) lyr).setAllActives(active);
877
                        }
878
                }
879
        }
880

    
881
        /**
882
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#getActives()
883
         */
884
        public FLayer[] getActives() {
885
                ArrayList ret = new ArrayList();
886

    
887
                for (int i = 0; i < layers.size(); i++) {
888
                        if (((FLayer) layers.get(i)).isActive()) {
889
                                ret.add(layers.get(i));
890
                        }else{
891
                                if (layers.get(i) instanceof FLayers){
892
                                        FLayer[] lyrs=((FLayers) layers.get(i)).getActives();
893
                                        for (int j=0;j<lyrs.length;j++){
894
                                                ret.add(lyrs[j]);
895
                                        }
896
                                }
897
                        }
898
                }
899

    
900
                return (FLayer[]) ret.toArray(new FLayer[0]);
901
        }
902

    
903
    /* (non-Javadoc)
904
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMinScale()
905
     */
906
    public double getMinScale() {
907
        return -1; // La visibilidad o no la controla cada capa
908
                // dentro de una colecci?n
909
    }
910

    
911
    /* (non-Javadoc)
912
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMaxScale()
913
     */
914
    public double getMaxScale() {
915
        return -1;
916
    }
917
    public void setMinScale(double minScale)
918
    {
919
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
920
                        FLayer lyr = (FLayer) iter.next();
921
                        lyr.setMinScale(minScale);
922
                }
923
    }
924
    public void setMaxScale(double maxScale)
925
    {
926
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
927
                        FLayer lyr = (FLayer) iter.next();
928
                        lyr.setMinScale(maxScale);
929
                }
930
    }
931
    public void setActive(boolean b){
932
            super.setActive(b);
933
            for (int i=0;i<layers.size();i++){
934
                    ((FLayer)layers.get(i)).setActive(b);
935
            }
936
    }
937

    
938
        /* (non-Javadoc)
939
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#addLayerListener(com.iver.cit.gvsig.fmap.layers.LayerListener)
940
         */
941
        public boolean addLayerListener(LayerListener o) {
942
                for (int i = 0; i < layers.size(); i++)
943
                        ((FLayer) layers.get(i)).addLayerListener(o);
944
                return true;
945
        }
946

    
947
        public XMLItem[] getInfo(Point p, double tolerance) throws DriverException {
948
                int i;
949
                Vector items = new Vector();
950
                FLayer layer;
951
                XMLItem[] aux;
952
                for (i = 0; i < this.layers.size(); i++){
953
                        layer = (FLayer)layers.get(i);
954
                        if (layer instanceof InfoByPoint){
955
                                InfoByPoint queryable_layer = (InfoByPoint) layer;
956
                                aux = queryable_layer.getInfo(p, tolerance);
957
                                for(int j = 0; j < aux.length; j++){
958
                                        items.add(aux[j]);
959
                                }
960
                        }
961
                }
962
                return (XMLItem[])items.toArray(new XMLItem[0]);
963

    
964
//                for (i = 0; i < this.layers.size(); i++){
965
//                        FLayer laCapa = (FLayer) layers.get(i);
966
//                        if (laCapa instanceof FLyrVect){
967
//                        }
968
//                        else if (laCapa instanceof RasterOperations) {
969
//                                try {
970
//                                        RasterOperations layer = (RasterOperations) laCapa;
971
//                                        sb.append(layer.getInfo(p, tolerance));
972
//                                } catch (DriverException e) {
973
//                                        e.printStackTrace();
974
//                                }
975
//                        }
976
//                        else if (laCapa instanceof InfoByPoint) {
977
//                                try {
978
//                                        InfoByPoint layer = (InfoByPoint) laCapa;
979
//                                        sb.append(layer.getInfo(p, tolerance));
980
//                                } catch (DriverException e) {
981
//                                        e.printStackTrace();
982
//                                }
983
//                        }
984
//                }
985

    
986
        }
987

    
988
        public ImageIcon getTocImageIcon() {
989
                return new ImageIcon(MapControl.class.getResource("images/layerGroup.png"));
990
        }
991

    
992
        public boolean isDirty() {
993
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
994
                        FLayer lyr = (FLayer) iter.next();
995
                        if (lyr.isDirty())
996
                                return true;
997
                }
998
                return false;
999
        }
1000

    
1001
        public void setDirty(boolean dirty) {
1002
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1003
                        FLayer lyr = (FLayer) iter.next();
1004
                        lyr.setDirty(dirty);
1005
                }
1006

    
1007
        }
1008

    
1009
        public boolean addLayerFromXMLEntity(XMLEntity xml, String name) {
1010
                fmap.clearErrors();
1011
                this.addLayerFromXML(xml,name);
1012

    
1013
                return (fmap.getLayersError().size() == 0);
1014

    
1015
        }
1016

    
1017
        private void addLayerFromXML(XMLEntity xml, String name) {
1018
                FLayer layer = null;
1019

    
1020
                try {
1021
                if (name == null) name = xml.getName();
1022

    
1023

    
1024
                String className = xml.getStringProperty("className");
1025

    
1026
                if (className.equals(FLyrVect.class.getName())) {
1027
                        String type = xml.getStringProperty("type");
1028
                        if ("vectorial".equals(type)){
1029
                                //String recordsetName = xml.getChild(i).getStringProperty("recordset-name");
1030
                IProjection proj = null;
1031
                if (xml.contains("proj")) {
1032
                    proj = CRSFactory.getCRS(xml.getStringProperty("proj"));
1033
                }
1034
                else
1035
                {
1036
                    proj = this.getMapContext().getViewPort().getProjection();
1037
                }
1038
                                if (xml.contains("file")) {
1039
                                        Driver d;
1040
                                        try {
1041
                                                d = LayerFactory.getDM().getDriver(xml.getStringProperty("driverName"));
1042
                                        } catch (DriverLoadException e1) {
1043
                                                throw new XMLException(e1);
1044
                                        }
1045
                                        layer = LayerFactory.createLayer(name, (VectorialFileDriver) d,
1046
                                                                                                        new File(xml.getStringProperty("file")),
1047
                                                                                                        proj);
1048

    
1049

    
1050
                                }
1051
                if (xml.contains("db")) {
1052

    
1053
                    String driverName = xml.getStringProperty("db");
1054
                    VectorialDatabaseDriver driver;
1055
                    try {
1056
                        driver = (VectorialDatabaseDriver) LayerFactory.getDM().getDriver(driverName);
1057
                        //Hay que separar la carga de los datos del XMLEntity del load.
1058
                        driver.setXMLEntity(xml.getChild(2));
1059

    
1060
                        boolean loadOk = false;
1061
                        try {
1062
                                ((DefaultDBDriver)driver).load();
1063
                                if (((DefaultDBDriver)driver).getConnection() != null) {
1064
                                        loadOk = true;
1065
                                }
1066

    
1067
                        } catch (DriverException e) {
1068
                                e.printStackTrace();
1069
                                loadOk = false;
1070

    
1071
                        }
1072

    
1073
                        layer = LayerFactory.createDBLayer(driver, name, proj);
1074
                        if (!loadOk) {
1075
                                layer.setAvailable(false);
1076
                        }
1077

    
1078
                    } catch (DriverLoadException e) {
1079
                        e.printStackTrace();
1080
                        throw new XMLException(e);
1081
                    }
1082

    
1083
                }
1084
                // Clases con algun driver gen?rico creado por otro
1085
                // programador
1086
                if (xml.contains("other")) {
1087

    
1088
                    String driverName = xml.getStringProperty("other");
1089
                    VectorialDriver driver = null;
1090
                    try {
1091
                        driver = (VectorialDriver) LayerFactory.getDM().getDriver(driverName);
1092
                    } catch (DriverLoadException e) {
1093
                        // Si no existe ese driver, no pasa nada.
1094
                        // Puede que el desarrollador no quiera que
1095
                        // aparezca en el cuadro de di?logo y ha metido
1096
                        // el jar con sus clases en nuestro directorio lib.
1097
                        // Intentamos cargar esa clase "a pelo".
1098
                        if (xml.getChild(2).contains("className"))
1099
                        {
1100
                            String className2 = xml.getChild(2).getStringProperty("className");
1101
                            try {
1102
                                driver = (VectorialDriver) Class.forName(className2).newInstance();
1103
                            } catch (Exception e1) {
1104
                                throw new XMLException(e1);
1105
                            }
1106
                        }
1107
                    } catch (NullPointerException npe) {
1108
                        // Si no existe ese driver, no pasa nada.
1109
                        // Puede que el desarrollador no quiera que
1110
                        // aparezca en el cuadro de di?logo y ha metido
1111
                        // el jar con sus clases en nuestro directorio lib.
1112
                        // Intentamos cargar esa clase "a pelo".
1113
                        if (xml.getChild(2).contains("className"))
1114
                        {
1115
                            String className2 = xml.getChild(2).getStringProperty("className");
1116
                            try {
1117
                                driver = (VectorialDriver) Class.forName(className2).newInstance();
1118
                            } catch (Exception e1) {
1119
                                throw new XMLException(e1);
1120
                            }
1121
                        }
1122
                    }
1123
                    if (driver instanceof IPersistance)
1124
                    {
1125
                        IPersistance persist = (IPersistance) driver;
1126
                        persist.setXMLEntity(xml.getChild(2));
1127
                    }
1128
                    layer = LayerFactory.createLayer(name, driver, proj);
1129
                }
1130

    
1131

    
1132
                        } else if ("raster".equals(type)) {
1133
/*                                                if (xml.getChild(i).contains("file")) {
1134
                                        Driver d = LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName"));
1135
                                                                                        layer = LayerFactory.createLayer(s[i],
1136
                                                                                                        ,
1137
                                                                                                        new File(xml.getChild(i).getStringProperty("file")),
1138
                                                                                                        this.getFMap().getViewPort().getProjection());
1139

1140
                                }
1141
*/                                        }
1142

    
1143
                        layer.setXMLEntity(xml);
1144

    
1145
//                } else if (className.equals(FLyrWMS.class.getName())) {
1146
//                        try {
1147
//                                layer = LayerFactory.createLayer(s[i],
1148
//                                                StringUtilities.string2Rect(
1149
//                                                        xml.getChild(i).getStringProperty("fullExtent")),
1150
//                                                new URL(xml.getChild(i).getStringProperty("host")),
1151
//                                                xml.getChild(i).getStringProperty("format"),
1152
//                                                xml.getChild(i).getStringProperty("layerQuery"),
1153
//                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
1154
//                                                xml.getChild(i).getStringProperty("srs"));
1155
//                                layer.setXMLEntity(xml.getChild(i));
1156
//                        } catch (MalformedURLException e) {
1157
//                                throw new XMLException(e);
1158
//                        }
1159
                } else if (className.equals((FLyrRaster.class.getName()))) {
1160
                        //if (xml.getChild(i).contains("file")) {
1161
                        /*layer = LayerFactory.createLayer(s[i],
1162
                                        xml.getChild(i).getStringProperty("driverName"),
1163
                                        new File(xml.getChild(i).getStringProperty("file")),
1164
                                        this.getFMap().getViewPort().getProjection());*/
1165
                        layer = new FLyrRaster();
1166
                        layer.setName(name);
1167
                        if (!xml.contains("proj"))
1168
                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
1169
                        layer.setXMLEntity(xml);
1170
                        try {
1171
                                layer.load();
1172
                        } catch (DriverIOException e) {
1173
                                throw new XMLException(e);
1174
                        }
1175

    
1176
                }else if (className.equals((FLayers.class.getName()))) {
1177
                        layer = new FLayers(getMapContext(),this);
1178
                        layer.setXMLEntity(xml);
1179
                } else {
1180
                        // Capas Nuevas (externas)
1181
                                Class clase = Class.forName(className);
1182
                                layer = (FLayer) clase.newInstance();
1183
                                layer.setName(name);
1184
                                layer.setXMLEntity(xml);
1185
                                try {
1186
                                        layer.load();
1187
                                }catch (DriverIOException e) {
1188
                                        throw new XMLException(e);
1189
                                }
1190

    
1191
                }
1192

    
1193
                this.addLayer(layer);
1194
                logger.debug("layer: "+ layer.getName() +" loaded");
1195
                // Comprobar que la proyecci?n es la misma que la de FMap
1196
        // Si no lo es, es una capa que est? reproyectada al vuelo
1197
        IProjection proj = layer.getProjection();
1198
        if ((proj != null))
1199
            if (proj != getMapContext().getProjection())
1200
            {
1201
                ICoordTrans ct = proj.getCT(getMapContext().getProjection());
1202
                // TODO: REVISAR CON LUIS
1203
                // Se lo fijamos a todas, luego cada una que se reproyecte
1204
                // si puede, o que no haga nada
1205
                layer.setCoordTrans(ct);
1206
                // NOTA: DESPU?S DE ESTO DEBER?AMOS CREAR LAS ETIQUETAS
1207
                // SI ES NECESARIO.
1208
                // TODO: REVISAR A FONDO ESTO, PORQUE LAS ETIQUETAS SE CREAN
1209
                // 2 VECES SI HAY REPROYECC?N
1210
                if (layer instanceof FLyrVect)
1211
                {
1212
                    FLyrVect lyrVect = (FLyrVect)layer;
1213
                    VectorialLegend legend = (VectorialLegend) lyrVect.getLegend();
1214
                    if (legend.getLabelField() != null) {
1215
                        lyrVect.createLabelLayer(lyrVect.getRecordset());
1216
                    }
1217

    
1218
                }
1219
            }
1220
        }catch (Exception e) {
1221
                        fmap.addLayerError(xml.getStringProperty("name"));
1222
                                //loadLayerException.addException(e);
1223
                        /*if (layer!=null){
1224
                layer.setActive(false);
1225
                        layer.setVisible(false);
1226
                        this.addLayer(layer);
1227
                }*/
1228
                        //throw new XMLException(e);
1229
            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1230
            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1231
            // logger.debug(e.fillInStackTrace());
1232
            e.printStackTrace();
1233
        }
1234
        }
1235

    
1236
        private void addLayerFromXMLNew(XMLEntity xml, String name) {
1237
                FLayer layer = null;
1238

    
1239

    
1240
                try {
1241
                String className = xml.getStringProperty("className");
1242

    
1243
                if (className.equals((FLayers.class.getName()))){
1244
                        layer = new FLayers(getMapContext(),this);
1245
                } else {
1246
//                         Por compatibilidad
1247
                        if (className.equals(FLyrVect.class.getName())) {
1248
                                if (xml.contains("file")) {
1249
                                        layer = new FLayerFileVectorial();
1250
                                } else if (xml.contains("db")) {
1251
                                        try {
1252
                                                layer = (FLayer)((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create("com.iver.cit.gvsig.fmap.layers.FLayerJDBCVectorial");
1253
                                        } catch (Exception e) {
1254
                                                throw new XMLException(new Exception("No se tiene registrada la capa de tipo JDBC"));
1255
                                        }
1256
                                        //className = FLayerJDBCVectorial.class.getName();
1257
                                } else if (xml.contains("other")){
1258
                                        layer = new FLayerGenericVectorial();
1259
                                } else {
1260
                                        throw new XMLException(new Exception("Capa vectorial de tipo no reconocido"));
1261
                                }
1262
//                                Fin por compatibilidad
1263
                        } else {
1264
                                try {
1265
                                        layer = (FLayer)(((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create(className));
1266
                                } catch (Exception e) {
1267
                                        //puende que no este registrada como punto de extension
1268
                                        Class clase = Class.forName(className);
1269
                                        layer = (FLayer) clase.newInstance();
1270
                                        // FIXME: Hacemos algo aqui o dejamos que suba el error?
1271
                                }
1272
                        }
1273

    
1274
                }
1275
                layer.setXMLEntity(xml);
1276
                if (name != null) layer.setName(name);
1277
                try {
1278
                        layer.load();
1279
                }catch (DriverIOException e) {
1280
                        throw new XMLException(e);
1281
                }
1282

    
1283
                this.addLayer(layer);
1284
                logger.debug("layer: "+ layer.getName() +" loaded");
1285
                // Comprobar que la proyecci?n es la misma que la de FMap
1286
        // Si no lo es, es una capa que est? reproyectada al vuelo
1287
        IProjection proj = layer.getProjection();
1288
        if ((proj != null))
1289
            if (proj != getMapContext().getProjection())
1290
            {
1291
                ICoordTrans ct = proj.getCT(getMapContext().getProjection());
1292
                // TODO: REVISAR CON LUIS
1293
                // Se lo fijamos a todas, luego cada una que se reproyecte
1294
                // si puede, o que no haga nada
1295
                layer.setCoordTrans(ct);
1296
                // NOTA: DESPU?S DE ESTO DEBER?AMOS CREAR LAS ETIQUETAS
1297
                // SI ES NECESARIO.
1298
                // TODO: REVISAR A FONDO ESTO, PORQUE LAS ETIQUETAS SE CREAN
1299
                // 2 VECES SI HAY REPROYECC?N
1300
                if (layer instanceof FLyrVect)
1301
                {
1302
                    FLyrVect lyrVect = (FLyrVect)layer;
1303
                    VectorialLegend legend = (VectorialLegend) lyrVect.getLegend();
1304
                    if (legend.getLabelField() != null) {
1305
                        lyrVect.createLabelLayer(lyrVect.getRecordset());
1306
                    }
1307

    
1308
                }
1309
            }
1310
        }catch (Exception e) {
1311
                        fmap.addLayerError(xml.getStringProperty("name"));
1312
                                //loadLayerException.addException(e);
1313
                        /*if (layer!=null){
1314
                layer.setActive(false);
1315
                        layer.setVisible(false);
1316
                        this.addLayer(layer);
1317
                }*/
1318
                        //throw new XMLException(e);
1319
            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1320
            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1321
            // logger.debug(e.fillInStackTrace());
1322
            e.printStackTrace();
1323
        }
1324
        }
1325

    
1326
}