Statistics
| Revision:

svn-gvsig-desktop / branches / v10 / libraries / libFMap / src / com / iver / cit / gvsig / fmap / layers / FLayers.java @ 10638

History | View | Annotate | Download (42.3 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.print.attribute.PrintRequestAttributeSet;
56
import javax.swing.ImageIcon;
57

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

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

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

    
95

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

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

    
120

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

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

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

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

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

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

    
183
                doAddLayer(pos,layer);
184

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

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

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

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

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

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

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

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

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

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

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

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

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

    
298

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

    
312
                };
313

    
314
                while (iter.hasNext()) {
315
                        array.add(iter.nextLayer());
316
                }
317

    
318
                return (FLayer[]) array.toArray(new FLayer[0]);
319
        }
320

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

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

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

    
348
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
349
                                        return lyr;
350
                        }
351
                        
352
                        layerList = new ArrayList();
353
                        getLayerFromGroup(lyr,layerList);
354
                        
355
                        for(int j = 0; j<layerList.size(); j++ )
356
                        {
357
                                lyr2 = ((FLayer)layerList.get(j));
358
                                if (lyr2.getName().compareToIgnoreCase(layerName) == 0) {
359
                                        return lyr2;
360
                                }
361
                        }
362
                        
363
                }
364

    
365
                return null;
366
        }
367
    // looks in the layertree including FLayers 
368
        private void getLayerFromGroup(FLayer layer, ArrayList result){
369
                int i;
370
                FLayers layerGroup;
371
                if (layer instanceof FLayers)
372
                {
373
                        result.add(layer);
374
                        layerGroup = (FLayers)layer;
375
                        for (i=0; i < layerGroup.getLayersCount(); i++ )
376
                        {
377
                                getLayerFromGroup(layerGroup.getLayer(i),result);
378
                        }
379
                }
380
                else
381
                {
382
                        result.add(layer);
383
                }
384
        }
385
        
386
        
387
        // this is to to split up a layer group in order to get a layer by name
388
        // when there are layergroups.
389
        private void splitLayerGroup(FLayer layer, ArrayList result)
390
        {
391
                int i;
392
                FLayers layerGroup;
393
                if (layer instanceof FLayers)
394
                {
395
                        layerGroup = (FLayers)layer;
396
                        for (i=0; i < layerGroup.getLayersCount(); i++ )
397
                        {
398
                                splitLayerGroup(layerGroup.getLayer(i),result);
399
                        }
400
                }
401
                else
402
                {
403
                        result.add(layer);
404
                }
405
        }
406

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

    
417
        /**
418
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#draw(java.awt.image.BufferedImage,
419
         *                 java.awt.Graphics2D, com.iver.cit.gvsig.fmap.ViewPort)
420
         */
421
        public void draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
