Mercurial > dive4elements > river
diff flys-client/src/main/java/de/intevation/flys/client/client/ui/map/MapOutputTab.java @ 806:e50da1f74e58
The layers created in the floodmap reflect to the facets this output mode has.
flys-client/trunk@2374 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Wed, 20 Jul 2011 13:31:20 +0000 |
parents | 95cc560ce7c4 |
children | 112f95d7b286 |
line wrap: on
line diff
--- a/flys-client/src/main/java/de/intevation/flys/client/client/ui/map/MapOutputTab.java Wed Jul 20 07:52:19 2011 +0000 +++ b/flys-client/src/main/java/de/intevation/flys/client/client/ui/map/MapOutputTab.java Wed Jul 20 13:31:20 2011 +0000 @@ -1,5 +1,6 @@ package de.intevation.flys.client.client.ui.map; +import com.google.gwt.core.client.GWT; import com.google.gwt.user.client.ui.HorizontalPanel; import com.google.gwt.user.client.ui.Widget; @@ -11,25 +12,29 @@ import org.gwtopenmaps.openlayers.client.Bounds; import org.gwtopenmaps.openlayers.client.LonLat; +import org.gwtopenmaps.openlayers.client.Map; +import org.gwtopenmaps.openlayers.client.layer.Layer; import org.gwtopenmaps.openlayers.client.layer.WMS; import org.gwtopenmaps.openlayers.client.layer.WMSParams; - +import de.intevation.flys.client.shared.model.AttributedTheme; import de.intevation.flys.client.shared.model.Collection; +import de.intevation.flys.client.shared.model.Theme; +import de.intevation.flys.client.shared.model.ThemeList; import de.intevation.flys.client.shared.model.OutputMode; import de.intevation.flys.client.client.ui.CollectionView; import de.intevation.flys.client.client.ui.OutputTab; -import de.intevation.flys.client.client.ui.chart.ChartThemePanel; +import de.intevation.flys.client.client.ui.ThemePanel; public class MapOutputTab extends OutputTab { protected CollectionView parent; - protected Canvas controlPanel; - protected Canvas themePanel; - protected Widget mapPanel; + protected Canvas controlPanel; + protected ThemePanel themePanel; + protected Widget mapPanel; protected FloodMap floodMap; @@ -61,8 +66,8 @@ wrapper.setHeight100(); controlPanel = createControlPanel(wrapper); - themePanel = createThemePanel(); mapPanel = floodMap.getMapWidget(); + Canvas themePanelWrapper = createThemePanel(); final HorizontalPanel layout = new HorizontalPanel(); layout.setWidth("99%"); @@ -76,7 +81,7 @@ hlayout.setWidth100(); hlayout.setMembersMargin(2); - hlayout.addMember(themePanel); + hlayout.addMember(themePanelWrapper); hlayout.addMember(wrapper); rootLayout.addMember(controlPanel); @@ -102,23 +107,99 @@ protected void initLayers() { - // TODO Initialize correct layers here + ThemeList themeList = themePanel.getThemeList(); - String url = "http://vmap0.tiles.osgeo.org/wms/vmap0"; - String layers = "basic"; + int num = themeList.getThemeCount(); + + Map map = floodMap.getMap(); + Bounds extent = null; + + for (int i = 1; i <= num; i++) { + Theme theme = themeList.getThemeAt(i); + Layer layer = createWMSLayer(theme); + + if (layer == null) { + continue; + } + + map.addLayer(layer); + + AttributedTheme at = (AttributedTheme) theme; + String tmp = at.getAttr("extent"); + + if (theme.getActive() == 1) { + if (extent == null) { + extent = boundsFromString(tmp); + } + else { + Bounds b = boundsFromString(tmp); + + if (b != null) { + extent.extend(b); + } + } + } + } + + map.zoomToExtent(extent != null + ? extent + : new Bounds(-90, -180, 90, 180)); + } + + + protected Bounds boundsFromString(String bounds) { + if (bounds == null || bounds.length() == 0) { + return null; + } + + String[] values = bounds.split(" "); + + if (values == null || values.length < 4) { + return null; + } + + try { + return new Bounds( + Double.valueOf(values[0]), + Double.valueOf(values[3]), + Double.valueOf(values[2]), + Double.valueOf(values[1])); + } + catch (NumberFormatException nfe) {} + + return null; + } + + + protected Layer createWMSLayer(Theme theme) { + if (theme == null) { + return null; + } + + AttributedTheme at = (AttributedTheme) theme; + + String type = at.getAttr("name"); + String desc = at.getAttr("description"); + String url = at.getAttr("url"); + String layers = at.getAttr("layers"); + + if (url == null || layers == null) { + return null; + } + + //boolean baseLayer = type.equals("floodmap.wmsbackground"); WMSParams params = new WMSParams(); params.setLayers(layers); params.setFormat("image/png"); - params.setIsTransparent(false); + params.setIsTransparent(true); params.setMaxExtent(new Bounds(90, 180, -90, -180)); - WMS wms = new WMS("vmap0", url, params); - wms.setIsBaseLayer(true); - wms.setIsVisible(true); + WMS wms = new WMS(desc, url, params); + wms.setIsVisible(at.getActive() == 1); + wms.setIsBaseLayer(false); - floodMap.getMap().addLayer(wms); - floodMap.getMap().setCenter(new LonLat(0, 0)); + return wms; } @@ -133,10 +214,25 @@ c.setHeight100(); c.setBorder("1px solid black"); - ChartThemePanel ctp = new ChartThemePanel(collection, mode); - c.addChild(ctp); + themePanel = new MapThemePanel( + collection, mode, new MapThemePanel.ActivateCallback() { + public void activate(Theme theme, boolean active) { + activateTheme(theme, active); + } + }); + c.addChild(themePanel); return c; } + + + protected void activateTheme(Theme theme, boolean active) { + String name = theme.getDescription(); + Layer layer = floodMap.getMap().getLayerByName(name); + + if (layer != null) { + layer.setIsVisible(active); + } + } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :