root / trunk / libraries / libFMap / src / com / iver / cit / gvsig / fmap / layers / FLayers.java @ 1453
History | View | Annotate | Download (16.7 KB)
1 | 1100 | fjp | /* 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 | 214 | fernando | package com.iver.cit.gvsig.fmap.layers; |
42 | |||
43 | 651 | fernando | import com.iver.cit.gvsig.fmap.DriverException; |
44 | 694 | fernando | import com.iver.cit.gvsig.fmap.FMap; |
45 | 562 | fernando | import com.iver.cit.gvsig.fmap.ViewPort; |
46 | 1453 | luisw | import com.iver.cit.gvsig.fmap.drivers.DriverIOException; |
47 | 562 | fernando | import com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection; |
48 | import com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData; |
||
49 | import com.iver.cit.gvsig.fmap.operations.Cancellable; |
||
50 | import com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor; |
||
51 | 926 | fernando | import com.iver.cit.gvsig.fmap.operations.strategies.VisitException; |
52 | 1005 | vcaballero | |
53 | 894 | vcaballero | import com.iver.utiles.StringUtilities; |
54 | 562 | fernando | import com.iver.utiles.XMLEntity; |
55 | 541 | vcaballero | |
56 | 1005 | vcaballero | import org.cresques.cts.ICoordTrans; |
57 | 1417 | fjp | import org.cresques.cts.IProjection; |
58 | import org.cresques.cts.gt2.CoordSys; |
||
59 | import org.cresques.cts.gt2.CoordTrans; |
||
60 | 562 | fernando | |
61 | 1005 | vcaballero | import java.awt.Graphics2D; |
62 | import java.awt.geom.Rectangle2D; |
||
63 | import java.awt.image.BufferedImage; |
||
64 | |||
65 | import java.io.File; |
||
66 | |||
67 | import java.net.MalformedURLException; |
||
68 | import java.net.URL; |
||
69 | |||
70 | import java.util.ArrayList; |
||
71 | import java.util.BitSet; |
||
72 | import java.util.Iterator; |
||
73 | |||
74 | 1417 | fjp | import javax.swing.JOptionPane; |
75 | 1005 | vcaballero | |
76 | 1417 | fjp | |
77 | 214 | fernando | /**
|
78 | * Representa un nodo interno en el ?rbol de capas
|
||
79 | */
|
||
80 | 1005 | vcaballero | public class FLayers extends FLyrDefault implements VectorialData, |
81 | LayerCollection { |
||
82 | 524 | vcaballero | //ArrayList de Listener registrados.
|
83 | private ArrayList layerListeners = new ArrayList(); |
||
84 | private ArrayList layers = new ArrayList(4); |
||
85 | 694 | fernando | private FMap fmap;
|
86 | 1005 | vcaballero | |
87 | 524 | vcaballero | /**
|
88 | * Crea un nuevo FLayers.
|
||
89 | 1005 | vcaballero | *
|
90 | * @param fmap
|
||
91 | * @param parent
|
||
92 | 524 | vcaballero | */
|
93 | 694 | fernando | public FLayers(FMap fmap, FLayers parent) {
|
94 | setParentLayer(parent); |
||
95 | this.fmap = fmap;
|
||
96 | 524 | vcaballero | } |
97 | 257 | vcaballero | |
98 | 524 | vcaballero | /**
|
99 | * A?ade un listener de los eventos de la colecci?n de capas
|
||
100 | *
|
||
101 | 1005 | vcaballero | * @param listener
|
102 | 524 | vcaballero | */
|
103 | public void addLayerCollectionListener(LayerCollectionListener listener) { |
||
104 | layerListeners.add(listener); |
||
105 | } |
||
106 | 1005 | vcaballero | |
107 | /**
|
||
108 | * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllVisibles(boolean)
|
||
109 | */
|
||
110 | public void setAllVisibles(boolean visible) { |
||
111 | 708 | fernando | FLayer lyr; |
112 | 214 | fernando | |
113 | 524 | vcaballero | for (int i = 0; i < layers.size(); i++) { |
114 | lyr = ((FLayer) layers.get(i)); |
||
115 | 708 | fernando | lyr.setVisible(visible); |
116 | 1005 | vcaballero | |
117 | if (lyr instanceof LayerCollection) { |
||
118 | 708 | fernando | ((LayerCollection) lyr).setAllVisibles(visible); |
119 | } |
||
120 | 524 | vcaballero | } |
121 | } |
||
122 | 346 | fernando | |
123 | 524 | vcaballero | /**
|
124 | 1005 | vcaballero | * Elimina un listener de los eventos de la colecci?n de capas
|
125 | 524 | vcaballero | *
|
126 | 1005 | vcaballero | * @param listener
|
127 | 524 | vcaballero | */
|
128 | public void removeLayerCollectionListener(LayerCollectionListener listener) { |
||
129 | layerListeners.remove(listener); |
||
130 | } |
||
131 | 214 | fernando | |
132 | 524 | vcaballero | /**
|
133 | 1005 | vcaballero | * A?ade una capa.
|
134 | 524 | vcaballero | *
|
135 | 1005 | vcaballero | * @param layer
|
136 | 524 | vcaballero | */
|
137 | private void doAddLayer(FLayer layer) { |
||
138 | layers.add(layer); |
||
139 | 694 | fernando | layer.setParentLayer(this);
|
140 | 524 | vcaballero | } |
141 | 270 | vcaballero | |
142 | 524 | vcaballero | /**
|
143 | * A?ade una capa al final de la lista de subcapas
|
||
144 | *
|
||
145 | 1005 | vcaballero | * @param layer
|
146 | 524 | vcaballero | *
|
147 | * @throws CancelationException
|
||
148 | */
|
||
149 | public void addLayer(FLayer layer) throws CancelationException { |
||
150 | 1081 | fernando | callLayerAdding(LayerCollectionEvent.createLayerAddingEvent(layer)); |
151 | 214 | fernando | |
152 | 524 | vcaballero | doAddLayer(layer); |
153 | 404 | fjp | |
154 | 1081 | fernando | callLayerAdded(LayerCollectionEvent.createLayerAddedEvent(layer)); |
155 | 524 | vcaballero | } |
156 | 404 | fjp | |
157 | 524 | vcaballero | /**
|
158 | * Mueve una capa de la posici?n from a la posici?n to. (Se supone que
|
||
159 | * est?n dentro del mismo nivel). Para mover entre niveles, usar otro
|
||
160 | * m?todo (por hacer)
|
||
161 | *
|
||
162 | 1005 | vcaballero | * @param from origen.
|
163 | * @param to destino.
|
||
164 | 524 | vcaballero | *
|
165 | * @throws CancelationException
|
||
166 | */
|
||
167 | public void moveTo(int from, int to) throws CancelationException { |
||
168 | FLayer aux = (FLayer) layers.get(from); |
||
169 | 1081 | fernando | callLayerMoving(LayerPositionEvent.createLayerMovingEvent(aux, from, to)); |
170 | 524 | vcaballero | layers.remove(from); |
171 | layers.add(to, aux); |
||
172 | 1081 | fernando | callLayerMoved(LayerPositionEvent.createLayerMovedEvent(aux, from, to)); |
173 | 524 | vcaballero | } |
174 | 257 | vcaballero | |
175 | 524 | vcaballero | /**
|
176 | 1005 | vcaballero | * Borra una capa del ArrayList que contiene a las capas.
|
177 | 524 | vcaballero | *
|
178 | 1005 | vcaballero | * @param lyr FLayer.
|
179 | 524 | vcaballero | */
|
180 | private void doRemoveLayer(FLayer lyr) { |
||
181 | layers.remove(lyr); |
||
182 | } |
||
183 | 214 | fernando | |
184 | 524 | vcaballero | /**
|
185 | 1005 | vcaballero | * Borra una capa de la colecci?n de capas.
|
186 | 524 | vcaballero | *
|
187 | 1005 | vcaballero | * @param lyr FLayer
|
188 | 524 | vcaballero | *
|
189 | 1005 | vcaballero | * @throws CancelationException
|
190 | 524 | vcaballero | */
|
191 | public void removeLayer(FLayer lyr) throws CancelationException { |
||
192 | 1081 | fernando | callLayerRemoving(LayerCollectionEvent.createLayerRemovingEvent(lyr)); |
193 | 524 | vcaballero | doRemoveLayer(lyr); |
194 | 1081 | fernando | callLayerRemoved(LayerCollectionEvent.createLayerRemovedEvent(lyr)); |
195 | 524 | vcaballero | } |
196 | 214 | fernando | |
197 | 524 | vcaballero | /**
|
198 | * Borra una FLayer del vector a partir del identificador.
|
||
199 | *
|
||
200 | * @param idLayer
|
||
201 | */
|
||
202 | public void removeLayer(int idLayer) { |
||
203 | 1081 | fernando | FLayer lyr = (FLayer) layers.get(idLayer); |
204 | callLayerRemoving(LayerCollectionEvent.createLayerRemovingEvent(lyr)); |
||
205 | 524 | vcaballero | layers.remove(idLayer); |
206 | 1081 | fernando | callLayerRemoved(LayerCollectionEvent.createLayerRemovedEvent(lyr)); |
207 | 524 | vcaballero | } |
208 | 257 | vcaballero | |
209 | 524 | vcaballero | /**
|
210 | * M?todo de conveniencia para borrar una capa con ese nombre
|
||
211 | *
|
||
212 | * @param layerName
|
||
213 | */
|
||
214 | public void removeLayer(String layerName) { |
||
215 | FLayer lyr; |
||
216 | 214 | fernando | |
217 | 524 | vcaballero | for (int i = 0; i < layers.size(); i++) { |
218 | lyr = ((FLayer) layers.get(i)); |
||
219 | 402 | fjp | |
220 | 524 | vcaballero | if (lyr.getName().compareToIgnoreCase(layerName) == 0) { |
221 | 1081 | fernando | removeLayer(i); |
222 | 214 | fernando | |
223 | 524 | vcaballero | break;
|
224 | } |
||
225 | } |
||
226 | } |
||
227 | 214 | fernando | |
228 | 524 | vcaballero | /**
|
229 | * Obtiene el array de capas visibles que penden del arbol cuya ra?z es
|
||
230 | * este nodo
|
||
231 | *
|
||
232 | 1005 | vcaballero | * @return Vector de FLayer.
|
233 | 524 | vcaballero | */
|
234 | public FLayer[] getVisibles() { |
||
235 | ArrayList array = new ArrayList(); |
||
236 | 404 | fjp | |
237 | 524 | vcaballero | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
238 | if (((FLayer) iter.next()).isVisible()) {
|
||
239 | array.add((FLayer) iter.next()); |
||
240 | } |
||
241 | } |
||
242 | 404 | fjp | |
243 | 524 | vcaballero | return (FLayer[]) array.toArray(new FLayer[0]); |
244 | } |
||
245 | 404 | fjp | |
246 | 524 | vcaballero | /**
|
247 | * Obtiene el hijo i-?simo directo de esta colecci?n
|
||
248 | *
|
||
249 | 1005 | vcaballero | * @param index ?ndice.
|
250 | 524 | vcaballero | *
|
251 | 1005 | vcaballero | * @return capa seleccionada.
|
252 | 524 | vcaballero | */
|
253 | public FLayer getLayer(int index) { |
||
254 | return (FLayer) layers.get(index);
|
||
255 | } |
||
256 | 242 | vcaballero | |
257 | 524 | vcaballero | /**
|
258 | * M?todo de conveniencia para buscar una capa por su nombre Es conveniente
|
||
259 | * usar getLayer(int) siempre que se pueda, es m?s directo.
|
||
260 | *
|
||
261 | 1005 | vcaballero | * @param layerName nombre.
|
262 | 524 | vcaballero | *
|
263 | 1005 | vcaballero | * @return capa seleccionada.
|
264 | 524 | vcaballero | */
|
265 | public FLayer getLayer(String layerName) { |
||
266 | FLayer lyr; |
||
267 | 242 | vcaballero | |
268 | 524 | vcaballero | for (int i = 0; i < layers.size(); i++) { |
269 | lyr = ((FLayer) layers.get(i)); |
||
270 | 242 | vcaballero | |
271 | 524 | vcaballero | if (lyr.getName().compareToIgnoreCase(layerName) == 0) { |
272 | return lyr;
|
||
273 | } |
||
274 | } |
||
275 | 346 | fernando | |
276 | 524 | vcaballero | return null; |
277 | } |
||
278 | 346 | fernando | |
279 | 524 | vcaballero | /**
|
280 | * Obtiene el n?mero de capas que hay en su mismo nivel Es decir, no cuenta
|
||
281 | * las subcapas de un FLayers
|
||
282 | *
|
||
283 | 1005 | vcaballero | * @return n?mero de capas.
|
284 | 524 | vcaballero | */
|
285 | public int getLayersCount() { |
||
286 | return layers.size();
|
||
287 | } |
||
288 | 346 | fernando | |
289 | 524 | vcaballero | /**
|
290 | 1056 | vcaballero | * @see com.iver.cit.gvsig.fmap.layers.FLayer#draw(java.awt.image.BufferedImage,
|
291 | 524 | vcaballero | * java.awt.Graphics2D, com.iver.cit.gvsig.fmap.ViewPort)
|
292 | */
|
||
293 | public void draw(BufferedImage image, Graphics2D g, ViewPort viewPort, |
||
294 | 1005 | vcaballero | Cancellable cancel) throws DriverException {
|
295 | 1176 | fjp | double scale = getFMap().getScaleView();
|
296 | 524 | vcaballero | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
297 | 533 | vcaballero | FLayer lyr = (FLayer) iter.next(); |
298 | 541 | vcaballero | |
299 | 524 | vcaballero | if (lyr.isVisible()) {
|
300 | 1176 | fjp | if (lyr.isWithinScale())
|
301 | lyr.draw(image, g, viewPort, cancel); |
||
302 | 524 | vcaballero | } |
303 | } |
||
304 | 1005 | vcaballero | |
305 | if (getVirtualLayers() != null) { |
||
306 | 745 | fjp | getVirtualLayers().draw(image, g, viewPort, cancel); |
307 | 1005 | vcaballero | } |
308 | 524 | vcaballero | } |
309 | |||
310 | /**
|
||
311 | 1005 | vcaballero | * @see com.iver.cit.gvsig.fmap.layers.FLayer#print(java.awt.Graphics2D,
|
312 | * com.iver.cit.gvsig.fmap.ViewPort,
|
||
313 | * com.iver.cit.gvsig.fmap.operations.Cancellable)
|
||
314 | 524 | vcaballero | */
|
315 | 1005 | vcaballero | public void print(Graphics2D g, ViewPort viewPort, Cancellable cancel) |
316 | throws DriverException {
|
||
317 | 650 | vcaballero | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
318 | FLayer lyr = (FLayer) iter.next(); |
||
319 | |||
320 | if (lyr.isVisible()) {
|
||
321 | lyr.print(g, viewPort, cancel); |
||
322 | } |
||
323 | } |
||
324 | 524 | vcaballero | } |
325 | |||
326 | /**
|
||
327 | * @see com.iver.cit.gvsig.fmap.layers.FLayer#getFullExtent()
|
||
328 | */
|
||
329 | 651 | fernando | public Rectangle2D getFullExtent() throws DriverException { |
330 | 524 | vcaballero | Rectangle2D rAux = null; |
331 | int i = 0; |
||
332 | |||
333 | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
||
334 | 533 | vcaballero | FLayer capa = (FLayer) iter.next(); |
335 | 524 | vcaballero | |
336 | if (i == 0) { |
||
337 | rAux = capa.getFullExtent(); |
||
338 | } else {
|
||
339 | rAux.add(capa.getFullExtent()); |
||
340 | } |
||
341 | |||
342 | i++; |
||
343 | } |
||
344 | |||
345 | return rAux;
|
||
346 | } |
||
347 | 1005 | vcaballero | |
348 | 524 | vcaballero | /**
|
349 | 1005 | vcaballero | * Llama al m?todo layerAdding de los listeners dados de alta.
|
350 | 524 | vcaballero | *
|
351 | 1005 | vcaballero | * @param event
|
352 | 524 | vcaballero | *
|
353 | * @throws CancelationException
|
||
354 | */
|
||
355 | private void callLayerAdding(LayerCollectionEvent event) |
||
356 | throws CancelationException {
|
||
357 | for (Iterator iter = layerListeners.iterator(); iter.hasNext();) { |
||
358 | ((LayerCollectionListener) iter.next()).layerAdding(event); |
||
359 | } |
||
360 | } |
||
361 | 257 | vcaballero | |
362 | 524 | vcaballero | /**
|
363 | 1005 | vcaballero | * Llama al m?todo layerRemoving de los listeners dados de alta.
|
364 | 524 | vcaballero | *
|
365 | 1005 | vcaballero | * @param event
|
366 | 524 | vcaballero | *
|
367 | * @throws CancelationException
|
||
368 | */
|
||
369 | private void callLayerRemoving(LayerCollectionEvent event) |
||
370 | throws CancelationException {
|
||
371 | for (Iterator iter = layerListeners.iterator(); iter.hasNext();) { |
||
372 | ((LayerCollectionListener) iter.next()).layerRemoving(event); |
||
373 | } |
||
374 | } |
||
375 | 257 | vcaballero | |
376 | 524 | vcaballero | /**
|
377 | 1005 | vcaballero | * Llama al m?todo layerMoving de los listeners dados de alta.
|
378 | 524 | vcaballero | *
|
379 | 1005 | vcaballero | * @param event
|
380 | 524 | vcaballero | *
|
381 | * @throws CancelationException
|
||
382 | */
|
||
383 | private void callLayerMoving(LayerPositionEvent event) |
||
384 | throws CancelationException {
|
||
385 | for (Iterator iter = layerListeners.iterator(); iter.hasNext();) { |
||
386 | ((LayerCollectionListener) iter.next()).layerMoving(event); |
||
387 | } |
||
388 | } |
||
389 | 353 | fernando | |
390 | 524 | vcaballero | /**
|
391 | 1005 | vcaballero | * Llama al m?todo layerAdded de los listeners dados de alta.
|
392 | 524 | vcaballero | *
|
393 | 1005 | vcaballero | * @param event
|
394 | 524 | vcaballero | */
|
395 | private void callLayerAdded(LayerCollectionEvent event) { |
||
396 | for (Iterator iter = layerListeners.iterator(); iter.hasNext();) { |
||
397 | ((LayerCollectionListener) iter.next()).layerAdded(event); |
||
398 | } |
||
399 | } |
||
400 | 353 | fernando | |
401 | 524 | vcaballero | /**
|
402 | 1005 | vcaballero | * Llama al m?todo layerRemoved de los listeners dados de alta.
|
403 | 524 | vcaballero | *
|
404 | 1005 | vcaballero | * @param event
|
405 | 524 | vcaballero | */
|
406 | private void callLayerRemoved(LayerCollectionEvent event) { |
||
407 | for (Iterator iter = layerListeners.iterator(); iter.hasNext();) { |
||
408 | ((LayerCollectionListener) iter.next()).layerRemoved(event); |
||
409 | } |
||
410 | } |
||
411 | 353 | fernando | |
412 | 435 | vcaballero | /**
|
413 | 1005 | vcaballero | * Llama al m?todo layerMoved de los listeners dados de alta.
|
414 | 524 | vcaballero | *
|
415 | 1005 | vcaballero | * @param event
|
416 | 524 | vcaballero | */
|
417 | private void callLayerMoved(LayerPositionEvent event) { |
||
418 | for (Iterator iter = layerListeners.iterator(); iter.hasNext();) { |
||
419 | ((LayerCollectionListener) iter.next()).layerMoved(event); |
||
420 | } |
||
421 | } |
||
422 | |||
423 | /**
|
||
424 | 435 | vcaballero | * @see com.iver.cit.gvsig.fmap.layers.FLayer#getProperties()
|
425 | */
|
||
426 | 651 | fernando | public XMLEntity getXMLEntity() {
|
427 | 524 | vcaballero | XMLEntity xml = super.getXMLEntity();
|
428 | xml.putProperty("numLayers", layers.size());
|
||
429 | 1005 | vcaballero | |
430 | String[] s = new String[layers.size()]; |
||
431 | |||
432 | for (int i = 0; i < layers.size(); i++) { |
||
433 | s[i] = ((FLayer) layers.get(i)).getName(); |
||
434 | 558 | vcaballero | } |
435 | 1005 | vcaballero | |
436 | xml.putProperty("LayerNames", s);
|
||
437 | |||
438 | 524 | vcaballero | for (int i = 0; i < layers.size(); i++) { |
439 | xml.addChild(((FLayer) layers.get(i)).getXMLEntity()); |
||
440 | 435 | vcaballero | } |
441 | 524 | vcaballero | |
442 | 435 | vcaballero | return xml;
|
443 | } |
||
444 | 341 | fernando | |
445 | 435 | vcaballero | /**
|
446 | 1056 | vcaballero | * DOCUMENT ME!
|
447 | *
|
||
448 | * @param xml DOCUMENT ME!
|
||
449 | *
|
||
450 | * @throws XMLException
|
||
451 | *
|
||
452 | 435 | vcaballero | * @see com.iver.cit.gvsig.fmap.layers.FLyrDefault#setXMLEntity(com.iver.utiles.XMLEntity)
|
453 | */
|
||
454 | 1056 | vcaballero | public void setXMLEntity(XMLEntity xml) throws XMLException { |
455 | 442 | vcaballero | super.setXMLEntity(xml);
|
456 | 1005 | vcaballero | |
457 | 894 | vcaballero | int numLayers = xml.getIntProperty("numLayers"); |
458 | 524 | vcaballero | |
459 | 1005 | vcaballero | String[] s = xml.getStringArrayProperty("LayerNames"); |
460 | 1060 | fjp | try {
|
461 | for (int i = 0; i < numLayers; i++) { |
||
462 | FLayer layer = null;
|
||
463 | |||
464 | String className = xml.getChild(i).getStringProperty("className"); |
||
465 | |||
466 | if (className.equals(FLyrVect.class.getName())) {
|
||
467 | if (xml.getChild(i).contains("file")) { |
||
468 | |||
469 | layer = LayerFactory.createLayer(s[i], |
||
470 | xml.getChild(i).getStringProperty("driverName"),
|
||
471 | new File(xml.getChild(i).getStringProperty("file")), |
||
472 | this.getFMap().getViewPort().getProjection());
|
||
473 | 1417 | fjp | |
474 | 1060 | fjp | } else if (true) { |
475 | //TODO falta por implementar
|
||
476 | } else if (true) { |
||
477 | //TODO falta por implementar
|
||
478 | } |
||
479 | |||
480 | layer.setXMLEntity(xml.getChild(i)); |
||
481 | 1417 | fjp | // Comprobar que la proyecci?n es la misma que la de FMap
|
482 | // Si no lo es, es una capa que est? reproyectada al vuelo
|
||
483 | IProjection proj = layer.getProjection(); |
||
484 | if (proj != null) |
||
485 | if (proj != fmap.getProjection())
|
||
486 | { |
||
487 | ICoordTrans ct = new CoordTrans((CoordSys) proj,
|
||
488 | (CoordSys) fmap.getProjection()); |
||
489 | layer.setCoordTrans(ct); |
||
490 | System.err.println("coordTrans = " + |
||
491 | proj.getAbrev() + " " +
|
||
492 | fmap.getProjection().getAbrev()); |
||
493 | } |
||
494 | |||
495 | 1060 | fjp | } else if (className.equals(FLyrWMS.class.getName())) { |
496 | try {
|
||
497 | layer = LayerFactory.createLayer(s[i], |
||
498 | StringUtilities.string2Rect( |
||
499 | xml.getChild(i).getStringProperty("fullExtent")),
|
||
500 | new URL(xml.getChild(i).getStringProperty("host")), |
||
501 | xml.getChild(i).getStringProperty("format"),
|
||
502 | 1416 | fernando | xml.getChild(i).getStringProperty("layerQuery"),
|
503 | 1060 | fjp | xml.getChild(i).getStringProperty("infoLayerQuery"),
|
504 | xml.getChild(i).getStringProperty("srs"));
|
||
505 | } catch (MalformedURLException e) { |
||
506 | throw new XMLException(e); |
||
507 | } |
||
508 | } else if (className.equals((FLyrRaster.class.getName()))) { |
||
509 | //if (xml.getChild(i).contains("file")) {
|
||
510 | 1453 | luisw | /*layer = LayerFactory.createLayer(s[i],
|
511 | 1005 | vcaballero | xml.getChild(i).getStringProperty("driverName"),
|
512 | new File(xml.getChild(i).getStringProperty("file")),
|
||
513 | 1453 | luisw | this.getFMap().getViewPort().getProjection());*/
|
514 | layer = new FLyrRaster();
|
||
515 | layer.setName(s[i]); |
||
516 | layer.setXMLEntity(xml.getChild(i)); |
||
517 | ((FLyrRaster)layer).setProjection(this.getFMap().getViewPort().getProjection());
|
||
518 | try {
|
||
519 | layer.load(); |
||
520 | } catch (DriverIOException e) {
|
||
521 | throw new XMLException(e); |
||
522 | } |
||
523 | 1060 | fjp | |
524 | //} else if (true) {
|
||
525 | 894 | vcaballero | //TODO falta por implementar
|
526 | 1060 | fjp | //} else if (true) {
|
527 | 894 | vcaballero | //TODO falta por implementar
|
528 | 1060 | fjp | //}
|
529 | //TODO Falta por implementar
|
||
530 | 894 | vcaballero | } |
531 | 1060 | fjp | |
532 | fmap.getLayers().addLayer(layer); |
||
533 | 894 | vcaballero | } |
534 | 1060 | fjp | } catch (DriverException e) {
|
535 | throw new XMLException(e); |
||
536 | 435 | vcaballero | } |
537 | 1060 | fjp | |
538 | 435 | vcaballero | } |
539 | 562 | fernando | |
540 | /**
|
||
541 | 1005 | vcaballero | * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor,
|
542 | * java.util.BitSet)
|
||
543 | 562 | fernando | */
|
544 | 1005 | vcaballero | public void process(FeatureVisitor visitor, BitSet subset) |
545 | throws DriverException, VisitException {
|
||
546 | 562 | fernando | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
547 | FLayer layer = (FLayer) iter.next(); |
||
548 | 1005 | vcaballero | |
549 | 562 | fernando | if (layer instanceof VectorialData) { |
550 | ((VectorialData) layer).process(visitor, subset); |
||
551 | } |
||
552 | } |
||
553 | } |
||
554 | |||
555 | /**
|
||
556 | * @see com.iver.cit.gvsig.fmap.layers.layerOperations.VectorialData#process(com.iver.cit.gvsig.fmap.operations.strategies.FeatureVisitor)
|
||
557 | */
|
||
558 | 1005 | vcaballero | public void process(FeatureVisitor visitor) |
559 | throws DriverException, VisitException {
|
||
560 | 562 | fernando | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
561 | FLayer layer = (FLayer) iter.next(); |
||
562 | 1005 | vcaballero | |
563 | if (layer.isActive()) {
|
||
564 | 661 | fjp | if (layer instanceof VectorialData) { |
565 | ((VectorialData) layer).process(visitor); |
||
566 | } |
||
567 | 1005 | vcaballero | } |
568 | 562 | fernando | } |
569 | } |
||
570 | 694 | fernando | |
571 | /**
|
||
572 | * @see com.iver.cit.gvsig.fmap.layers.FLayer#getFMap()
|
||
573 | */
|
||
574 | public FMap getFMap() {
|
||
575 | return fmap;
|
||
576 | } |
||
577 | 885 | fjp | |
578 | /* (non-Javadoc)
|
||
579 | * @see com.iver.cit.gvsig.fmap.layers.FLayer#setCoordTrans(org.cresques.cts.ICoordTrans)
|
||
580 | */
|
||
581 | public void setCoordTrans(ICoordTrans ct) { |
||
582 | super.setCoordTrans(ct);
|
||
583 | 1005 | vcaballero | |
584 | 885 | fjp | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
585 | FLayer layer = (FLayer) iter.next(); |
||
586 | layer.setCoordTrans(ct); |
||
587 | 1005 | vcaballero | } |
588 | 885 | fjp | } |
589 | 1005 | vcaballero | |
590 | /**
|
||
591 | * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#setAllActives(boolean)
|
||
592 | */
|
||
593 | public void setAllActives(boolean active) { |
||
594 | FLayer lyr; |
||
595 | |||
596 | for (int i = 0; i < layers.size(); i++) { |
||
597 | lyr = ((FLayer) layers.get(i)); |
||
598 | lyr.setActive(active); |
||
599 | |||
600 | if (lyr instanceof LayerCollection) { |
||
601 | ((LayerCollection) lyr).setAllActives(active); |
||
602 | } |
||
603 | } |
||
604 | } |
||
605 | |||
606 | /**
|
||
607 | * @see com.iver.cit.gvsig.fmap.layers.layerOperations.LayerCollection#getActives()
|
||
608 | */
|
||
609 | public FLayer[] getActives() { |
||
610 | ArrayList ret = new ArrayList(); |
||
611 | |||
612 | for (int i = 0; i < layers.size(); i++) { |
||
613 | if (((FLayer) layers.get(i)).isActive()) {
|
||
614 | ret.add(layers.get(i)); |
||
615 | } |
||
616 | } |
||
617 | |||
618 | return (FLayer[]) ret.toArray(new FLayer[0]); |
||
619 | } |
||
620 | 1176 | fjp | |
621 | /* (non-Javadoc)
|
||
622 | * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMinScale()
|
||
623 | */
|
||
624 | public double getMinScale() { |
||
625 | return -1; // La visibilidad o no la controla cada capa |
||
626 | // dentro de una colecci?n
|
||
627 | } |
||
628 | |||
629 | /* (non-Javadoc)
|
||
630 | * @see com.iver.cit.gvsig.fmap.layers.FLayer#getMaxScale()
|
||
631 | */
|
||
632 | public double getMaxScale() { |
||
633 | return -1; |
||
634 | } |
||
635 | public void setMinScale(double minScale) |
||
636 | { |
||
637 | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
||
638 | FLayer lyr = (FLayer) iter.next(); |
||
639 | lyr.setMinScale(minScale); |
||
640 | } |
||
641 | } |
||
642 | public void setMaxScale(double maxScale) |
||
643 | { |
||
644 | for (Iterator iter = layers.iterator(); iter.hasNext();) { |
||
645 | FLayer lyr = (FLayer) iter.next(); |
||
646 | lyr.setMinScale(maxScale); |
||
647 | } |
||
648 | } |
||
649 | |||
650 | 214 | fernando | } |