//$HeadURL$ /*---------------- FILE HEADER ------------------------------------------ This file is part of deegree. Copyright (C) 2001-2008 by: Department of Geography, University of Bonn http://www.giub.uni-bonn.de/deegree/ lat/lon GmbH http://www.lat-lon.de This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA Contact: Andreas Poth lat/lon GmbH Aennchenstr. 19 53177 Bonn Germany E-Mail: poth@lat-lon.de Prof. Dr. Klaus Greve Department of Geography University of Bonn Meckenheimer Allee 166 53115 Bonn Germany E-Mail: greve@giub.uni-bonn.de ---------------------------------------------------------------------------*/ package org.deegree.igeo.modules.remotecontrol; import java.util.ArrayList; import java.util.List; import java.util.Map; import org.deegree.framework.log.ILogger; import org.deegree.framework.log.LoggerFactory; import org.deegree.framework.util.StringTools; import org.deegree.igeo.ApplicationContainer; import org.deegree.igeo.commands.SelectFeatureCommand; import org.deegree.igeo.commands.model.ZoomCommand; import org.deegree.igeo.i18n.Messages; import org.deegree.igeo.mapmodel.Layer; import org.deegree.igeo.mapmodel.LayerGroup; import org.deegree.igeo.mapmodel.MapModel; import org.deegree.igeo.mapmodel.MapModelVisitor; import org.deegree.igeo.modules.ModuleException; import org.deegree.model.Identifier; import org.deegree.model.feature.FeatureCollection; import org.deegree.model.spatialschema.Envelope; import org.deegree.model.spatialschema.GeometryException; /** * The <code></code> class TODO add class documentation here. * * @author <a href="mailto:poth@lat-lon.de">Andreas Poth</a> * * @author last edited by: $Author$ * * @version $Revision$, $Date$ * */ public class SelectFeatureHandler implements RequestHandler { private static final ILogger LOG = LoggerFactory.getLogger( SelectFeatureHandler.class ); /* * (non-Javadoc) * * @see org.deegree.igeo.modules.remotecontrol.RequestHandler#perform(java.util.Map, * org.deegree.igeo.ApplicationContainer) */ public String perform( Map<String, String> paramater, ApplicationContainer<?> appContainer ) throws ModuleException { String tmp = paramater.get( "OBJECTIDS" ); if ( tmp == null || tmp.length() == 0 ) { throw new ModuleException( Messages.get( "$DG10091" ) ); } List<String> objIds = StringTools.toList( tmp, ",;", true ); tmp = paramater.get( "LAYER" ); if ( tmp == null ) { throw new ModuleException( Messages.get( "$DG10092" ) ); } MapModel mapModel = appContainer.getMapModel( null ); LocalMapModelVisitor mv = new LocalMapModelVisitor( tmp ); try { mapModel.walkLayerTree( mv ); } catch ( Exception e ) { LOG.logError( e.getMessage(), e ); throw new ModuleException( e.getMessage() ); } Layer layer = mv.getResult(); if ( layer == null ) { throw new ModuleException( Messages.get( "$DG10093", tmp ) ); } layer.setVisible( true ); // first select features in layer List<Identifier> ids = new ArrayList<Identifier>(); for ( String id : objIds ) { ids.add( new Identifier( id ) ); } SelectFeatureCommand cmd = new SelectFeatureCommand( layer, ids, false ); try { appContainer.getCommandProcessor().executeSychronously( cmd, true ); } catch ( Exception e ) { LOG.logError( e.getMessage(), e ); throw new ModuleException( e.getMessage() ); } // get selected features as FeatureCollection and so their common bounding box FeatureCollection fc = layer.getSelectedFeatures(); if ( fc.size() == 0 ) { throw new ModuleException( Messages.get( "$DG10094", paramater.get( "OBJECTIDS" ) ) ); } Envelope env = null; try { env = fc.getBoundedBy(); if ( env.getWidth() < 0.0001 ) { // feature collection just contains one point; set fix bbox width/height // 25 map units env = env.getBuffer( 25 ); } } catch ( GeometryException e ) { LOG.logError( e.getMessage(), e ); throw new ModuleException( e.getMessage() ); } // zoom to common bounding box of selected features ZoomCommand zcmd = new ZoomCommand( mapModel ); zcmd.setZoomBox( env, mapModel.getTargetDevice().getPixelWidth(), mapModel.getTargetDevice().getPixelHeight() ); if ( "TRUE".equalsIgnoreCase( paramater.get( "sync" ) ) ) { try { appContainer.getCommandProcessor().executeSychronously( zcmd, true ); } catch ( Exception e ) { LOG.logError( e.getMessage(), e ); throw new ModuleException( e.getMessage() ); } } else { appContainer.getCommandProcessor().executeASychronously( zcmd ); } return "feature selected"; } // //////////////////////////////////////////////////////////////////////////////////////////// // inner classes // //////////////////////////////////////////////////////////////////////////////////////////// private class LocalMapModelVisitor implements MapModelVisitor { private String layerTitle; private Layer result; /** * * @param layerTitle */ LocalMapModelVisitor( String layerTitle ) { this.layerTitle = layerTitle; } /** * */ public void visit( Layer layer ) throws Exception { if ( layer.getTitle().equals( layerTitle ) ) { result = layer; } } /** * */ public void visit( LayerGroup layerGroup ) throws Exception { } /** * @return the result */ public Layer getResult() { return result; } } @Override public void init( Map<String, String> parameters ) { // does not use parameters } }