Statistics
| Revision:

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

History | View | Annotate | Download (47.8 KB)

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

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

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

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

    
63
import com.hardcode.driverManager.Driver;
64
import com.hardcode.driverManager.DriverLoadException;
65
import com.hardcode.gdbms.driver.exceptions.ReadDriverException;
66
import com.iver.cit.gvsig.exceptions.expansionfile.ExpansionFileReadException;
67
import com.iver.cit.gvsig.exceptions.layers.DriverLayerException;
68
import com.iver.cit.gvsig.exceptions.layers.LoadLayerException;
69
import com.iver.cit.gvsig.exceptions.visitors.VisitorException;
70
import com.iver.cit.gvsig.fmap.MapContext;
71
import com.iver.cit.gvsig.fmap.MapControl;
72
import com.iver.cit.gvsig.fmap.ViewPort;
73
import com.iver.cit.gvsig.fmap.core.ILabelable;
74
import com.iver.cit.gvsig.fmap.crs.CRSFactory;
75
import com.iver.cit.gvsig.fmap.drivers.DefaultDBDriver;
76
import com.iver.cit.gvsig.fmap.drivers.VectorialDatabaseDriver;
77
import com.iver.cit.gvsig.fmap.drivers.VectorialDriver;
78
import com.iver.cit.gvsig.fmap.drivers.VectorialFileDriver;
79
import com.iver.cit.gvsig.fmap.layers.layerOperations.ComposedLayer;
80
import com.iver.cit.gvsig.fmap.layers.layerOperations.InfoByPoint;
81
import com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection;
82
import com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData;
83
import com.iver.cit.gvsig.fmap.layers.layerOperations.XMLItem;
84
import com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor;
85
import com.iver.cit.gvsig.fmap.rendering.VectorialLegend;
86
import com.iver.utiles.IPersistance;
87
import com.iver.utiles.XMLEntity;
88
import com.iver.utiles.extensionPoints.ExtensionPoint;
89
import com.iver.utiles.extensionPoints.ExtensionPointsSingleton;
90
import com.iver.utiles.swing.threads.Cancellable;
91

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

    
100

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

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

    
125

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

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

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

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

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

    
183
                        if (layer instanceof FLayers){
184
                                FLayers layers=(FLayers)layer;
185
                                fmap.addAsCollectionListener(layers);
186
                        }
187
                        callLayerAdding(LayerCollectionEvent.createLayerAddingEvent(layer));
188
                //}
189

    
190
                doAddLayer(pos,layer);
191

    
192
                //if (!layerDef.isUnavailable()) {
193
                        callLayerAdded(LayerCollectionEvent.createLayerAddedEvent(layer));
194
                //}
195
                } catch (CancelationException e) {
196
                        // TODO Auto-generated catch block
197
                        e.printStackTrace();
198
                } catch (LoadLayerException e) {
199
                        layer.setAvailable(false);
200
                        layer.addError(e);
201
                }
202
        }
203

    
204
        /**
205
         * Mueve una capa de la posici?n from a la posici?n to. (Se supone que
206
         * est?n dentro del mismo nivel). Para mover entre niveles, usar otro
207
         * m?todo (por hacer)
208
         *
209
         * @param from origen.
210
         * @param to destino.
211
         *
212
         * @throws CancelationException
213
         */
214
        public void moveTo(int from, int to) throws CancelationException {
215
                int newfrom=layers.size()-from-1;
216
                int newto=layers.size()-to-1;
217
                if ( newfrom < 0 || newfrom >=layers.size() || newto < 0 || newto >= layers.size()) return;
218
                FLayer aux = (FLayer) layers.get(newfrom);
219
                callLayerMoving(LayerPositionEvent.createLayerMovingEvent(aux, newfrom, newto));
220
                layers.remove(newfrom);
221
                layers.add(newto, aux);
222
                callLayerMoved(LayerPositionEvent.createLayerMovedEvent(aux, newfrom, newto));
223
        }
224

    
225
        /**
226
         * Borra una capa del ArrayList que contiene a las capas.
227
         *
228
         * @param lyr FLayer.
229
         */
230
        private void doRemoveLayer(FLayer lyr) {
231
                        layers.remove(lyr);
232
        }
233

    
234
        /**
235
         * Borra una capa de la colecci?n de capas.
236
         *
237
         * @param lyr FLayer
238
         *
239
         * @throws CancelationException
240
         */
241
        public void removeLayer(FLayer lyr) throws CancelationException {
242
                callLayerRemoving(LayerCollectionEvent.createLayerRemovingEvent(lyr));
243
                doRemoveLayer(lyr);
244
                callLayerRemoved(LayerCollectionEvent.createLayerRemovedEvent(lyr));
245
        }
246

    
247
        /**
248
         * Borra una FLayer del vector a partir del identificador.
249
         *
250
         * @param idLayer
251
         */
252
        public void removeLayer(int idLayer) {
253
                FLayer lyr = (FLayer) layers.get(idLayer);
254
                callLayerRemoving(LayerCollectionEvent.createLayerRemovingEvent(lyr));
255
                layers.remove(idLayer);
256
                callLayerRemoved(LayerCollectionEvent.createLayerRemovedEvent(lyr));
257
        }
258

    
259
        /**
260
         * M?todo de conveniencia para borrar una capa con ese nombre
261
         *
262
         * @param layerName
263
         */
264
        public void removeLayer(String layerName) {
265
                FLayer lyr;
266

    
267
                for (int i = 0; i < layers.size(); i++) {
268
                        lyr = ((FLayer) layers.get(i));
269

    
270
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
271
                                removeLayer(i);
272

    
273
                                break;
274
                        }
275
                }
276
        }
277
        /**
278
         * M?todo de conveniencia para reemplazar una capa con ese nombre
279
         *
280
         * @param layerName
281
         * @throws LoadLayerException
282
         */
283
        public void replaceLayer(String layerName, FLayer layer) throws LoadLayerException