422
                Cancellable cancel,double scale) throws DriverException {
423
            //double scale = getFMap().getScaleView();
424
//                Iterator iter = layers.iterator();
425
//        try
426
//        {
427
                boolean bNeedRecalculateCache = false;
428
//                    while (iter.hasNext())
429
//                    {
430
                     for (int i=0; i < layers.size(); i++) {
431
                if (cancel.isCanceled())
432
                    break; // M?s que nada porque las capas raster no son interrumpibles por ahora.
433
//                            FLayer lyr = (FLayer) iter.next();
434
                            FLayer lyr = (FLayer) layers.get(i);
435
                    /*        if (lyr instanceof FLyrVect && ((FLyrVect)lyr).isBroken()){
436
                                    continue;
437
                            }
438
                    */
439
                            LayerDrawEvent beforeEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_BEFORE_DRAW);
440
                            fmap.fireLayerDrawingEvent(beforeEvent);
441
                        if ((lyr.isDirty()) && (lyr.isCachingDrawnLayers() == false))
442
                                bNeedRecalculateCache = true;
443

    
444
                            if (lyr.isVisible()) {
445

    
446
                                    long t1 = System.currentTimeMillis();
447
                                    System.err.println("Layer " + lyr.getName() + " dirty=" + lyr.isDirty());
448
                                    // synchronized (this) {
449
                                            //Sincronizaci?n del m?todo dibujar de cada Layer, esto es posible hacerlo de otra forma,
450
                                            //pero de momento se queda as?, para solucionar el refresco de una misma vista que est? a?adida en el Layout.
451
                                    try{
452
                                            /* if (lyr instanceof IComposedDrawing)
453
                                            {
454
                                                    // Acumulamos las peticiones hasta que sea
455
                                                    // otro servidor o otro tipo de capa o la ?ltima
456
                                                    // Si hay que dibujar:
457
                                                    lyr.draw(image, g, viewPort, cancel,scale);
458
                                                    // Si hay que acumlar:
459
                                                    lyr.acumulateDrawing(antLayer);
460

461
                                            }
462
                                            else */
463

    
464
                                             if (lyr.isCachingDrawnLayers())
465
                                            {
466
                                                    if ((bNeedRecalculateCache) || (lyr.getCacheImageDrawnLayers()==null))
467
                                                    {
468
                                                    //if (bNeedRecalculateCache)
469
                                                    // {
470
                                                            // Copiamos la imagen actual
471
                                                            BufferedImage buff = new BufferedImage(image.getWidth(), image.getHeight(), image.getType());
472
                                                            WritableRaster w = buff.getRaster();
473
                                                            image.copyData(w);
474
                                                            lyr.setCacheImageDrawnLayers(buff);
475
                                                            System.err.println("RECALCULO LA CACHE CON LO QUE HABIA ANTES DE " + lyr.getName());
476
                                                    }
477
//                                                    }
478
//                                                    else
479
//                                                    {
480
                                                            if (lyr.getCacheImageDrawnLayers() != null)
481
                                                            {
482
                                                                    // Previo a esto hemos tenido que fijar
483
                                                                    // la imagen que queremos usar, en el
484
                                                                    // prepareDrawing de FMap.
485
                                                                    if (lyr.isDirty())
486
                                                                    {
487
                                                                            g.drawImage(lyr.getCacheImageDrawnLayers(), 0, 0, null);
488
                                                                            System.err.println("Pinto con acelerado lo que hab?a antes de " + lyr.getName());
489
                                                                    }
490
                                                            }
491
//                                                    }
492
                                            }
493
                                            // Si la capa est? "sucia" o alguna de las de abajo est? sucia
494
                                            // hay que volver a dibujar.
495
                                                   if (lyr.isDirty() || bNeedRecalculateCache)
496
                                                   {
497
                                                           if (lyr.getFLayerStatus().isDriverLoaded())
498
                                                           {
499
                                                                   lyr.draw(image, g, viewPort, cancel,scale);
500
                                                                   bNeedRecalculateCache = true;
501
                                                           }
502
                                                   }
503
                                    } catch (DriverException e){
504
                                            // fmap.callNewErrorEvent(new ErrorEvent(lyr.getName(), e));
505
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
506
                                            e.printStackTrace();
507
                                            lyr.setAvailable(false);
508
                                            // this.removeLayer(lyr);
509
                                    } catch (Exception e) {
510
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
511
                                            e.printStackTrace();
512
                                            lyr.setAvailable(false);
513
                                    }
514
                                            // }
515
                                            long t2 = System.currentTimeMillis();
516
                                            System.out.println("Layer " + lyr.getName() + " "
517
                                                    + (t2-t1) + " milisecs.");
518
                                            lyr.setDirty(false);
519
                            }
520
                            LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
521
                            fmap.fireLayerDrawingEvent(afterEvent);
522

    
523
                    }
524
                    if (getVirtualLayers() != null) {
525
                            getVirtualLayers().draw(image, g, viewPort, cancel,scale);
526
                    }
527
//        }
528
//        catch (ConcurrentModificationException e)
529
//        {
530
//            System.err.println(e.getMessage());
531
//        }
532
        }
533

    
534
        /**
535
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#print(java.awt.Graphics2D,
536
         *                 com.iver.cit.gvsig.fmap.ViewPort,
537
         *                 com.iver.utiles.swing.threads.Cancellable)
538
         */
539
        public void print(Graphics2D g, ViewPort viewPort, Cancellable cancel, double scale, PrintRequestAttributeSet properties)
540
                throws DriverException {
541

    
542
        // TODO: A la hora de imprimir, isWithinScale falla, porque est?
543
        // calculando la escala en pantalla, no para el layout.
544
        // Revisar esto.
545
                for (int i=0; i < layers.size(); i++) {
546
                        FLayer lyr = (FLayer) layers.get(i);
547
                        lyr.print(g, viewPort, cancel, scale, properties);
548

    
549
                }
550
                 if (getVirtualLayers() != null) {
551
            getVirtualLayers().print( g, viewPort, cancel, scale, properties);
552
        }
553
        }
554

    
555
        /**
556
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getFullExtent()
557
         */
558
        public Rectangle2D getFullExtent() throws DriverException {
559
                Rectangle2D rAux = null;
560
                boolean first = true;
561

    
562

    
563
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
564
                        FLayer capa = (FLayer) iter.next();
565
                        try{
566
                        if (first) {
567
                                rAux = capa.getFullExtent();
568
                                first=false;
569
                        } else {
570
                                rAux.add(capa.getFullExtent());
571
                        }
572
                        }catch (Exception e) {
573
                                e.printStackTrace();//TODO hay que revisar para determinar el comportamiento que espera el usuario.
574
                        }
575
                }
576

    
577
                return rAux;
578
        }
579

    
580
        /**
581
         * Llama al m?todo layerAdding de los listeners dados de alta.
582
         *
583
         * @param event
584
         *
585
         * @throws CancelationException
586
         */
587
        protected void callLayerAdding(LayerCollectionEvent event)
588
                throws CancelationException {
589
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
590
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
591
                        ((LayerCollectionListener) iter.next()).layerAdding(event);
592
                }
593
        }
