Statistics
| Revision:

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

History | View | Annotate | Download (49.5 KB)

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

    
43
import java.awt.Graphics2D;
44
import java.awt.Point;
45
import java.awt.geom.Rectangle2D;
46
import java.awt.image.BufferedImage;
47
import java.awt.image.WritableRaster;
48
import java.io.File;
49
import java.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.hardcode.gdbms.driver.exceptions.ReadDriverException;
65
import com.iver.cit.gvsig.exceptions.expansionfile.ExpansionFileReadException;
66
import com.iver.cit.gvsig.exceptions.layers.DriverLayerException;
67
import com.iver.cit.gvsig.exceptions.layers.LoadLayerException;
68
import com.iver.cit.gvsig.exceptions.visitors.VisitorException;
69
import com.iver.cit.gvsig.fmap.MapContext;
70
import com.iver.cit.gvsig.fmap.MapControl;
71
import com.iver.cit.gvsig.fmap.ViewPort;
72
import com.iver.cit.gvsig.fmap.core.ILabelable;
73
import com.iver.cit.gvsig.fmap.crs.CRSFactory;
74
import com.iver.cit.gvsig.fmap.drivers.DefaultJDBCDriver;
75
import com.iver.cit.gvsig.fmap.drivers.IVectorialDatabaseDriver;
76
import com.iver.cit.gvsig.fmap.drivers.VectorialDriver;
77
import com.iver.cit.gvsig.fmap.drivers.VectorialFileDriver;
78
import com.iver.cit.gvsig.fmap.layers.layerOperations.ComposedLayer;
79
import com.iver.cit.gvsig.fmap.layers.layerOperations.InfoByPoint;
80
import com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection;
81
import com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData;
82
import com.iver.cit.gvsig.fmap.layers.layerOperations.XMLItem;
83
import com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor;
84
import com.iver.cit.gvsig.fmap.rendering.IVectorialLegend;
85
import com.iver.utiles.IPersistance;
86
import com.iver.utiles.XMLEntity;
87
import com.iver.utiles.extensionPoints.ExtensionPoint;
88
import com.iver.utiles.extensionPoints.ExtensionPointsSingleton;
89
import com.iver.utiles.swing.threads.Cancellable;
90

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

    
99

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

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

    
124

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

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

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

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

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

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

    
189
                doAddLayer(pos,layer);
190

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

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

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

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

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

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

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

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

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

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

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

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

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

    
312

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

    
326
                };
327

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

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

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

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

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

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

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

    
377
                return null;
378
        }
379

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

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

    
411
        /**
412
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#draw(java.awt.image.BufferedImage,
413
         *                 java.awt.Graphics2D, com.iver.cit.gvsig.fmap.ViewPort)
414
         */
415
        public void draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
416
                        Cancellable cancel,double scale) throws ReadDriverException {
417
                draw(image,g,viewPort,cancel, scale, null);
418
        }
419

    
420

    
421
        public ComposedLayer draw(BufferedImage image, Graphics2D g, ViewPort viewPort,
422
                        Cancellable cancel,double scale, ComposedLayer group) throws ReadDriverException {
423
            //double scale = getFMap().getScaleView();
424
//                Iterator iter = layers.iterator();
425
//        try
426
//        {
427
                boolean bNeedRecalculateCache = false;
428

    
429
                           ///// CHEMA ComposedLayer
430
                    long tg1 = System.currentTimeMillis();
431
                        ///// CHEMA ComposedLayer
432

    
433

    
434

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

    
443

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

    
453
                            if (lyr.isVisible()) {
454

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

470
                                                 }
471
                                                 else */
472

    
473
                                            if (lyr.isCachingDrawnLayers())
474
                                            {
475
                                                    if ((bNeedRecalculateCache) || (lyr.getCacheImageDrawnLayers()==null))
476
                                                    {
477
                                                            //if (bNeedRecalculateCache)
478
                                                            // {
479

    
480
                                                               ///// CHEMA ComposedLayer
481
                                                            if (group != null) {
482
                                                                    //si tenemos un grupo pendiente de pintar, pintamos
483
                                                                    // para que la cache sea fiable
484
                                                                    group.draw(image, g, viewPort, cancel,scale);
485
                                                                    group = null;
486
                                                            }
487
                                                            ///// CHEMA ComposedLayer
488

    
489

    
490

    
491

    
492

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

    
511

    
512
                                                                                                                              ///// CHEMA ComposedLayer
513
                                                                    // Checks for draw group (ComposedLayer)
514
                                                                    if (group != null) {
515
                                                                            // it's going to load a cache image,
516
                                                                            // the current draw isn't needed
517
                                                                            group = null;
518
                                                                    }
519
                                                                    ///// CHEMA ComposedLayer
520

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

    
535
                                                    // Checks for draw group (ComposedLayer)
536
                                                    if (group != null) {
537
                                                            if (lyr instanceof FLayers){
538
                                                                    group = ((FLayers)lyr).draw(image, g, viewPort, cancel,scale,group);
539
                                                                    LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
540
                                                                    fmap.fireLayerDrawingEvent(afterEvent);
541
                                                            } else {
542
                                                                    //If layer can be added to the group, does it
543
                                                                    if (group.canAdd(lyr)) {
544
                                                                            group.add(lyr);
545
                                                                    } else {
546
                                                                            // draw the 'pending to draw' layer group
547
                                                                            group.draw(image, g, viewPort, cancel,scale);
548

    
549
                                                                            // gets a new group instance
550
                                                                            group = lyr.newComposedLayer();
551
                                                                            // if layer hasn't group, draws it inmediately
552
                                                                            if (group == null) {
553
                                                                                    if (lyr instanceof FLayers){
554
                                                                                            group = ((FLayers)lyr).draw(image, g, viewPort, cancel,scale,group);
555
                                                                                    } else {
556
                                                                                            lyr.draw(image, g, viewPort, cancel,scale);
557
                                                                                    }
558
                                                                                    LayerDrawEvent afterEvent = new LayerDrawEvent(lyr, g, viewPort, LayerDrawEvent.LAYER_AFTER_DRAW);
559
                                                                                    fmap.fireLayerDrawingEvent(afterEvent);
560
                                                                            } else {
561
                                                                                    // add the layer to the group
562
                                                                                    group.setMapContext(fmap);
563
                                                                                    group.add(lyr);
564

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

    
588
                                                    /*
589
                                                     * (Jaume)
590
                                                     * If the layer is instance of ILabelable then it may have labels.
591
                                                     */
592
                                                    if (lyr instanceof ILabelable && ((ILabelable) lyr).isLabeled()) {
593

    
594
                                                            ///// CHEMA ComposedLayer
595
                                                            if (group != null) {
596
                                                                    //si tenemos un grupo pendiente de pintar, pintamos
597
                                                                    // para que se pinten correctamente las etiquetas
598
                                                                    group.draw(image, g, viewPort, cancel,scale);
599
                                                                    group = null;
600
                                                            }
601
                                                            ///// CHEMA ComposedLayer
602

    
603

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

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

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

    
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 " +this.getName() + " " +
649
                                + (tg2-tg1) + " milisecs.");
650
                        ///// CHEMA ComposedLayer
651
                    return group;
652
                    ///// CHEMA ComposedLayer
653
        }
654
        /**
655
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#print(java.awt.Graphics2D,
656
         *                 com.iver.cit.gvsig.fmap.ViewPort,
657
         *                 com.iver.utiles.swing.threads.Cancellable)
658
         */
659
        public void print(Graphics2D g, ViewPort viewPort, Cancellable cancel, double scale, PrintRequestAttributeSet properties)
660
                throws ReadDriverException {
661
                this.print(g, viewPort, cancel, scale, properties, null);
662
        }
663

    
664
        public ComposedLayer print(Graphics2D g, ViewPort viewPort, Cancellable cancel, double scale, PrintRequestAttributeSet properties, ComposedLayer group)
665
        throws ReadDriverException {
666

    
667
        // TODO: A la hora de imprimir, isWithinScale falla, porque est?
668
        // calculando la escala en pantalla, no para el layout.
669
        // Revisar esto.
670

    
671
                // TODO: We have to check when we have to call the drawLabels method when exists a ComposedLayer group.
672
                for (int i=0; i < layers.size(); i++) {
673
                        FLayer lyr = (FLayer) layers.get(i);
674

    
675
                        try{
676

    
677
                                ///// CHEMA ComposedLayer
678
                                // Checks for draw group (ComposedLayer)
679
                                if (group != null) {
680
                                        if (lyr instanceof FLayers){
681
                                                group = ((FLayers)lyr).print(g, viewPort, cancel,scale,properties,group);
682
                                        } else {
683
                                                // If layer can be added to the group, does it
684
                                                if (group.canAdd(lyr) && !(lyr instanceof ILabelable && ((ILabelable) lyr).isLabeled())){
685
                                                        group.add(lyr);
686
                                                } else {
687
                                                        // draw the 'pending to draw' layer group
688
                                                        group.print(g,viewPort,cancel,scale,properties);
689

    
690
                                                        // gets a new group instance
691
                                                        if (lyr instanceof ILabelable && ((ILabelable) lyr).isLabeled()) {
692
                                                                group = lyr.newComposedLayer();
693
                                                        } else {
694
                                                                group = null;
695
                                                        }
696
                                                        // if layer hasn't group, draws it inmediately
697
                                                        if (group == null) {
698
                                                                if (lyr instanceof FLayers){
699
                                                                        group = ((FLayers)lyr).print(g, viewPort, cancel,scale,properties,group);
700
                                                                } else {
701
                                                                        lyr.print(g, viewPort, cancel,scale,properties);
702
                                                                        if (lyr instanceof ILabelable && ((ILabelable) lyr).isLabeled()) {
703
                                                                                ILabelable lLayer = (ILabelable) lyr;
704

    
705
                                                                                lLayer.drawLabels(null, g, viewPort, cancel, scale);
706
                                                                        }
707
                                                                }
708
                                                        } else {
709
                                                                // add the layer to the group
710
                                                                group.setMapContext(fmap);
711
                                                                group.add(lyr);
712

    
713
                                                        }
714

    
715
                                                }
716
                                        }
717
                                } else {
718
                                        // gets a new group instance
719
                                        group = lyr.newComposedLayer();
720
                                        // if layer hasn't group, draws it inmediately
721
                                        if (group == null) {
722
                                                if (lyr instanceof FLayers){
723
                                                        group = ((FLayers)lyr).print(g, viewPort, cancel,scale,properties,group);
724
                                                } else {
725
                                                        lyr.print(g, viewPort, cancel,scale,properties);
726
                                                        if (lyr instanceof ILabelable && ((ILabelable) lyr).isLabeled()) {
727
                                                                ILabelable lLayer = (ILabelable) lyr;
728

    
729
                                                                lLayer.drawLabels(null, g, viewPort, cancel, scale);
730
                                                        }
731
                                                }
732
                                        } else {
733
                                                // add the layer to the group
734
                                                group.setMapContext(fmap);
735
                                                group.add(lyr);
736

    
737
                                        }
738
                                }
739
                                ///// CHEMA ComposedLayer
740

    
741
                        } catch (Exception e){
742
                                fmap.addLayerError("Error en la impresion de la capa " + lyr.getName() + ": " + e.getMessage());
743
                                e.printStackTrace();
744
                        }
745

    
746
                }
747

    
748
                ///// CHEMA ComposedLayer
749
                if (group != null && this.getParentLayer() == null) {
750
                                //si tenemos un grupo pendiente de pintar, pintamos
751
                                group.print(g, viewPort, cancel,scale,properties);
752
                                group = null;
753

    
754
                }
755
                ///// CHEMA ComposedLayer
756

    
757
                if (getVirtualLayers() != null) {
758
                        getVirtualLayers().print( g, viewPort, cancel, scale, properties);
759
                }
760

    
761
                ///// CHEMA ComposedLayer
762
                return group;
763
                ///// CHEMA ComposedLayer
764
        }
765

    
766
        /**
767
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getFullExtent()
768
         */
769
        public Rectangle2D getFullExtent() {
770
                Rectangle2D rAux = null;
771
                boolean first = true;
772

    
773

    
774
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
775
                        FLayer capa = (FLayer) iter.next();
776
                        try{
777
                        if (first) {
778
                                rAux = capa.getFullExtent();
779
                                first=false;
780
                        } else {
781
                                rAux.add(capa.getFullExtent());
782
                        }
783
                        }catch (Exception e) {
784
                                e.printStackTrace();//TODO hay que revisar para determinar el comportamiento que espera el usuario.
785
                        }
786
                }
787

    
788
                return rAux;
789
        }
790

    
791
        /**
792
         * Llama al m?todo layerAdding de los listeners dados de alta.
793
         *
794
         * @param event
795
         *
796
         * @throws CancelationException
797
         */
798
        protected void callLayerAdding(LayerCollectionEvent event)
799
                throws CancelationException {
800
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
801
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
802
                        ((LayerCollectionListener) iter.next()).layerAdding(event);
803
                }
804
        }
805

    
806
        /**
807
         * Llama al m?todo layerRemoving de los listeners dados de alta.
808
         *
809
         * @param event
810
         *
811
         * @throws CancelationException
812
         */
813
        protected void callLayerRemoving(LayerCollectionEvent event)
814
                throws CancelationException {
815
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
816
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
817
                        ((LayerCollectionListener) iter.next()).layerRemoving(event);
818
                }
819
        }
820

    
821

    
822
        /**
823
         * Llama al m?todo layerMoving de los listeners dados de alta.
824
         *
825
         * @param event
826
         *
827
         * @throws CancelationException
828
         */
829
        protected void callLayerMoving(LayerPositionEvent event)
830
                throws CancelationException {
831
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
832
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
833
                        ((LayerCollectionListener) iter.next()).layerMoving(event);
834
                }
835
        }
836

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

    
849
        /**
850
         * Llama al m?todo layerRemoved de los listeners dados de alta.
851
         *
852
         * @param event
853
         */
854
        protected void callLayerRemoved(LayerCollectionEvent event) {
855
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
856
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
857
                        ((LayerCollectionListener) iter.next()).layerRemoved(event);
858
                }
859
        }
860

    
861
        /**
862
         * Llama al m?todo layerMoved de los listeners dados de alta.
863
         *
864
         * @param event
865
         */
866
        protected void callLayerMoved(LayerPositionEvent event) {
867
            ArrayList aux = (ArrayList) layerCollectionListeners.clone();
868
                for (Iterator iter = aux.iterator(); iter.hasNext();) {
869
                        ((LayerCollectionListener) iter.next()).layerMoved(event);
870
                }
871
        }
872

    
873
        /**
874
         * @throws XMLException
875
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getProperties()
876
         */
877
        public XMLEntity getXMLEntity() throws XMLException {
878
                XMLEntity xml = super.getXMLEntity();
879
                xml.putProperty("numLayers", layers.size());
880

    
881
                String[] s = new String[layers.size()];
882

    
883
                for (int i = 0; i < layers.size(); i++) {
884
                        s[i] = ((FLayer) layers.get(i)).getName();
885
                }
886

    
887
                xml.putProperty("LayerNames", s);
888

    
889
                for (int i = 0; i < layers.size(); i++) {
890
                        try {
891
                                xml.addChild(((FLayer) layers.get(i)).getXMLEntity());
892
                        }catch (XMLException e) {
893
                                e.printStackTrace();
894
                        }
895
                }
896

    
897
                return xml;
898
        }
899

    
900
        /**
901
         * DOCUMENT ME!
902
         *
903
         * @param xml DOCUMENT ME!
904
         *
905
         * @throws XMLException
906
         *
907
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
908
         */
909
        public void setXMLEntity03(XMLEntity xml) throws XMLException{
910
                super.setXMLEntity03(xml);
911
                int numLayers = xml.getIntProperty("numLayers");
912

    
913
                String[] s = xml.getStringArrayProperty("LayerNames");
914
                try {
915
                        for (int i = 0; i < numLayers; i++) {
916
                                FLayer layer = null;
917

    
918
                                String className = xml.getChild(i).getStringProperty("className");
919

    
920
                                if (className.equals(FLyrVect.class.getName())) {
921
                                        if (xml.getChild(i).contains("file")) {
922

    
923
                                                        layer = LayerFactory.createLayer(s[i],
924
                                                                        (VectorialFileDriver)LayerFactory.getDM().getDriver(xml.getChild(i).getStringProperty("driverName")),
925
                                                                        new File(xml.getChild(i).getStringProperty("file")),
926
                                                                        this.getMapContext().getViewPort().getProjection());
927

    
928
                                        } else if (true) {
929
                                                //TODO falta por implementar
930
                                        } else if (true) {
931
                                                //TODO falta por implementar
932
                                        }
933

    
934
                                        layer.setXMLEntity03(xml.getChild(i));
935
                                        // Comprobar que la proyecci?n es la misma que la de FMap
936
                                        // Si no lo es, es una capa que est? reproyectada al vuelo
937
                                        IProjection proj = layer.getProjection();
938
                                        if (proj != null)
939
                                            if (proj != fmap.getProjection())
940
                                            {
941
                                                        ICoordTrans ct = proj.getCT(fmap.getProjection());
942
                                                        layer.setCoordTrans(ct);
943
                                                        System.err.println("coordTrans = " +
944
                                                                proj.getAbrev() + " " +
945
                                                                fmap.getProjection().getAbrev());
946
                                            }
947

    
948
//                                } else if (className.equals(FLyrWMS.class.getName())) {
949
//                                        try {
950
//                                                layer = LayerFactory.createLayer(s[i],
951
//                                                                StringUtilities.string2Rect(
952
//                                                                        xml.getChild(i).getStringProperty("fullExtent")),
953
//                                                                new URL(xml.getChild(i).getStringProperty("host")),
954
//                                                                xml.getChild(i).getStringProperty("format"),
955
//                                                                xml.getChild(i).getStringProperty("layerQuery"),
956
//                                                                xml.getChild(i).getStringProperty("infoLayerQuery"),
957
//                                                                xml.getChild(i).getStringProperty("srs"));
958
//                                        } catch (MalformedURLException e) {
959
//                                                throw new XMLException(e);
960
//                                        }
961
                                } else if (className.equals((FLyrRaster.class.getName()))) {
962
                                        //if (xml.getChild(i).contains("file")) {
963
                                        /*layer = LayerFactory.createLayer(s[i],
964
                                                        xml.getChild(i).getStringProperty("driverName"),
965
                                                        new File(xml.getChild(i).getStringProperty("file")),
966
                                                        this.getFMap().getViewPort().getProjection());*/
967
                                        layer = new FLyrRaster();
968
                                        layer.setName(s[i]);
969
                                        if (!xml.getChild(i).contains("proj"))
970
                                                ((FLyrRaster)layer).setProjection(this.getMapContext().getViewPort().getProjection());
971
                                        layer.setXMLEntity03(xml.getChild(i));
972
                                        layer.load();
973

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

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

    
1003
        }
1004

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

    
1019
                String[] s = xml.getStringArrayProperty("LayerNames");
1020
                // try {
1021
                fmap.clearErrors();
1022
                        for (int i = 0; i < numLayers; i++) {
1023
                                try {
1024
                                        this.addLayerFromXML(xml.getChild(i),s[i]);
1025
                                } catch (LoadLayerException e) {
1026
                                        throw new XMLException(e);
1027
                                }
1028

    
1029

    
1030
                        }
1031
                /* } catch (DriverException e) {
1032
                        throw new XMLException(e);
1033
                } */
1034
                /*if (loadLayerException.getExceptions().size()>0){
1035
                        throw loadLayerException;
1036
                }*/
1037
        }
1038

    
1039
        /**
1040
         * @throws ExpansionFileReadException
1041
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor,
1042
         *                 FBitSet)
1043
         */
1044
        public void process(FeatureVisitor visitor, FBitSet subset)
1045
                throws ReadDriverException, ExpansionFileReadException, VisitorException {
1046
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1047
                        FLayer layer = (FLayer) iter.next();
1048

    
1049
                        if (layer instanceof VectorialData) {
1050
                                ((VectorialData) layer).process(visitor, subset);
1051
                        }
1052
                }
1053
        }
1054

    
1055
        /**
1056
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor)
1057
         */
1058
        public void process(FeatureVisitor visitor)
1059
                throws ReadDriverException, VisitorException {
1060
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1061
                        FLayer layer = (FLayer) iter.next();
1062

    
1063
                        if (layer instanceof FLayers){
1064
                                FLayers lyrs=(FLayers)layer;
1065
                                for (int i=0;i<lyrs.getLayersCount();i++){
1066
                                        FLayer lyr=lyrs.getLayer(i);
1067
                                        if (lyr.isActive()) {
1068
                                                if (lyr instanceof VectorialData) {
1069
                                                        ((VectorialData) lyr).process(visitor);
1070
                                                }
1071
                                        }
1072
                                }
1073
                        }
1074
                        if (layer.isActive()) {
1075
                                if (layer instanceof VectorialData) {
1076
                                        ((VectorialData) layer).process(visitor);
1077
                                }
1078
                        }
1079
                }
1080
        }
1081
        /**
1082
         * @throws ExpansionFileReadException
1083
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor, Rectangle2D)
1084
         */
1085
        public void process(FeatureVisitor visitor, Rectangle2D rect) throws ReadDriverException, ExpansionFileReadException, VisitorException {
1086
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1087
                        FLayer layer = (FLayer) iter.next();
1088

    
1089
                        if (layer.isActive()) {
1090
                                if (layer instanceof VectorialData) {
1091
                                        ((VectorialData) layer).process(visitor, rect);
1092
                                }
1093
                        }
1094
                }
1095

    
1096
        }