284
        {
285
                FLayer lyr;
286
                FLayer parent;
287
                for (int i = 0; i < layers.size(); i++) {
288
                        lyr = ((FLayer) layers.get(i));
289

    
290
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
291
                                parent = lyr.getParentLayer();
292
                                removeLayer(i);
293
                                if (parent != null)
294
                                //Notificamos a la capa que va a ser a?adida
295
                                if (layer instanceof FLyrDefault)
296
                                        ((FLyrDefault)layer).wakeUp();
297

    
298
                                if (layer instanceof FLayers){
299
                                        FLayers layers=(FLayers)layer;
300
                                        fmap.addAsCollectionListener(layers);
301
                                }
302
                                callLayerAdding(LayerCollectionEvent.createLayerAddingEvent(layer));
303

    
304
                                layers.add(i,layer);
305
                                layer.setParentLayer(this);
306

    
307
                                callLayerAdded(LayerCollectionEvent.createLayerAddedEvent(layer));
308
                                break;
309
                        }
310
                }
311
        }
312

    
313

    
314
        /**
315
         * Obtiene el array de capas visibles que penden del arbol cuya ra?z es
316
         * este nodo
317
         *
318
         * @return Vector de FLayer.
319
         */
320
        public FLayer[] getVisibles() {
321
                ArrayList array = new ArrayList();
322
                LayersIterator iter = new LayersIterator(this) {
323
                        public boolean evaluate(FLayer layer) {
324
                                return layer.isVisible();
325
                        }
326

    
327
                };
328

    
329
                while (iter.hasNext()) {
330
                        array.add(iter.nextLayer());
331
                }
332

    
333
                return (FLayer[]) array.toArray(new FLayer[0]);
334
        }
335

    
336
        /**
337
         * Obtiene el hijo i-?simo (de abajo a arriba) directo de esta colecci?n.
338
         *
339
         * @param index ?ndice.
340
         *
341
         * @return capa seleccionada.
342
         */
343
        public FLayer getLayer(int index) {
344
                return (FLayer) layers.get(index);
345
        }
346

    
347
        /**
348
         * M?todo de conveniencia para buscar una capa por su nombre Es conveniente
349
         * usar getLayer(int) siempre que se pueda, es m?s directo.
350
         *
351
         * @param layerName nombre.
352
         *
353
         * @return capa seleccionada.
354
         */
355
        public FLayer getLayer(String layerName) {
356
                FLayer lyr;
357
                FLayer lyr2;
358
                ArrayList layerList;
359

    
360
                for (int i = 0; i < layers.size(); i++) {
361
                        lyr = ((FLayer) layers.get(i));
362

    
363
                        if (lyr.getName().compareToIgnoreCase(layerName) == 0) {
364
                                        return lyr;
365
                        }
366

    
367
                        layerList = new ArrayList();
368
                        splitLayerGroup(lyr,layerList);
369
                        for(int j = 0; j<layerList.size(); j++ )
370
                        {
371
                                lyr2 = ((FLayer)layerList.get(j));
372
                                if (lyr2.getName().compareToIgnoreCase(layerName) == 0) {
373
                                        return lyr2;
374
                                }
375
                        }
376
                }
377

    
378
                return null;
379
        }
380

    
381
        // added by Laura
382
        // this is to to split up a layer group in order to get a layer by name
383
        // when there are layergroups.
384
        private void splitLayerGroup(FLayer layer, ArrayList result)
385
        {
386
                int i;
387
                FLayers layerGroup;
388
                if (layer instanceof FLayers)
389
                {
390
                        layerGroup = (FLayers)layer;
391
                        for (i=0; i < layerGroup.getLayersCount(); i++ )
392
                        {
393
                                splitLayerGroup(layerGroup.getLayer(i),result);
394
                        }
395
                }
396
                else
397
                {
398
                        result.add(layer);
399
                }
400
        }
401

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

    
412
        /**
413
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#draw(java.awt.image.BufferedImage,
414
         *                 java.awt.Graphics2D, com.iver.cit.gvsig.fmap.ViewPort)
415
         */
416
        public void draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
417
                Cancellable cancel,double scale) throws ReadDriverException {
418
            //double scale = getFMap().getScaleView();
419
//                Iterator iter = layers.iterator();
420
//        try
421
//        {
422
                boolean bNeedRecalculateCache = false;
423

    
424
                           ///// CHEMA ComposedLayer
425
                    long tg1 = System.currentTimeMillis();
426
                        ComposedLayer group = null;
427
                        ArrayList pendingEvents= new ArrayList();
428
                boolean fireAfterDrawEvent = true;
429
                           ///// CHEMA ComposedLayer
430

    
431

    
432

    
433
//                    while (iter.hasNext())
434
//                    {
435
                     for (int i=0; i < layers.size(); i++) {
436
                if (cancel.isCanceled())
437
                    break; // M?s que nada porque las capas raster no son interrumpibles por ahora.
438
//                            FLayer lyr = (FLayer) iter.next();
439
                            FLayer lyr = (FLayer) layers.get(i);
440

    
441

    
442
                               ///// CHEMA ComposedLayer
443
                            fireAfterDrawEvent = true;
444
                            ///// CHEMA ComposedLayer
445

    
446

    
447
                    /*        if (lyr instanceof FLyrVect && ((FLyrVect)lyr).isBroken()){
448
                                    continue;
449
                            }
450
                    */
451
                            LayerDrawEvent beforeEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_BEFORE_DRAW);
452
                            fmap.fireLayerDrawingEvent(beforeEvent);
453
                        if ((lyr.isDirty()) || (lyr.isCachingDrawnLayers() == false))
454
                                bNeedRecalculateCache = true;
455

    
456
                            if (lyr.isVisible()) {
457

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

473
                                            }
474
                                            else */
475

    
476
                                             if (lyr.isCachingDrawnLayers())
477
                                            {
478
                                                    if ((bNeedRecalculateCache) || (lyr.getCacheImageDrawnLayers()==null))
479
                                                    {
480
                                                    //if (bNeedRecalculateCache)
481
                                                    // {
482

    
483
                                                               ///// CHEMA ComposedLayer
484
                                                            if (group != null) {
485
                                                                    //si tenemos un grupo pendiente de pintar, pintamos
486
                                                                    // para que la cache sea fiable
487
                                                                    group.draw(image, g, viewPort, cancel,scale);
488
                                                                    fireLayerDrawingEvents(pendingEvents);
489
                                                                    pendingEvents.clear();
490
                                                                    group = null;
491
                                                            }
492
                                                               ///// CHEMA ComposedLayer
493

    
494

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

    
513

    
514
                                                                               ///// CHEMA ComposedLayer
515
                                                                            // Checks for draw group (ComposedLayer)
516
                                                                        if (group != null) {
517
                                                                                // it's going to load a cache image,
518
                                                                                // the current draw isn't needed
519
                                                                                fireLayerDrawingEvents(pendingEvents);
520
                                                                                pendingEvents.clear();
521
                                                                                group = null;
522
                                                                        }
523
                                                                           ///// CHEMA ComposedLayer
524

    
525

    
526
                                                                            g.drawImage(lyr.getCacheImageDrawnLayers(), 0, 0, null);
527
                                                                            System.err.println("Pinto con acelerado lo que hab?a antes de " + lyr.getName());
528
                                                                    }
529
                                                            }
530
//                                                    }
531
                                            }
532
                                            // Si la capa est? "sucia" o alguna de las de abajo est? sucia
533
                                            // hay que volver a dibujar.
534
                                                   if (lyr.isDirty() || bNeedRecalculateCache)
535
                                                   {
536
                                                           ///// CHEMA ComposedLayer
537
                                                           //lyr.draw(image, g, viewPort, cancel,scale);
538
                                                                ///// CHEMA ComposedLayer
539

    
540
                                                           // Checks for draw group (ComposedLayer)
541
                                                           if (group != null) {
542
                                                                   //If layer can be added to the group, does it
543
                                                                   if (group.canAdd(lyr)) {
544
                                                                           group.add(lyr);
545
                                                                           pendingEvents.add(new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW));
546
                                                                           fireAfterDrawEvent=false;
547
                                                                   } else {
548
                                                                           // draw the 'pending to draw' layer group
549
                                                                              group.draw(image, g, viewPort, cancel,scale);
550
                                                                    fireLayerDrawingEvents(pendingEvents);
551
                                                                    pendingEvents.clear();
552

    
553
                                                                              // gets a new group instance
554
                                                                              group = lyr.newComposedLayer();
555
                                                                              // if layer hasn't group, draws it inmediately
556
                                                                              if (group == null) {
557
                                                                                      lyr.draw(image, g, viewPort, cancel,scale);
558
                                                                              } else {
559
                                                                                      // add the layer to the group
560
                                                                                      group.add(lyr);
561
                                                                                      pendingEvents.add(new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW));
562
                                                                                      fireAfterDrawEvent=false;
563
                                                                              }
564
                                                                   }
565
                                                           } else {
566
                                                                   // gets a new group instance
567
                                                                   group = lyr.newComposedLayer();
568
                                                                   // if layer hasn't group, draws it inmediately
569
                                                                   if (group == null) {
570
                                                                           lyr.draw(image, g, viewPort, cancel,scale);
571
                                                                   } else {
572
                                                                           // adds the layer to the group
573
                                                                           group.add(lyr);
574
                                                                           pendingEvents.add(new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW));
575
                                                                           fireAfterDrawEvent=false;
576
                                                                   }
577
                                                           }
578
                                                           ///// CHEMA ComposedLayer
579

    
580
                                                           /*
581
                                                            * (Jaume)
582
                                                            * If the layer is instance of ILabelable then it may have labels.
583
                                                            */
584
                                                           if (lyr instanceof ILabelable && ((ILabelable) lyr).isLabeled()) {
585

    
586
                                                                      ///// CHEMA ComposedLayer
587
                                                            if (group != null) {
588
                                                                    //si tenemos un grupo pendiente de pintar, pintamos
589
                                                                    // para que se pinten correctamente las etiquetas
590
                                                                    group.draw(image, g, viewPort, cancel,scale);
591
                                                                    fireLayerDrawingEvents(pendingEvents);
592
                                                                    pendingEvents.clear();
593
                                                                    group = null;
594
                                                            }
595
                                                               ///// CHEMA ComposedLayer
596

    
597

    
598
                                                                   ((ILabelable) lyr).drawLabels(image, g, viewPort, cancel, scale);
599
                                                           }
600
                                                           bNeedRecalculateCache = true;
601
                                                   }
602
                                    } catch (ReadDriverException e){
603
                                            // fmap.callNewErrorEvent(new ErrorEvent(lyr.getName(), e));
604
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
605
                                            lyr.addError(e);
606
                                            e.printStackTrace();
607
                                            lyr.setAvailable(false);
608
                                            // this.removeLayer(lyr);
609
                                    } catch (Exception e) {
610
                                            fmap.addLayerError("La capa " + lyr.getName() + " es err?nea.");
611
                                            e.printStackTrace();
612
                                            lyr.setAvailable(false);
613
                                    }
614
                                            // }
615
                                            long t2 = System.currentTimeMillis();
616
                                            System.out.println("Layer " + lyr.getName() + " "
617
                                                    + (t2-t1) + " milisecs.");
618
                                            lyr.setDirty(false);
619
                            }
620
                            ///// CHEMA ComposedLayer
621
                            if (fireAfterDrawEvent) {
622
                            ///// CHEMA ComposedLayer
623
                                    LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
624
                                    fmap.fireLayerDrawingEvent(afterEvent);
625
                            ///// CHEMA ComposedLayer
626
                            }
627
                            ///// CHEMA ComposedLayer
628
                     }
629

    
630
                    ///// CHEMA ComposedLayer
631
                    if (group != null) {
632
                                 //si tenemos un grupo pendiente de pintar, pintamos
633
                                 group.draw(image, g, viewPort, cancel,scale);
634
                                fireLayerDrawingEvents(pendingEvents);
635

    
636
                         }
637
                        ///// CHEMA ComposedLayer
638
                    if (getVirtualLayers() != null) {
639
                            getVirtualLayers().draw(image, g, viewPort, cancel,scale);
640
                    }
641
//        }
642
//        catch (ConcurrentModificationException e)
643
//        {
644
//            System.err.println(e.getMessage());
645
//        }
646
                        long tg2 = System.currentTimeMillis();
647

    
648
                        System.out.println("Draw all layer "
649
                                + (tg2-tg1) + " milisecs.");
650

    
651
        }
652

    
653
        private void fireLayerDrawingEvents(Collection events) {
654
                Iterator iter = events.iterator();
655
                LayerDrawEvent afterEvent;
656
                while (iter.hasNext()) {
657
                        afterEvent =(LayerDrawEvent)iter.next();
658
                        System.out.println("+++ evento " + afterEvent.getLayer().getName());
659
                        fmap.fireLayerDrawingEvent(afterEvent);
660
                }
661
        }
662

    
663
        /**
664
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#print(java.awt.Graphics2D,
665
         *                 com.iver.cit.gvsig.fmap.ViewPort,
666
         *                 com.iver.utiles.swing.threads.Cancellable)
667
         */
668
        public void print(Graphics2D g, ViewPort viewPort, Cancellable cancel, double scale, PrintRequestAttributeSet properties)
669
                throws ReadDriverException {
670

    
671
        // TODO: A la hora de imprimir, isWithinScale falla, porque est?
672
        // calculando la escala en pantalla, no para el layout.
673
        // Revisar esto.
674
                for (int i=0; i < layers.size(); i++) {
675
                        FLayer lyr = (FLayer) layers.get(i);
676
                        lyr.print(g, viewPort, cancel, scale, properties);
677
                        if (lyr instanceof ILabelable) {
678
                                ILabelable lLayer = (ILabelable) lyr;
679

    
680
                                lLayer.drawLabels(null, g, viewPort, cancel, scale);
681
                        }
682
                }
683
                 if (getVirtualLayers() != null) {
684
            getVirtualLayers().print( g, viewPort, cancel,scale, properties);
685
        }
686
        }
687

    
688
        /**
689
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getFullExtent()
690
         */
691
        public Rectangle2D getFullExtent() {
692
                Rectangle2D rAux = null;
693
                boolean first = true;
694

    
695

    
696
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
697
                        FLayer capa = (FLayer) iter.next();
698
                        try{
699
                        if (first) {
700
                                rAux = capa.getFullExtent();
701
                                first=false;
702
                        } else {
703
                                rAux.add(capa.getFullExtent());
704
                        }
705
                        }catch (Exception e) {
706
                                e.printStackTrace();//TODO hay que revisar para determinar el comportamiento que espera el usuario.
707
                        }
708
                }
709

    
710
                return rAux;
711
        }
712

    
713
        /**
714
         * Llama al m?todo layerAdding de los listeners dados de alta.
715
         *
716
         * @param event
717
         *
718
         * @throws CancelationException
719
         */
720
        protected void callLayerAdding(LayerCollectionEvent event)
721
                throws CancelationException {
722
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
723
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
724
                        ((LayerCollectionListener) iter.next()).layerAdding(event);
725
                }
726
        }
727

    
728
        /**
729
         * Llama al m?todo layerRemoving de los listeners dados de alta.
730
         *
731
         * @param event
732
         *
733
         * @throws CancelationException
734
         */
735
        protected void callLayerRemoving(LayerCollectionEvent event)
736
                throws CancelationException {
737
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
738
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
739
                        ((LayerCollectionListener) iter.next()).layerRemoving(event);
740
                }
741
        }
742

    
743

    
744
        /**
745
         * Llama al m?todo layerMoving de los listeners dados de alta.
746
         *
747
         * @param event
748
         *
749
         * @throws CancelationException
750
         */
751
        protected void callLayerMoving(LayerPositionEvent event)
752
                throws CancelationException {
753
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
754
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
755
                        ((LayerCollectionListener) iter.next()).layerMoving(event);
756
                }
757
        }
758

    
759
        /**
760
         * Llama al m?todo layerAdded de los listeners dados de alta.
761
         *
762
         * @param event
763
         */
764
        protected void callLayerAdded(LayerCollectionEvent event) {
765
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
766
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
767
                        ((LayerCollectionListener) iter.next()).layerAdded(event);
768
                }
769
        }
770

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

    
783
        /**
784
         * Llama al m?todo layerMoved de los listeners dados de alta.
785
         *
786
         * @param event
787
         */
788
        protected void callLayerMoved(LayerPositionEvent event) {
789
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
790
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
791
                        ((LayerCollectionListener) iter.next()).layerMoved(event);
792
                }
793
        }
794

    
795
        /**
796
         * @throws XMLException
797
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getProperties()
798
         */
799
        public XMLEntity getXMLEntity() throws XMLException {
800
                XMLEntity xml = super.getXMLEntity();
801
                xml.putProperty("numLayers", layers.size());
802

    
803
                String[] s = new String[layers.size()];
804

    
805
                for (int i = 0; i < layers.size(); i++) {
806
                        s[i] = ((FLayer) layers.get(i)).getName();
807
                }
808

    
809
                xml.putProperty("LayerNames", s);
810

    
811
                for (int i = 0; i < layers.size(); i++) {
812
                        xml.addChild(((FLayer) layers.get(i)).getXMLEntity());
813
                }
814

    
815
                return xml;
816
        }
817

    
818
        /**
819
         * DOCUMENT ME!
820
         *
821
         * @param xml DOCUMENT ME!
822
         *
823
         * @throws XMLException
824
         *
825
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
826
         */