594

    
595
        /**
596
         * Llama al m?todo layerRemoving de los listeners dados de alta.
597
         *
598
         * @param event
599
         *
600
         * @throws CancelationException
601
         */
602
        protected void callLayerRemoving(LayerCollectionEvent event)
603
                throws CancelationException {
604
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
605
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
606
                        ((LayerCollectionListener) iter.next()).layerRemoving(event);
607
                }
608
        }
609

    
610

    
611
        /**
612
         * Llama al m?todo layerMoving de los listeners dados de alta.
613
         *
614
         * @param event
615
         *
616
         * @throws CancelationException
617
         */
618
        protected void callLayerMoving(LayerPositionEvent event)
619
                throws CancelationException {
620
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
621
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
622
                        ((LayerCollectionListener) iter.next()).layerMoving(event);
623
                }
624
        }
625

    
626
        /**
627
         * Llama al m?todo layerAdded de los listeners dados de alta.
628
         *
629
         * @param event
630
         */
631
        protected void callLayerAdded(LayerCollectionEvent event) {
632
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
633
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
634
                        ((LayerCollectionListener) iter.next()).layerAdded(event);
635
                }
636
        }
637

    
638
        /**
639
         * Llama al m?todo layerRemoved de los listeners dados de alta.
640
         *
641
         * @param event
642
         */
643
        protected void callLayerRemoved(LayerCollectionEvent event) {
644
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
645
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
646
                        ((LayerCollectionListener) iter.next()).layerRemoved(event);
647
                }
648
        }
649

    
650
        /**
651
         * Llama al m?todo layerMoved de los listeners dados de alta.
652
         *
653
         * @param event
654
         */
655
        protected void callLayerMoved(LayerPositionEvent event) {
656
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
657
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
658
                        ((LayerCollectionListener) iter.next()).layerMoved(event);
659
                }
660
        }
661

    
662
        /**
663
         * @throws XMLException
664
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getProperties()
665
         */
666
        public XMLEntity getXMLEntity() throws XMLException {
667
                XMLEntity xml = super.getXMLEntity();
668
                xml.putProperty("numLayers", layers.size());
669

    
670
                String[] s = new String[layers.size()];
671

    
672
                for (int i = 0; i < layers.size(); i++) {
673
                        s[i] = ((FLayer) layers.get(i)).getName();
674
                }
675

    
676
                xml.putProperty("LayerNames", s);
677

    
678
                for (int i = 0; i < layers.size(); i++) {
679
                        xml.addChild(((FLayer) layers.get(i)).getXMLEntity());
680
                }
681

    
682
                return xml;
683
        }
684

    
685
        /**
686
         * DOCUMENT ME!
687
         *
688
         * @param xml DOCUMENT ME!
689
         *
690
         * @throws XMLException
691
         *
692
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
693
         */