1097

    
1098
        /**
1099
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMapContext()
1100
         */
1101
        public MapContext getMapContext() {
1102
                return fmap;
1103
        }
1104

    
1105
        /* (non-Javadoc)
1106
         * @see com.iver.cit.gvsig.fmap.layers.FLayer#setCoordTrans(org.cresques.cts.ICoordTrans)
1107
         */
1108
        public void setCoordTrans(ICoordTrans ct) {
1109
                super.setCoordTrans(ct);
1110

    
1111
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1112
                        FLayer layer = (FLayer) iter.next();
1113
                        layer.setCoordTrans(ct);
1114
                }
1115
        }
1116

    
1117
        /**
1118
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllActives(boolean)
1119
         */
1120
        public void setAllActives(boolean active) {
1121
                FLayer lyr;
1122

    
1123
                for (int i = 0; i < layers.size(); i++) {
1124
                        lyr = ((FLayer) layers.get(i));
1125
                        lyr.setActive(active);
1126

    
1127
                        if (lyr instanceof LayerCollection) {
1128
                                ((LayerCollection) lyr).setAllActives(active);
1129
                        }
1130
                }
1131
        }
1132

    
1133
        /**
1134
         * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#getActives()
1135
         */
1136
        public FLayer[] getActives() {
1137
                ArrayList ret = new ArrayList();
1138
                LayersIterator it = new LayersIterator(this) {
1139

    
1140
                        public boolean evaluate(FLayer layer) {
1141
                                return layer.isActive();
1142
                        }
1143

    
1144
                };
1145

    
1146
                while (it.hasNext())
1147
                {
1148
                        ret.add(it.next());
1149
                }
1150
                return (FLayer[]) ret.toArray(new FLayer[0]);
1151
        }
1152

    
1153
    /* (non-Javadoc)
1154
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMinScale()
1155
     */
1156
    public double getMinScale() {
1157
        return -1; // La visibilidad o no la controla cada capa
1158
                // dentro de una colecci?n
1159
    }
1160

    
1161
    /* (non-Javadoc)
1162
     * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMaxScale()
1163
     */
1164
    public double getMaxScale() {
1165
        return -1;
1166
    }
1167
    public void setMinScale(double minScale)
1168
    {
1169
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1170
                        FLayer lyr = (FLayer) iter.next();
1171
                        lyr.setMinScale(minScale);
1172
                }
1173
    }
1174
    public void setMaxScale(double maxScale)
1175
    {
1176
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1177
                        FLayer lyr = (FLayer) iter.next();
1178
                        lyr.setMinScale(maxScale);
1179
                }
1180
    }
1181
    public void setActive(boolean b){
1182
            super.setActive(b);
1183
            for (int i=0;i<layers.size();i++){
1184
                    ((FLayer)layers.get(i)).setActive(b);
1185
            }
1186
    }
1187

    
1188
        /* (non-Javadoc)
1189
         * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#addLayerListener(com.iver.cit.gvsig.fmap.layers.LayerListener)
1190
         */
1191
        public boolean addLayerListener(LayerListener o) {
1192
                for (int i = 0; i < layers.size(); i++)
1193
                        ((FLayer) layers.get(i)).addLayerListener(o);
1194
                return true;
1195
        }
1196

    
1197
        public XMLItem[] getInfo(Point p, double tolerance, Cancellable cancel) throws ReadDriverException, VisitorException, LoadLayerException {
1198
                int i;
1199
                Vector items = new Vector();
1200
                FLayer layer;
1201
                XMLItem[] aux;
1202
                for (i = 0; i < this.layers.size(); i++){
1203
                        layer = (FLayer)layers.get(i);
1204
                        if (layer instanceof InfoByPoint){
1205
                                InfoByPoint queryable_layer = (InfoByPoint) layer;
1206
                                aux = queryable_layer.getInfo(p, tolerance, null);
1207
                                if (!(queryable_layer instanceof FLayers)){
1208
                                        for(int j = 0; j < aux.length; j++){
1209
                                                items.add(aux[j]);
1210
                                        }
1211
                                }
1212
                        }
1213
                }
1214
                return (XMLItem[])items.toArray(new XMLItem[0]);
1215

    
1216
//                for (i = 0; i < this.layers.size(); i++){
1217
//                        FLayer laCapa = (FLayer) layers.get(i);
1218
//                        if (laCapa instanceof FLyrVect){
1219
//                        }
1220
//                        else if (laCapa instanceof RasterOperations) {
1221
//                                try {
1222
//                                        RasterOperations layer = (RasterOperations) laCapa;
1223
//                                        sb.append(layer.getInfo(p, tolerance));
1224
//                                } catch (DriverException e) {
1225
//                                        e.printStackTrace();
1226
//                                }
1227
//                        }
1228
//                        else if (laCapa instanceof InfoByPoint) {
1229
//                                try {
1230
//                                        InfoByPoint layer = (InfoByPoint) laCapa;
1231
//                                        sb.append(layer.getInfo(p, tolerance));
1232
//                                } catch (DriverException e) {
1233
//                                        e.printStackTrace();
1234
//                                }
1235
//                        }
1236
//                }
1237

    
1238
        }