827
        public void setXMLEntity03(XMLEntity xml) throws XMLException{
828
                super.setXMLEntity03(xml);
829
                int numLayers = xml.getIntProperty("numLayers");
830

    
831
                String[] s = xml.getStringArrayProperty("LayerNames");
832
                try {
833
                        for (int i = 0; i < numLayers; i++) {
834
                                FLayer layer = null;
835

    
836
                                String className = xml.getChild(i).getStringProperty("className");
837

    
838
                                if (className.equals(FLyrVect.class.getName())) {
839
                                        if (xml.getChild(i).contains("file")) {
840

    
841
                                                        layer = LayerFactory.createLayer(s[i],
842
                                                                        (VectorialFileDriver)LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName")),
843
                                                                        new File(xml.getChild(i).getStringProperty("file")),
844
                                                                        this.getMapContext().getViewPort().getProjection());
845

    
846
                                        } else if (true) {
847
                                                //TODO falta por implementar
848
                                        } else if (true) {
849
                                                //TODO falta por implementar
850
                                        }
851

    
852
                                        layer.setXMLEntity03(xml.getChild(i));
853
                                        // Comprobar que la proyecci?n es la misma que la de FMap
854
                                        // Si no lo es, es una capa que est? reproyectada al vuelo
855
                                        IProjection proj = layer.getProjection();
856
                                        if (proj != null)
857
                                            if (proj != fmap.getProjection())
858
                                            {
859
                                                        ICoordTrans ct = proj.getCT(fmap.getProjection());
860
                                                        layer.setCoordTrans(ct);
861
                                                        System.err.println("coordTrans = " +
862
                                                                proj.getAbrev() + " " +
863
                                                                fmap.getProjection().getAbrev());
864
                                            }
865

    
866
//                                } else if (className.equals(FLyrWMS.class.getName())) {
867
//                                        try {
868
//                                                layer = LayerFactory.createLayer(s[i],
869
//                                                                StringUtilities.string2Rect(
870
//                                                                        xml.getChild(i).getStringProperty("fullExtent")),
871
//                                                                new URL(xml.getChild(i).getStringProperty("host")),
872
//                                                                xml.getChild(i).getStringProperty("format"),
873
//                                                                xml.getChild(i).getStringProperty("layerQuery"),
874
//                                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
875
//                                                                xml.getChild(i).getStringProperty("srs"));
876
//                                        } catch (MalformedURLException e) {
877
//                                                throw new XMLException(e);
878
//                                        }
879
                                } else if (className.equals((FLyrRaster.class.getName()))) {
880
                                        //if (xml.getChild(i).contains("file")) {
881
                                        /*layer = LayerFactory.createLayer(s[i],
882
                                                        xml.getChild(i).getStringProperty("driverName"),
883
                                                        new File(xml.getChild(i).getStringProperty("file")),
884
                                                        this.getFMap().getViewPort().getProjection());*/
885
                                        layer = new FLyrRaster();
886
                                        layer.setName(s[i]);
887
                                        if (!xml.getChild(i).contains("proj"))
888
                                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
889
                                        layer.setXMLEntity03(xml.getChild(i));
890
                                        layer.load();
891

    
892
                                }else if (className.equals((FLayers.class.getName()))) {
893
                                        layer = new FLayers(getMapContext(),this);
894
                                        layer.setXMLEntity(xml.getChild(i));
895
                                } else {
896
                                        // Capas Nuevas (externas)
897
                                        try {
898
                                                Class clase = Class.forName(className);
899
                                                layer = (FLayer) clase.newInstance();
900
                                                layer.setName(s[i]);
901
                                                layer.setXMLEntity03(xml.getChild(i));
902
                                                layer.load();
903
                                        } catch (Exception e) {
904
                                                //e.printStackTrace();
905
                                                throw new XMLException(e);
906
                                        }
907
                                }
908

    
909
                                this.addLayer(layer);
910
                        }
911
                } /*azabala-modificaciones en layerfactory-
912
                catch (DriverException e) {
913
                        throw new XMLException(e);
914
                }*/
915
                catch (DriverLoadException e) {
916
            throw new XMLException(e);
917
        } catch (LoadLayerException e) {
918
                 throw new XMLException(e);
919
                }
920

    
921
        }
922

    
923
        /**
924
         * DOCUMENT ME!
925
         *
926
         * @param xml DOCUMENT ME!
927
         *
928
         * @throws XMLException
929
         *
930
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
931
         */
932
        public void setXMLEntity(XMLEntity xml) throws XMLException{
933
                super.setXMLEntity(xml);
934
                //LoadLayerException loadLayerException=new LoadLayerException();
935
                int numLayers = xml.getIntProperty("numLayers");
936

    
937
                String[] s = xml.getStringArrayProperty("LayerNames");
938
                // try {
939
                fmap.clearErrors();
940
                        for (int i = 0; i < numLayers; i++) {
941
                                try {
942
                                        this.addLayerFromXML(xml.getChild(i),s[i]);
943
                                } catch (LoadLayerException e) {
944
                                        throw new XMLException(e);
945
                                }
946

    
947

    
948
                        }
949
                /* } catch (DriverException e) {
950
                        throw new XMLException(e);
951
                } */
952
                /*if (loadLayerException.getExceptions().size()>0){
953
                        throw loadLayerException;
954
                }*/
955
        }
956

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

    
967
                        if (layer instanceof VectorialData) {
968
                                ((VectorialData) layer).process(visitor, subset);
969
                        }
970
                }
971
        }
972

    
973
        /**
974
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor)
975
         */
976
        public void process(FeatureVisitor visitor)
977
                throws ReadDriverException, VisitorException {
978
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
979
                        FLayer layer = (FLayer) iter.next();
980

    
981
                        if (layer instanceof FLayers){
982
                                FLayers lyrs=(FLayers)layer;
983
                                for (int i=0;i<lyrs.getLayersCount();i++){
984
                                        FLayer lyr=lyrs.getLayer(i);
985
                                        if (lyr.isActive()) {
986
                                                if (lyr instanceof VectorialData) {
987
                                                        ((VectorialData) lyr).process(visitor);
988
                                                }
989
                                        }
990
                                }
991
                        }
992
                        if (layer.isActive()) {
993
                                if (layer instanceof VectorialData) {
994
                                        ((VectorialData) layer).process(visitor);
995
                                }
996
                        }
997
                }
998
        }
999
        /**
1000
         * @throws ExpansionFileReadException
1001
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor, Rectangle2D)
1002
         */
1003
        public void process(FeatureVisitor visitor, Rectangle2D rect) throws ReadDriverException, ExpansionFileReadException, VisitorException {
1004
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1005
                        FLayer layer = (FLayer) iter.next();
1006

    
1007
                        if (layer.isActive()) {
1008
                                if (layer instanceof VectorialData) {
1009
                                        ((VectorialData) layer).process(visitor, rect);
1010
                                }
1011
                        }
1012
                }
1013

    
1014
        }
1015

    
1016
        /**
1017
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMapContext()
1018
         */
1019
        public MapContext getMapContext() {
1020
                return fmap;
1021
        }
1022

    
1023
        /* (non-Javadoc)
1024
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#setCoordTrans(org.cresques.cts.ICoordTrans)
1025
         */
1026
        public void setCoordTrans(ICoordTrans ct) {
1027
                super.setCoordTrans(ct);
1028

    
1029
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1030
                        FLayer layer = (FLayer) iter.next();
1031
                        layer.setCoordTrans(ct);
1032
                }
1033
        }
1034

    
1035
        /**
1036
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllActives(boolean)
1037
         */
1038
        public void setAllActives(boolean active) {
1039
                FLayer lyr;
1040

    
1041
                for (int i = 0; i < layers.size(); i++) {
1042
                        lyr = ((FLayer) layers.get(i));
1043
                        lyr.setActive(active);
1044

    
1045
                        if (lyr instanceof LayerCollection) {
1046
                                ((LayerCollection) lyr).setAllActives(active);
1047
                        }
1048
                }
1049
        }
1050

    
1051
        /**
1052
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#getActives()
1053
         */
1054
        public FLayer[] getActives() {
1055
                ArrayList ret = new ArrayList();
1056
                LayersIterator it = new LayersIterator(this) {
1057

    
1058
                        public boolean evaluate(FLayer layer) {
1059
                                return layer.isActive();
1060
                        }
1061

    
1062
                };
1063

    
1064
                while (it.hasNext())
1065
                {
1066
                        ret.add(it.next());
1067
                }
1068
                return (FLayer[]) ret.toArray(new FLayer[0]);
1069
        }
1070

    
1071
    /* (non-Javadoc)
1072
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMinScale()
1073
     */
1074
    public double getMinScale() {
1075
        return -1; // La visibilidad o no la controla cada capa
1076
                // dentro de una colecci?n
1077
    }
1078

    
1079
    /* (non-Javadoc)
1080
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMaxScale()
1081
     */
1082
    public double getMaxScale() {
1083
        return -1;
1084
    }
1085
    public void setMinScale(double minScale)
1086
    {
1087
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1088
                        FLayer lyr = (FLayer) iter.next();
1089
                        lyr.setMinScale(minScale);
1090
                }
1091
    }
1092
    public void setMaxScale(double maxScale)
1093
    {
1094
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1095
                        FLayer lyr = (FLayer) iter.next();
1096
                        lyr.setMinScale(maxScale);
1097
                }
1098
    }
1099
    public void setActive(boolean b){
1100
            super.setActive(b);
1101
            for (int i=0;i<layers.size();i++){
1102
                    ((FLayer)layers.get(i)).setActive(b);
1103
            }
1104
    }
1105

    
1106
        /* (non-Javadoc)
1107
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#addLayerListener(com.iver.cit.gvsig.fmap.layers.LayerListener)
1108
         */
1109
        public boolean addLayerListener(LayerListener o) {
1110
                for (int i = 0; i < layers.size(); i++)
1111
                        ((FLayer) layers.get(i)).addLayerListener(o);
1112
                return true;
1113
        }
1114

    
1115
        public XMLItem[] getInfo(Point p, double tolerance, Cancellable cancel) throws ReadDriverException, VisitorException, LoadLayerException {
1116
                int i;
1117
                Vector items = new Vector();
1118
                FLayer layer;
1119
                XMLItem[] aux;
1120
                for (i = 0; i < this.layers.size(); i++){
1121
                        layer = (FLayer)layers.get(i);
1122
                        if (layer instanceof InfoByPoint){
1123
                                InfoByPoint queryable_layer = (InfoByPoint) layer;
1124
                                aux = queryable_layer.getInfo(p, tolerance, null);
1125
                                if (!(queryable_layer instanceof FLayers)){
1126
                                        for(int j = 0; j < aux.length; j++){
1127
                                                items.add(aux[j]);
1128
                                        }
1129
                                }
1130
                        }
1131
                }
1132
                return (XMLItem[])items.toArray(new XMLItem[0]);
1133

    
1134
//                for (i = 0; i < this.layers.size(); i++){
1135
//                        FLayer laCapa = (FLayer) layers.get(i);
1136
//                        if (laCapa instanceof FLyrVect){
1137
//                        }
1138
//                        else if (laCapa instanceof RasterOperations) {
1139
//                                try {
1140
//                                        RasterOperations layer = (RasterOperations) laCapa;
1141
//                                        sb.append(layer.getInfo(p, tolerance));
1142
//                                } catch (DriverException e) {
1143
//                                        e.printStackTrace();
1144
//                                }
1145
//                        }
1146
//                        else if (laCapa instanceof InfoByPoint) {
1147
//                                try {
1148
//                                        InfoByPoint layer = (InfoByPoint) laCapa;
1149
//                                        sb.append(layer.getInfo(p, tolerance));
1150
//                                } catch (DriverException e) {
1151
//                                        e.printStackTrace();
1152
//                                }
1153
//                        }
1154
//                }
1155

    
1156
        }
1157

    
1158
        public ImageIcon getTocImageIcon() {
1159
                return new ImageIcon(MapControl.class.getResource("images/layerGroup.png"));
1160
        }
1161

    
1162
        public boolean isDirty() {
1163
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1164
                        FLayer lyr = (FLayer) iter.next();
1165
                        if (lyr.isDirty())
1166
                                return true;
1167
                }
1168
                return false;
1169
        }
1170

    
1171
        public void setDirty(boolean dirty) {
1172
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1173
                        FLayer lyr = (FLayer) iter.next();
1174
                        lyr.setDirty(dirty);
1175
                }
1176

    
1177
        }
1178

    
1179
        public boolean addLayerFromXMLEntity(XMLEntity xml, String name) throws LoadLayerException {
1180
                fmap.clearErrors();
1181
                this.addLayerFromXML(xml,name);
1182

    
1183
                return (fmap.getLayersError().size() == 0);
1184

    
1185
        }
1186

    
1187
        private void addLayerFromXML(XMLEntity xml, String name) throws LoadLayerException {
1188
                FLayer layer = null;
1189

    
1190
                try {
1191
                if (name == null) name = xml.getName();
1192

    
1193

    
1194
                String className = xml.getStringProperty("className");
1195

    
1196
                if (className.equals(FLyrVect.class.getName())) {
1197
                        String type = xml.getStringProperty("type");
1198
                        if ("vectorial".equals(type)){
1199
                                //String recordsetName = xml.getChild(i).getStringProperty("recordset-name");
1200
                IProjection proj = null;
1201
                if (xml.contains("proj")) {
1202
                    proj = CRSFactory.getCRS(xml.getStringProperty("proj"));
1203
                }
1204
                else
1205
                {
1206
                    proj = this.getMapContext().getViewPort().getProjection();
1207
                }
1208
                                if (xml.contains("file")) {
1209
                                        Driver d;
1210
                                        try {
1211
                                                d = LayerFactory.getDM().getDriver(xml.getStringProperty("driverName"));
1212
                                        } catch (DriverLoadException e1) {
1213
                                                throw new DriverLayerException(name,e1);
1214
                                        }
1215
                                        layer = LayerFactory.createLayer(name, (VectorialFileDriver) d,
1216
                                                                                                        new File(xml.getStringProperty("file")),
1217
                                                                                                        proj);
1218

    
1219

    
1220
                                }
1221
                if (xml.contains("db")) {
1222

    
1223
                    String driverName = xml.getStringProperty("db");
1224
                    VectorialDatabaseDriver driver;
1225
                    try {
1226
                        driver = (VectorialDatabaseDriver) LayerFactory.getDM().getDriver(driverName);
1227
                        //Hay que separar la carga de los datos del XMLEntity del load.
1228
                        driver.setXMLEntity(xml.getChild(2));
1229

    
1230
                        boolean loadOk = false;
1231
                               ((DefaultDBDriver)driver).load();
1232
                               if (((DefaultDBDriver)driver).getConnection() != null) {
1233
                                       loadOk = true;
1234
                               }
1235
                        layer = LayerFactory.createDBLayer(driver, name, proj);
1236
                        if (!loadOk) {
1237
                                layer.setAvailable(false);
1238
                        }
1239

    
1240
                    } catch (DriverLoadException e) {
1241
                        throw new DriverLayerException(name,e);
1242
                    } catch (XMLException e) {
1243
                            throw new DriverLayerException(name,e);
1244
                                        } catch (ReadDriverException e) {
1245
                                                throw new DriverLayerException(name,e);
1246
                                        }
1247

    
1248
                }
1249
                // Clases con algun driver gen?rico creado por otro
1250
                // programador
1251
                if (xml.contains("other")) {
1252

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

    
1296

    
1297
                        } else if ("raster".equals(type)) {
1298
/*                                                if (xml.getChild(i).contains("file")) {
1299
                                        Driver d = LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName"));
1300
                                                                                        layer = LayerFactory.createLayer(s[i],
1301
                                                                                                        ,
1302
                                                                                                        new File(xml.getChild(i).getStringProperty("file")),
1303
                                                                                                        this.getFMap().getViewPort().getProjection());
1304

1305
                                }
1306
*/                                        }
1307

    
1308
                        layer.setXMLEntity(xml);
1309

    
1310
//                } else if (className.equals(FLyrWMS.class.getName())) {
1311
//                        try {
1312
//                                layer = LayerFactory.createLayer(s[i],
1313
//                                                StringUtilities.string2Rect(
1314
//                                                        xml.getChild(i).getStringProperty("fullExtent")),
1315
//                                                new URL(xml.getChild(i).getStringProperty("host")),
1316
//                                                xml.getChild(i).getStringProperty("format"),
1317
//                                                xml.getChild(i).getStringProperty("layerQuery"),
1318
//                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
1319
//                                                xml.getChild(i).getStringProperty("srs"));
1320
//                                layer.setXMLEntity(xml.getChild(i));
1321
//                        } catch (MalformedURLException e) {
1322
//                                throw new XMLException(e);
1323
//                        }
1324
                } else if (className.equals((FLyrRaster.class.getName()))) {
1325
                        //if (xml.getChild(i).contains("file")) {
1326
                        /*layer = LayerFactory.createLayer(s[i],
1327
                                        xml.getChild(i).getStringProperty("driverName"),
1328
                                        new File(xml.getChild(i).getStringProperty("file")),
1329
                                        this.getFMap().getViewPort().getProjection());*/
1330
                        layer = new FLyrRaster();
1331
                        layer.setName(name);
1332
                        if (!xml.contains("proj"))
1333
                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
1334
                        layer.setXMLEntity(xml);
1335
                        layer.load();
1336

    
1337
                }else if (className.equals((FLayers.class.getName()))) {
1338
                        layer = new FLayers(getMapContext(),this);
1339
                        layer.setXMLEntity(xml);
1340
                } else {
1341
                        // Capas Nuevas (externas)
1342
                                Class clase = Class.forName(className);
1343
                                layer = (FLayer) clase.newInstance();
1344
                                layer.setName(name);
1345
                                layer.setXMLEntity(xml);
1346
                                layer.load();
1347
                }
1348

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

    
1375
                }
1376
            }
1377
//        }catch (LoadLayerException e) {
1378
//                        fmap.addLayerError(xml.getStringProperty("name"));
1379
//                                //loadLayerException.addException(e);
1380
//                        /*if (layer!=null){
1381
//                layer.setActive(false);
1382
//                        layer.setVisible(false);
1383
//                        this.addLayer(layer);
1384
//                }*/
1385
//                        //throw new XMLException(e);
1386
//            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1387
//            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1388
//            // logger.debug(e.fillInStackTrace());
1389
//            e.printStackTrace();
1390
        } catch (XMLException e) {
1391
                fmap.addLayerError(xml.getStringProperty("name"));
1392
                        throw new LoadLayerException(name,e);
1393
                } catch (ClassNotFoundException e) {
1394
                        fmap.addLayerError(xml.getStringProperty("name"));
1395
                        throw new LoadLayerException(name,e);
1396
                } catch (InstantiationException e) {
1397
                        fmap.addLayerError(xml.getStringProperty("name"));
1398
                        throw new LoadLayerException(name,e);
1399
                } catch (IllegalAccessException e) {
1400
                        fmap.addLayerError(xml.getStringProperty("name"));
1401
                        throw new LoadLayerException(name,e);
1402
//                        jaume
1403
//                } catch (ReadDriverException e) {
1404
//                        fmap.addLayerError(xml.getStringProperty("name"));
1405
//                        throw new LoadLayerException(name,e);
1406
                } catch (LoadLayerException e){
1407
                        fmap.addLayerError(xml.getStringProperty("name"));
1408
                        throw e;
1409
                }