694
        public void setXMLEntity03(XMLEntity xml) throws XMLException{
695
                super.setXMLEntity03(xml);
696
                int numLayers = xml.getIntProperty("numLayers");
697

    
698
                String[] s = xml.getStringArrayProperty("LayerNames");
699
                try {
700
                        for (int i = 0; i < numLayers; i++) {
701
                                FLayer layer = null;
702

    
703
                                String className = xml.getChild(i).getStringProperty("className");
704

    
705
                                if (className.equals(FLyrVect.class.getName())) {
706
                                        if (xml.getChild(i).contains("file")) {
707

    
708
                                                        layer = LayerFactory.createLayer(s[i],
709
                                                                        (VectorialFileDriver)LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName")),
710
                                                                        new File(xml.getChild(i).getStringProperty("file")),
711
                                                                        this.getMapContext().getViewPort().getProjection());
712

    
713
                                        } else if (true) {
714
                                                //TODO falta por implementar
715
                                        } else if (true) {
716
                                                //TODO falta por implementar
717
                                        }
718

    
719
                                        layer.setXMLEntity03(xml.getChild(i));
720
                                        // Comprobar que la proyecci?n es la misma que la de FMap
721
                                        // Si no lo es, es una capa que est? reproyectada al vuelo
722
                                        IProjection proj = layer.getProjection();
723
                                        if (proj != null)
724
                                            if (proj != fmap.getProjection())
725
                                            {
726
                                                        ICoordTrans ct = proj.getCT(fmap.getProjection());
727
                                                        layer.setCoordTrans(ct);
728
                                                        System.err.println("coordTrans = " +
729
                                                                proj.getAbrev() + " " +
730
                                                                fmap.getProjection().getAbrev());
731
                                            }
732

    
733
//                                } else if (className.equals(FLyrWMS.class.getName())) {
734
//                                        try {
735
//                                                layer = LayerFactory.createLayer(s[i],
736
//                                                                StringUtilities.string2Rect(
737
//                                                                        xml.getChild(i).getStringProperty("fullExtent")),
738
//                                                                new URL(xml.getChild(i).getStringProperty("host")),
739
//                                                                xml.getChild(i).getStringProperty("format"),
740
//                                                                xml.getChild(i).getStringProperty("layerQuery"),
741
//                                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
742
//                                                                xml.getChild(i).getStringProperty("srs"));
743
//                                        } catch (MalformedURLException e) {
744
//                                                throw new XMLException(e);
745
//                                        }
746
                                } else if (className.equals((FLyrRaster.class.getName()))) {
747
                                        //if (xml.getChild(i).contains("file")) {
748
                                        /*layer = LayerFactory.createLayer(s[i],
749
                                                        xml.getChild(i).getStringProperty("driverName"),
750
                                                        new File(xml.getChild(i).getStringProperty("file")),
751
                                                        this.getFMap().getViewPort().getProjection());*/
752
                                        layer = new FLyrRaster();
753
                                        layer.setName(s[i]);
754
                                        if (!xml.getChild(i).contains("proj"))
755
                                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
756
                                        layer.setXMLEntity03(xml.getChild(i));
757
                                        try {
758
                                                        layer.load();
759

    
760
                                        } catch (DriverIOException e) {
761
                                                throw new XMLException(e);
762
                                        }
763

    
764
                                }else if (className.equals((FLayers.class.getName()))) {
765
                                        layer = new FLayers(getMapContext(),this);
766
                                        layer.setXMLEntity(xml.getChild(i));
767
                                } else {
768
                                        // Capas Nuevas (externas)
769
                                        try {
770
                                                Class clase = Class.forName(className);
771
                                                layer = (FLayer) clase.newInstance();
772
                                                layer.setName(s[i]);
773
                                                layer.setXMLEntity03(xml.getChild(i));
774
                                                try {
775
                                                                layer.load();
776
                                                } catch (DriverIOException e) {
777
                                                        throw new XMLException(e);
778
                                                }
779
                                        } catch (Exception e) {
780
                                                //e.printStackTrace();
781
                                                throw new XMLException(e);
782
                                        }
783
                                }
784

    
785
                                this.addLayer(layer);
786
                        }
787
                } /*azabala-modificaciones en layerfactory-
788
                catch (DriverException e) {
789
                        throw new XMLException(e);
790
                }*/
791
                catch (DriverLoadException e) {
792
            throw new XMLException(e);
793
        }
794

    
795
        }
796

    
797
        /**
798
         * DOCUMENT ME!
799
         *
800
         * @param xml DOCUMENT ME!
801
         *
802
         * @throws XMLException
803
         *
804
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
805
         */
806
        public void setXMLEntity(XMLEntity xml) throws XMLException{
807
                super.setXMLEntity(xml);
808
                //LoadLayerException loadLayerException=new LoadLayerException();
809
                int numLayers = xml.getIntProperty("numLayers");
810

    
811
                String[] s = xml.getStringArrayProperty("LayerNames");
812
                // try {
813
                fmap.clearErrors();
814
                        for (int i = 0; i < numLayers; i++) {
815
                                this.addLayerFromXML(xml.getChild(i),s[i]);
816

    
817

    
818
                        }
819
                /* } catch (DriverException e) {
820
                        throw new XMLException(e);
821
                } */
822
                /*if (loadLayerException.getExceptions().size()>0){
823
                        throw loadLayerException;
824
                }*/
825
        }
826

    
827
        /**
828
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor,
829
         *                 FBitSet)
830
         */
831
        public void process(FeatureVisitor visitor, FBitSet subset)
832
                throws DriverException, VisitException {
833
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
834
                        FLayer layer = (FLayer) iter.next();
835

    
836
                        if (layer instanceof VectorialData) {
837
                                ((VectorialData) layer).process(visitor, subset);
838
                        }
839
                }
840
        }
841

    
842
        /**
843
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor)
844
         */
845
        public void process(FeatureVisitor visitor)
846
                throws DriverException, VisitException {
847
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
848
                        FLayer layer = (FLayer) iter.next();
849

    
850
                        if (layer instanceof FLayers){
851
                                FLayers lyrs=(FLayers)layer;
852
                                for (int i=0;i<lyrs.getLayersCount();i++){
853
                                        FLayer lyr=lyrs.getLayer(i);
854
                                        if (lyr.isActive()) {
855
                                                if (lyr instanceof VectorialData) {
856
                                                        ((VectorialData) lyr).process(visitor);
857
                                                }
858
                                        }
859
                                }
860
                        }
861
                        if (layer.isActive()) {
862
                                if (layer instanceof VectorialData) {
863
                                        ((VectorialData) layer).process(visitor);
864
                                }
865
                        }
866
                }
867
        }
868
        /**
869
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor, Rectangle2D)
870
         */
871
        public void process(FeatureVisitor visitor, Rectangle2D rect) throws DriverException, VisitException {
872
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
873
                        FLayer layer = (FLayer) iter.next();
874

    
875
                        if (layer.isActive()) {
876
                                if (layer instanceof VectorialData) {
877
                                        ((VectorialData) layer).process(visitor, rect);
878
                                }
879
                        }
880
                }
881

    
882
        }