1239

    
1240
        public ImageIcon getTocImageIcon() {
1241
                return new ImageIcon(MapControl.class.getResource("images/layerGroup.png"));
1242
        }
1243

    
1244
        public boolean isDirty() {
1245
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1246
                        FLayer lyr = (FLayer) iter.next();
1247
                        if (lyr.isDirty())
1248
                                return true;
1249
                }
1250
                return false;
1251
        }
1252

    
1253
        public void setDirty(boolean dirty) {
1254
                for (Iterator iter = layers.iterator(); iter.hasNext();) {
1255
                        FLayer lyr = (FLayer) iter.next();
1256
                        lyr.setDirty(dirty);
1257
                }
1258

    
1259
        }
1260

    
1261
        public boolean addLayerFromXMLEntity(XMLEntity xml, String name) throws LoadLayerException {
1262
                fmap.clearErrors();
1263
                this.addLayerFromXML(xml,name);
1264

    
1265
                return (fmap.getLayersError().size() == 0);
1266

    
1267
        }
1268

    
1269
        private void addLayerFromXML(XMLEntity xml, String name) throws LoadLayerException {
1270
                FLayer layer = null;
1271

    
1272
                try {
1273
                if (name == null) name = xml.getName();
1274

    
1275

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

    
1302

    
1303
                                }
1304
                if (xml.contains("db")) {
1305

    
1306
                    String driverName = xml.getStringProperty("db");
1307
                    IVectorialDatabaseDriver driver;
1308
                    try {
1309
                        driver = (IVectorialDatabaseDriver) LayerFactory.getDM().getDriver(driverName);
1310
                        //Hay que separar la carga de los datos del XMLEntity del load.
1311
                        driver.setXMLEntity(xml.getChild(2));
1312

    
1313
                        boolean loadOk = false;
1314
                               ((DefaultJDBCDriver)driver).load();
1315
                               if (((DefaultJDBCDriver)driver).getConnection() != null) {
1316
                                       loadOk = true;
1317
                               }
1318
                        layer = LayerFactory.createDBLayer(driver, name, proj);
1319
                        if (!loadOk) {
1320
                                layer.setAvailable(false);
1321
                        }
1322

    
1323
                    } catch (DriverLoadException e) {
1324
                        throw new DriverLayerException(name,e);
1325
                    } catch (XMLException e) {
1326
                            throw new DriverLayerException(name,e);
1327
                                        } catch (ReadDriverException e) {
1328
                                                throw new DriverLayerException(name,e);
1329
                                        }
1330

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

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

    
1379
                        }
1380

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

    
1387

    
1388
                        layer.setXMLEntity(xml);
1389

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

    
1417
                }else if (className.equals((FLayers.class.getName()))) {
1418
                        layer = new FLayers(getMapContext(),this);
1419
                        layer.setXMLEntity(xml);
1420
                } else {
1421
                        // Capas Nuevas (externas)
1422
                                Class clase = Class.forName(className);
1423
                                layer = (FLayer) clase.newInstance();
1424
                                layer.setName(name);
1425
                                layer.setXMLEntity(xml);
1426
                                layer.load();
1427
                }