1410
        }
1411

    
1412
        private void addLayerFromXMLNew(XMLEntity xml, String name) {
1413
                FLayer layer = null;
1414

    
1415

    
1416
                try {
1417
                String className = xml.getStringProperty("className");
1418

    
1419
                if (className.equals((FLayers.class.getName()))){
1420
                        layer = new FLayers(getMapContext(),this);
1421
                } else {
1422
//                         Por compatibilidad
1423
                        if (className.equals(FLyrVect.class.getName())) {
1424
                                if (xml.contains("file")) {
1425
                                        layer = new FLayerFileVectorial();
1426
                                } else if (xml.contains("db")) {
1427
                                        try {
1428
                                                layer = (FLayer)((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create("com.iver.cit.gvsig.fmap.layers.FLayerJDBCVectorial");
1429
                                        } catch (Exception e) {
1430
                                                throw new XMLException(new Exception("No se tiene registrada la capa de tipo JDBC"));
1431
                                        }
1432
                                        //className = FLayerJDBCVectorial.class.getName();
1433
                                } else if (xml.contains("other")){
1434
                                        layer = new FLayerGenericVectorial();
1435
                                } else {
1436
                                        throw new XMLException(new Exception("Capa vectorial de tipo no reconocido"));
1437
                                }
1438
//                                Fin por compatibilidad
1439
                        } else {
1440
                                try {
1441
                                        layer = (FLayer)(((ExtensionPoint)ExtensionPointsSingleton.getInstance().get("Layers")).create(className));
1442
                                } catch (Exception e) {
1443
                                        //puende que no este registrada como punto de extension
1444
                                        Class clase = Class.forName(className);
1445
                                        layer = (FLayer) clase.newInstance();
1446
                                        // FIXME: Hacemos algo aqui o dejamos que suba el error?
1447
                                }
1448
                        }
1449

    
1450
                }
1451
                layer.setXMLEntity(xml);
1452
                if (name != null) layer.setName(name);
1453
                layer.load();
1454

    
1455
                this.addLayer(layer);
1456
                logger.debug("layer: "+ layer.getName() +" loaded");
1457
                // Comprobar que la proyecci?n es la misma que la de FMap
1458
        // Si no lo es, es una capa que est? reproyectada al vuelo
1459
        IProjection proj = layer.getProjection();
1460
        if ((proj != null))
1461
            if (proj != getMapContext().getProjection())
1462
            {
1463
                ICoordTrans ct = proj.getCT(getMapContext().getProjection());
1464
                // TODO: REVISAR CON LUIS
1465
                // Se lo fijamos a todas, luego cada una que se reproyecte
1466
                // si puede, o que no haga nada
1467
                layer.setCoordTrans(ct);
1468
                // NOTA: DESPU?S DE ESTO DEBER?AMOS CREAR LAS ETIQUETAS
1469
                // SI ES NECESARIO.
1470
                // TODO: REVISAR A FONDO ESTO, PORQUE LAS ETIQUETAS SE CREAN
1471
                // 2 VECES SI HAY REPROYECC?N
1472
                if (layer instanceof FLyrVect)
1473
                {
1474
                    FLyrVect lyrVect = (FLyrVect)layer;
1475
                    VectorialLegend legend = (VectorialLegend) lyrVect.getLegend();
1476
//                    deprecated (jaume)
1477
//                    if (legend.getLabelField() != null) {
1478
//                        lyrVect.createLabelLayer(lyrVect.getRecordset());
1479
//                    }
1480

    
1481
                }
1482
            }
1483
        }catch (Exception e) {
1484
                        fmap.addLayerError(xml.getStringProperty("name"));
1485
                                //loadLayerException.addException(e);
1486
                        /*if (layer!=null){
1487
                layer.setActive(false);
1488
                        layer.setVisible(false);
1489
                        this.addLayer(layer);
1490
                }*/
1491
                        //throw new XMLException(e);
1492
            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1493
            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1494
            // logger.debug(e.fillInStackTrace());
1495
            e.printStackTrace();
1496
        }
1497
        }
1498

    
1499
}