883

    
884
        /**
885
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMapContext()
886
         */
887
        public MapContext getMapContext() {
888
                return fmap;
889
        }
890

    
891
        /* (non-Javadoc)
892
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#setCoordTrans(org.cresques.cts.ICoordTrans)
893
         */
894
        public void setCoordTrans(ICoordTrans ct) {
895
                super.setCoordTrans(ct);
896

    
897
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
898
                        FLayer layer = (FLayer) iter.next();
899
                        layer.setCoordTrans(ct);
900
                }
901
        }
902

    
903
        /**
904
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllActives(boolean)
905
         */
906
        public void setAllActives(boolean active) {
907
                FLayer lyr;
908

    
909
                for (int i = 0; i < layers.size(); i++) {
910
                        lyr = ((FLayer) layers.get(i));
911
                        lyr.setActive(active);
912

    
913
                        if (lyr instanceof LayerCollection) {
914
                                ((LayerCollection) lyr).setAllActives(active);
915
                        }
916
                }
917
        }
918

    
919
        /**
920
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#getActives()
921
         */
922
        public FLayer[] getActives() {
923
                ArrayList ret = new ArrayList();
924
                LayersIterator it = new LayersIterator(this) {
925

    
926
                        public boolean evaluate(FLayer layer) {
927
                                return layer.isActive();
928
                        }
929

    
930
                };
931

    
932
                while (it.hasNext())
933
                {
934
                        ret.add(it.next());
935
                }
936
                return (FLayer[]) ret.toArray(new FLayer[0]);
937
        }
938

    
939
    /* (non-Javadoc)
940
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMinScale()
941
     */
942
    public double getMinScale() {
943
        return -1; // La visibilidad o no la controla cada capa
944
                // dentro de una colecci?n
945
    }
946

    
947
    /* (non-Javadoc)
948
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMaxScale()
949
     */
950
    public double getMaxScale() {
951
        return -1;
952
    }
953
    public void setMinScale(double minScale)
954
    {
955
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
956
                        FLayer lyr = (FLayer) iter.next();
957
                        lyr.setMinScale(minScale);
958
                }
959
    }
960
    public void setMaxScale(double maxScale)
961
    {
962
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
963
                        FLayer lyr = (FLayer) iter.next();
964
                        lyr.setMinScale(maxScale);
965
                }
966
    }
967
    public void setActive(boolean b){
968
            super.setActive(b);
969
            for (int i=0;i<layers.size();i++){
970
                    ((FLayer)layers.get(i)).setActive(b);
971
            }
972
    }
973

    
974
        /* (non-Javadoc)
975
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#addLayerListener(com.iver.cit.gvsig.fmap.layers.LayerListener)
976
         */
977
        public boolean addLayerListener(LayerListener o) {
978
                for (int i = 0; i < layers.size(); i++)
979
                        ((FLayer) layers.get(i)).addLayerListener(o);
980
                return true;
981
        }
982

    
983
        public XMLItem[] getInfo(Point p, double tolerance, Cancellable cancel) throws DriverException {
984
                int i;
985
                Vector items = new Vector();
986
                FLayer layer;
987
                XMLItem[] aux;
988
                for (i = 0; i < this.layers.size(); i++){
989
                        layer = (FLayer)layers.get(i);
990
                        if (layer instanceof InfoByPoint){
991
                                InfoByPoint queryable_layer = (InfoByPoint) layer;
992
                                aux = queryable_layer.getInfo(p, tolerance, null);
993
                                if (!(queryable_layer instanceof FLayers)){
994
                                        for(int j = 0; j < aux.length; j++){
995
                                                items.add(aux[j]);
996
                                        }
997
                                }
998
                        }
999
                }
1000
                return (XMLItem[])items.toArray(new XMLItem[0]);
1001

    
1002
//                for (i = 0; i < this.layers.size(); i++){
1003
//                        FLayer laCapa = (FLayer) layers.get(i);
1004
//                        if (laCapa instanceof FLyrVect){
1005
//                        }
1006
//                        else if (laCapa instanceof RasterOperations) {
1007
//                                try {
1008
//                                        RasterOperations layer = (RasterOperations) laCapa;
1009
//                                        sb.append(layer.getInfo(p, tolerance));
1010
//                                } catch (DriverException e) {
1011
//                                        e.printStackTrace();
1012
//                                }
1013
//                        }
1014
//                        else if (laCapa instanceof InfoByPoint) {
1015
//                                try {
1016
//                                        InfoByPoint layer = (InfoByPoint) laCapa;
1017
//                                        sb.append(layer.getInfo(p, tolerance));
1018
//                                } catch (DriverException e) {
1019
//                                        e.printStackTrace();
1020
//                                }
1021
//                        }
1022
//                }
1023

    
1024
        }
1025

    
1026
        public ImageIcon getTocImageIcon() {
1027
                return new ImageIcon(MapControl.class.getResource("images/layerGroup.png"));
1028
        }
