//$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.views.swing.digitize; import java.awt.BasicStroke; import java.awt.Color; import java.awt.Graphics; import java.util.ArrayList; import java.util.Iterator; import java.util.LinkedList; import java.util.List; import org.deegree.framework.log.ILogger; import org.deegree.framework.log.LoggerFactory; import org.deegree.graphics.transformation.GeoTransform; import org.deegree.igeo.ApplicationContainer; import org.deegree.igeo.i18n.Messages; import org.deegree.igeo.mapmodel.MapModel; import org.deegree.igeo.views.DialogFactory; import org.deegree.igeo.views.swing.drawingpanes.SwingGeoDrawingPane; import org.deegree.model.feature.Feature; import org.deegree.model.feature.FeatureCollection; import org.deegree.model.spatialschema.Curve; import org.deegree.model.spatialschema.Geometry; import org.deegree.model.spatialschema.GeometryFactory; import org.deegree.model.spatialschema.GeometryImpl; import org.deegree.model.spatialschema.MultiCurve; import org.deegree.model.spatialschema.MultiPoint; import org.deegree.model.spatialschema.MultiSurface; import org.deegree.model.spatialschema.Point; import org.deegree.model.spatialschema.Surface; /** * * * @author <a href="mailto:poth@lat-lon.de">Andreas Poth</a> * @author last edited by: $Author$ * * @version. $Revision$, $Date$ */ public class MoveFeatureDrawingPane extends SwingGeoDrawingPane { private static ILogger LOG = LoggerFactory.getLogger( MoveFeatureDrawingPane.class ); private static BasicStroke dashedStroke = new BasicStroke( 1, BasicStroke.CAP_ROUND, BasicStroke.JOIN_MITER, 1, new float[] { 10, 10 }, 1 ); private static BasicStroke pointDashedStroke = new BasicStroke( 3, BasicStroke.CAP_ROUND, BasicStroke.JOIN_MITER, 1, new float[] { 2, 2 }, 1 ); private List<Geometry> geometryList; private Point startPoint; private Point lastPoint; /** * @param appCont */ public MoveFeatureDrawingPane( ApplicationContainer<?> appCont ) { super( appCont ); } /* * (non-Javadoc) * * @see org.deegree.igeo.views.DrawingPane#draw(int, int, java.awt.Graphics) */ public void draw( int x, int y, Graphics g ) { draw( x, y ); Point tmp = getCurrentAsGeoPoint(); points.remove( 1 ); points.add( tmp ); double dx = -1 * ( lastPoint.getX() - tmp.getX() ); double dy = -1 * ( lastPoint.getY() - tmp.getY() ); lastPoint = tmp; double[] d = new double[] { dx, dy }; if ( geometryList != null ) { for ( Geometry geometry : geometryList ) { geometry.translate( d ); if ( geometry instanceof Point ) { Point p = (Point) geometry; drawPoint( g, p, 6, pointDashedStroke, Color.BLACK, null ); } else if ( geometry instanceof MultiPoint ) { Point[] points = ( (MultiPoint) geometry ).getAllPoints(); for ( Point point : points ) { drawPoint( g, point, 6, pointDashedStroke, Color.BLACK, null ); } } else if ( geometry instanceof Curve ) { drawCurve( g, (Curve) geometry, dashedStroke, Color.BLACK ); } else if ( geometry instanceof MultiCurve ) { Curve[] curves = ( (MultiCurve) geometry ).getAllCurves(); for ( Curve curve : curves ) { drawCurve( g, curve, dashedStroke, Color.BLACK ); } } else if ( geometry instanceof Surface ) { drawSurface( g, (Surface) geometry, dashedStroke, Color.BLACK, null ); } else if ( geometry instanceof MultiSurface ) { Surface[] surfaces = ( (MultiSurface) geometry ).getAllSurfaces(); for ( Surface surface : surfaces ) { drawSurface( g, surface, dashedStroke, Color.BLACK, null ); } } } } } /* * (non-Javadoc) * * @see org.deegree.igeo.views.DrawingPane#draw(int, int) */ public void draw( int x, int y ) { this.currentX = x; this.currentY = y; } /* * (non-Javadoc) * * @see org.deegree.igeo.views.DrawingPane#isDrawing() */ public boolean isDrawing() { return isDrawing; } /* * (non-Javadoc) * * @see org.deegree.igeo.views.DrawingPane#setGraphicContext(java.awt.Graphics) */ public void setGraphicContext( Graphics g ) { this.g = g; } /* * (non-Javadoc) * * @see org.deegree.igeo.views.DrawingPane#startDrawing(int, int) */ public void startDrawing( int x, int y ) { points = new LinkedList<Point>(); GeoTransform gt = mapModel.getToTargetDeviceTransformation(); double xx = gt.getSourceX( x ); double yy = gt.getSourceY( y ); startPoint = GeometryFactory.createPoint( xx, yy, mapModel.getCoordinateSystem() ); lastPoint = GeometryFactory.createPoint( xx, yy, mapModel.getCoordinateSystem() ); points.add( startPoint ); points.add( lastPoint ); isDrawing = true; } /* * (non-Javadoc) * * @see org.deegree.igeo.views.DrawingPane#stopDrawing(int, int) */ public void stopDrawing( int x, int y ) { draw( x, y, g ); } /** * * @return current x/y coordinate as geographic coordinate according to the underlying {@link MapModel} */ public Point getCurrentAsGeoPoint() { GeoTransform gt = mapModel.getToTargetDeviceTransformation(); double xx = gt.getSourceX( currentX ); double yy = gt.getSourceY( currentY ); return GeometryFactory.createPoint( xx, yy, mapModel.getCoordinateSystem() ); } @Override public void setFeatureCollection( FeatureCollection fc ) { if ( fc == null || fc.size() == 0 ) { DialogFactory.openErrorDialog( "application", null, Messages.get( "$MD11094" ), Messages.get( "$MD11095" ) ); return; } geometryList = new ArrayList<Geometry>(); Iterator<Feature> iterator = fc.iterator(); while ( iterator.hasNext() ) { Feature feature = iterator.next(); Geometry[] geometries = feature.getGeometryPropertyValues(); for ( Geometry geometry : geometries ) { try { geometry = (Geometry) ( (GeometryImpl) geometry ).clone(); } catch ( CloneNotSupportedException e ) { LOG.logError( e.getMessage(), e ); } geometryList.add( geometry ); } } super.setFeatureCollection( fc ); } }