1428

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

    
1455
                }
1456
            }
1457
//        }catch (LoadLayerException e) {
1458
//                        fmap.addLayerError(xml.getStringProperty("name"));
1459
//                                //loadLayerException.addException(e);
1460
//                        /*if (layer!=null){
1461
//                layer.setActive(false);
1462
//                        layer.setVisible(false);
1463
//                        this.addLayer(layer);
1464
//                }*/
1465
//                        //throw new XMLException(e);
1466
//            System.err.println("No se ha podido cargar la capa : "+xml.getStringProperty("name"));
1467
//            logger.debug("No se ha podido cargar la capa : "+xml.getStringProperty("name") + ". Raz?n:");
1468
//            // logger.debug(e.fillInStackTrace());
1469
//            e.printStackTrace();
1470
        } catch (XMLException e) {
1471
                fmap.addLayerError(xml.getStringProperty("name"));
1472
                        throw new LoadLayerException(name,e);
1473
                } catch (ClassNotFoundException e) {
1474
                        fmap.addLayerError(xml.getStringProperty("name"));
1475
                        throw new LoadLayerException(name,e);
1476
                } catch (InstantiationException e) {
1477
                        fmap.addLayerError(xml.getStringProperty("name"));
1478
                        throw new LoadLayerException(name,e);
1479
                } catch (IllegalAccessException e) {
1480
                        fmap.addLayerError(xml.getStringProperty("name"));
1481
                        throw new LoadLayerException(name,e);
1482
                } catch (ReadDriverException e) {
1483
                        fmap.addLayerError(xml.getStringProperty("name"));
1484
                        throw new LoadLayerException(name,e);
1485
                } catch (LoadLayerException e){
1486
                        fmap.addLayerError(xml.getStringProperty("name"));
1487
                        throw e;
1488
                }
1489
        }
1490

    
1491
        private void addLayerFromXMLNew(XMLEntity xml, String name) {
1492
                FLayer layer = null;
1493

    
1494

    
1495
                try {
1496
                String className = xml.getStringProperty("className");
1497

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

    
1529
                }
1530
                layer.setXMLEntity(xml);
1531
                if (name != null) layer.setName(name);
1532
                layer.load();
1533

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

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

    
1578
}