1029

    
1030
        public boolean isDirty() {
1031
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1032
                        FLayer lyr = (FLayer) iter.next();
1033
                        if (lyr.isDirty())
1034
                                return true;
1035
                }
1036
                return false;
1037
        }
1038

    
1039
        public void setDirty(boolean dirty) {
1040
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1041
                        FLayer lyr = (FLayer) iter.next();
1042
                        lyr.setDirty(dirty);
1043
                }
1044

    
1045
        }
1046

    
1047
        public boolean addLayerFromXMLEntity(XMLEntity xml, String name) {
1048
                fmap.clearErrors();
1049
                this.addLayerFromXML(xml,name);
1050

    
1051
                return (fmap.getLayersError().size() == 0);
1052

    
1053
        }
1054

    
1055
        private void addLayerFromXML(XMLEntity xml, String name) {
1056
                FLayer layer = null;
1057
                long t1 = System.currentTimeMillis();
1058
                try {
1059
                if (name == null) name = xml.getName();
1060

    
1061

    
1062
                String className = xml.getStringProperty("className");
1063

    
1064
                if (className.equals(FLyrVect.class.getName())) {
1065
                        String type = xml.getStringProperty("type");
1066
                        if ("vectorial".equals(type)){
1067
                                //String recordsetName = xml.getChild(i).getStringProperty("recordset-name");
1068
                IProjection proj = null;
1069
                if (xml.contains("proj")) {
1070
                    proj = CRSFactory.getCRS(xml.getStringProperty("proj"));
1071
                }
1072
                else
1073
                {
1074
                    proj = this.getMapContext().getViewPort().getProjection();
1075
                }
1076
                                if (xml.contains("file")) {
1077
                                        Driver d;
1078
                                        try {
1079
                                                d = LayerFactory.getDM().getDriver(xml.getStringProperty("driverName"));
1080
                                        } catch (DriverLoadException e1) {
1081
                                                throw new XMLException(e1);
1082
                                        }
1083
                                        layer = LayerFactory.createLayer(name, (VectorialFileDriver) d,
1084
                                                                                                        new File(xml.getStringProperty("file")),
1085
                                                                                                        proj);
1086

    
1087

    
1088
                                }
1089
                if (xml.contains("db")) {
1090

    
1091
                    String driverName = xml.getStringProperty("db");
1092
                    VectorialDatabaseDriver driver;
1093
                    try {
1094
                        driver = (VectorialDatabaseDriver) LayerFactory.getDM().getDriver(driverName);
1095
                        //Hay que separar la carga de los datos del XMLEntity del load.
1096
                        driver.setXMLEntity(xml.getChild(2));
1097

    
1098
                        boolean loadOk = false;
1099
                        try {
1100
                                ((DefaultDBDriver)driver).load();
1101
                                if (((DefaultDBDriver)driver).getConnection() != null) {
1102
                                        loadOk = true;
1103
                                }
1104

    
1105
                        } catch (DriverException e) {
1106
                                e.printStackTrace();
1107
                                loadOk = false;
1108

    
1109
                        }
1110

    
1111
                        layer = LayerFactory.createDBLayer(driver, name, proj);
1112
                        if (!loadOk) {
1113
                                layer.setAvailable(false);
1114
                        }
1115

    
1116
                    } catch (DriverLoadException e) {
1117
                        e.printStackTrace();
1118
                        throw new XMLException(e);
1119
                    }
1120

    
1121
                }
1122
                // Clases con algun driver gen?rico creado por otro
1123
                // programador
1124
                if (xml.contains("other")) {
1125

    
1126
                    String driverName = xml.getStringProperty("other");
1127
                    VectorialDriver driver = null;
1128
                    try {
1129
                        driver = (VectorialDriver) LayerFactory.getDM().getDriver(driverName);
1130
                    } catch (DriverLoadException e) {
1131
                        // Si no existe ese driver, no pasa nada.
1132
                        // Puede que el desarrollador no quiera que
1133
                        // aparezca en el cuadro de di?logo y ha metido
1134
                        // el jar con sus clases en nuestro directorio lib.
1135
                        // Intentamos cargar esa clase "a pelo".
1136
                        if (xml.getChild(2).contains("className"))
1137
                        {
1138
                            String className2 = xml.getChild(2).getStringProperty("className");
1139
                            try {
1140
                                driver = (VectorialDriver) Class.forName(className2).newInstance();
1141
                            } catch (Exception e1) {
1142
                                throw new XMLException(e1);
1143
                            }
1144
                        }
1145
                    } catch (NullPointerException npe) {
1146
                        // Si no existe ese driver, no pasa nada.
1147
                        // Puede que el desarrollador no quiera que
1148
                        // aparezca en el cuadro de di?logo y ha metido
1149
                        // el jar con sus clases en nuestro directorio lib.
1150
                        // Intentamos cargar esa clase "a pelo".
1151
                        if (xml.getChild(2).contains("className"))
1152
                        {
1153
                            String className2 = xml.getChild(2).getStringProperty("className");
1154
                            try {
1155
                                driver = (VectorialDriver) Class.forName(className2).newInstance();
1156
                            } catch (Exception e1) {
1157
                                throw new XMLException(e1);
1158
                            }
1159
                        }
1160
                    }
1161
                    if (driver instanceof IPersistance)
1162
                    {
1163
                        IPersistance persist = (IPersistance) driver;
1164
                        persist.setXMLEntity(xml.getChild(2));
1165
                    }
1166
                    layer = LayerFactory.createLayer(name, driver, proj);
1167
                }
1168

    
1169

    
1170
                        } else if ("raster".equals(type)) {
1171
/*                                                if (xml.getChild(i).contains("file")) {
1172
                                        Driver d = LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName"));
1173
                                                                                        layer = LayerFactory.createLayer(s[i],
1174
                                                                                                        ,
1175
                                                                                                        new File(xml.getChild(i).getStringProperty("file")),
1176
                                                                                                        this.getFMap().getViewPort().getProjection());
1177

1178
                                }
1179
*/                                        }
1180

    
1181
                        layer.setXMLEntity(xml);
1182

    
1183
//                } else if (className.equals(FLyrWMS.class.getName())) {
1184
//                        try {
1185
//                                layer = LayerFactory.createLayer(s[i],
1186
//                                                StringUtilities.string2Rect(
1187
//                                                        xml.getChild(i).getStringProperty("fullExtent")),
1188
//                                                new URL(xml.getChild(i).getStringProperty("host")),
1189
//                                                xml.getChild(i).getStringProperty("format"),
1190
//                                                xml.getChild(i).getStringProperty("layerQuery"),
1191
//                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
1192
//                                                xml.getChild(i).getStringProperty("srs"));
1193
//                                layer.setXMLEntity(xml.getChild(i));
1194
//                        } catch (MalformedURLException e) {
1195
//                                throw new XMLException(e);
1196
//                        }
1197
                } else if (className.equals((FLyrRaster.class.getName()))) {
1198
                        //if (xml.getChild(i).contains("file")) {
1199
                        /*layer = LayerFactory.createLayer(s[i],
1200
                                        xml.getChild(i).getStringProperty("driverName"),
1201
                                        new File(xml.getChild(i).getStringProperty("file")),
1202
                                        this.getFMap().getViewPort().getProjection());*/
1203
                        layer = new FLyrRaster();
1204
                        layer.setName(name);
1205
                        if (!xml.contains("proj"))
1206
                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
1207
                        layer.setXMLEntity(xml);
1208
                        try {
1209
                                layer.load();
1210
                        } catch (DriverIOException e) {
1211
                                throw new XMLException(e);
1212
                        }
1213

    
1214
                }else if (className.equals((FLayers.class.getName()))) {
1215
                        layer = new FLayers(getMapContext(),this);
1216
                        layer.setXMLEntity(xml);
1217
                } else {
1218
                        // Capas Nuevas (externas)
1219
                                Class clase = Class.forName(className);
1220
                                layer = (FLayer) clase.newInstance();
1221
                                layer.setName(name);
1222
                                layer.setXMLEntity(xml);
1223
                                try {
1224
                                        layer.load();
1225
                                }catch (DriverIOException e) {
1226
                                        throw new XMLException(e);
1227
                                }
1228

    
1229
                }
1230

    
1231
                this.addLayer(layer);
1232
                long t2 = System.currentTimeMillis();
1233
                logger.debug("layer: "+ layer.getName() +" loaded. " + (t2-t1) + " msecs.");
1234
                // Comprobar que la proyecci?n es la misma que la de FMap
1235
        // Si no lo es, es una capa que est? reproyectada al vuelo
1236
        IProjection proj = layer.getProjection();
1237
        if ((proj != null))
1238
            if (proj != getMapContext().getProjection())
1239
            {
1240
                ICoordTrans ct = proj.getCT(getMapContext().getProjection());
1241
                // TODO: REVISAR CON LUIS
1242
                // Se lo fijamos a todas, luego cada una que se reproyecte
1243
                // si puede, o que no haga nada
1244
                layer.setCoordTrans(ct);
1245
                // NOTA: DESPU?S DE ESTO DEBER?AMOS CREAR LAS ETIQUETAS
1246
                // SI ES NECESARIO.
1247
                // TODO: REVISAR A FONDO ESTO, PORQUE LAS ETIQUETAS SE CREAN
1248
                // 2 VECES SI HAY REPROYECC?N
1249
                if (layer instanceof FLyrVect)
1250
                {
1251
                    FLyrVect lyrVect = (FLyrVect)layer;
1252
                    VectorialLegend legend = (VectorialLegend) lyrVect.getLegend();
1253
                    if (legend.getLabelField() != null) {
1254
                        lyrVect.createLabelLayer(lyrVect.getRecordset());
1255
                    }
1256

    
1257
                }
1258
            }
1259
        }catch (Exception e) {
1260
                        fmap.addLayerError(xml.getStringProperty("name"));
1261
                                //loadLayerException.addException(e);
1262
                        /*if (layer!=null){
1263
                layer.setActive(false);
1264
                        layer.setVisible(false);
1265
                        this.addLayer(layer);
1266
                }*/
1267
                        //throw new XMLException(e);
1268
            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1269
            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1270
            // logger.debug(e.fillInStackTrace());
1271
            e.printStackTrace();
1272
        }
1273
        }
1274

    
1275
        private void addLayerFromXMLNew(XMLEntity xml, String name) {
1276
                FLayer layer = null;
1277

    
1278

    
1279
                try {
1280
                String className = xml.getStringProperty("className");
1281

    
1282
                if (className.equals((FLayers.class.getName()))){
1283
                        layer = new FLayers(getMapContext(),this);
1284
                } else {
1285
//                         Por compatibilidad
1286
                        if (className.equals(FLyrVect.class.getName())) {
1287
                                if (xml.contains("file")) {
1288
                                        layer = new FLayerFileVectorial();
1289
                                } else if (xml.contains("db")) {
1290
                                        try {
1291
                                                layer = (FLayer)((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create("com.iver.cit.gvsig.fmap.layers.FLayerJDBCVectorial");
1292
                                        } catch (Exception e) {
1293
                                                throw new XMLException(new Exception("No se tiene registrada la capa de tipo JDBC"));
1294
                                        }
1295
                                        //className = FLayerJDBCVectorial.class.getName();
1296
                                } else if (xml.contains("other")){
1297
                                        layer = new FLayerGenericVectorial();
1298
                                } else {
1299
                                        throw new XMLException(new Exception("Capa vectorial de tipo no reconocido"));
1300
                                }
1301
//                                Fin por compatibilidad
1302
                        } else {
1303
                                try {
1304
                                        layer = (FLayer)(((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create(className));
1305
                                } catch (Exception e) {
1306
                                        //puende que no este registrada como punto de extension
1307
                                        Class clase = Class.forName(className);
1308
                                        layer = (FLayer) clase.newInstance();
1309
                                        // FIXME: Hacemos algo aqui o dejamos que suba el error?
1310
                                }
1311
                        }
1312

    
1313
                }
1314
                layer.setXMLEntity(xml);
1315
                if (name != null) layer.setName(name);
1316
                try {
1317
                        layer.load();
1318
                }catch (DriverIOException e) {
1319
                        throw new XMLException(e);
1320
                }
1321

    
1322
                this.addLayer(layer);
1323
                logger.debug("layer: "+ layer.getName() +" loaded");
1324
                // Comprobar que la proyecci?n es la misma que la de FMap
1325
        // Si no lo es, es una capa que est? reproyectada al vuelo
1326
        IProjection proj = layer.getProjection();
1327
        if ((proj != null))
1328
            if (proj != getMapContext().getProjection())
1329
            {
1330
                ICoordTrans ct = proj.getCT(getMapContext().getProjection());
1331
                // TODO: REVISAR CON LUIS
1332
                // Se lo fijamos a todas, luego cada una que se reproyecte
1333
                // si puede, o que no haga nada
1334
                layer.setCoordTrans(ct);
1335
                // NOTA: DESPU?S DE ESTO DEBER?AMOS CREAR LAS ETIQUETAS
1336
                // SI ES NECESARIO.
1337
                // TODO: REVISAR A FONDO ESTO, PORQUE LAS ETIQUETAS SE CREAN
1338
                // 2 VECES SI HAY REPROYECC?N
1339
                if (layer instanceof FLyrVect)
1340
                {
1341
                    FLyrVect lyrVect = (FLyrVect)layer;
1342
                    VectorialLegend legend = (VectorialLegend) lyrVect.getLegend();
1343
                    if (legend.getLabelField() != null) {
1344
                        lyrVect.createLabelLayer(lyrVect.getRecordset());
1345
                    }
1346

    
1347
                }
1348
            }
1349
        }catch (Exception e) {
1350
                        fmap.addLayerError(xml.getStringProperty("name"));
1351
                                //loadLayerException.addException(e);
1352
                        /*if (layer!=null){
1353
                layer.setActive(false);
1354
                        layer.setVisible(false);
1355
                        this.addLayer(layer);
1356
                }*/
1357
                        //throw new XMLException(e);
1358
            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1359
            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1360
            // logger.debug(e.fillInStackTrace());
1361
            e.printStackTrace();
1362
        }
1363
        }
1364

    
1365
        /**
1366
         * This method calls recursively to its layer children to tell that the layer is going
1367
         * to be removed from the view. This overwrites FLyrDefault.removingThisLayer().
1368
         */
1369
        public void removingThisLayer() {
1370

    
1371
                for (int i=0; i < layers.size(); i++) {
1372
                        FLayer lyr = (FLayer) layers.get(i);
1373
                        if (lyr instanceof FLyrDefault) {
1374
                                ((FLyrDefault) lyr).removingThisLayer();
1375
                        }
1376
                }
1377
        }
1378

    
1379
}