001: /*
002: * GeoTools - OpenSource mapping toolkit
003: * http://geotools.org
004: * (C) 2004-2006, Geotools Project Managment Committee (PMC)
005: *
006: * This library is free software; you can redistribute it and/or
007: * modify it under the terms of the GNU Lesser General Public
008: * License as published by the Free Software Foundation; either
009: * version 2.1 of the License, or (at your option) any later version.
010: *
011: * This library is distributed in the hope that it will be useful,
012: * but WITHOUT ANY WARRANTY; without even the implied warranty of
013: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
014: * Lesser General Public License for more details.
015: *
016: * Created on Jan 24, 2004
017: */
018: package org.geotools.validation.spatial;
019:
020: import java.util.Map;
021:
022: import org.geotools.data.FeatureSource;
023: import org.geotools.feature.Feature;
024: import org.geotools.validation.ValidationResults;
025:
026: import com.vividsolutions.jts.geom.Envelope;
027: import com.vividsolutions.jts.geom.Geometry;
028:
029: /**
030: * PolygonNotOverlappingLineValidation purpose.
031: *
032: * <p>
033: * Checks that the polygon is not overlapping the line.
034: * </p>
035: *
036: * @author dzwiers, Refractions Research, Inc.
037: * @author $Author: dmzwiers $ (last modification)
038: * @source $URL: http://svn.geotools.org/geotools/tags/2.4.1/modules/extension/validation/src/main/java/org/geotools/validation/spatial/PolygonNotOverlappingLineValidation.java $
039: * @version $Id: PolygonNotOverlappingLineValidation.java 22666 2006-11-09 03:50:28Z jgarnett $
040: */
041: public class PolygonNotOverlappingLineValidation extends
042: PolygonLineAbstractValidation {
043: /**
044: * PolygonNotOverlappingLineValidation constructor.
045: *
046: * <p>
047: * Description
048: * </p>
049: */
050: public PolygonNotOverlappingLineValidation() {
051: super ();
052: }
053:
054: /**
055: * Check that the polygon is not overlapping the line.
056: *
057: * @param layers Map of FeatureSource by "dataStoreID:typeName"
058: * @param envelope The bounding box that encloses the unvalidated data
059: * @param results Used to coallate results information
060: *
061: * @return <code>true</code> if all the features pass this test.
062: *
063: * @throws Exception DOCUMENT ME!
064: */
065: public boolean validate(Map layers, Envelope envelope,
066: ValidationResults results) throws Exception {
067: FeatureSource polySource1 = (FeatureSource) layers
068: .get(getPolygonTypeRef());
069: FeatureSource polySource2 = (FeatureSource) layers
070: .get(getRestrictedLineTypeRef());
071:
072: Object[] poly1 = polySource1.getFeatures().toArray();
073: Object[] poly2 = polySource2.getFeatures().toArray();
074:
075: if (!envelope.contains(polySource1.getBounds())) {
076: results
077: .error((Feature) poly1[0],
078: "Polygon Feature Source is not contained within the Envelope provided.");
079:
080: return false;
081: }
082:
083: if (!envelope.contains(polySource2.getBounds())) {
084: results
085: .error(
086: (Feature) poly1[0],
087: "Restricted Polygon Feature Source is not contained within the Envelope provided.");
088:
089: return false;
090: }
091:
092: for (int i = 0; i < poly1.length; i++) {
093: Feature tmp = (Feature) poly1[i];
094: Geometry gt = tmp.getDefaultGeometry();
095:
096: for (int j = 0; j < poly2.length; j++) {
097: Feature tmp2 = (Feature) poly2[j];
098: Geometry gt2 = tmp2.getDefaultGeometry();
099:
100: if (gt2.touches(gt)) {
101: return false;
102: }
103: }
104: }
105:
106: return true;
107: }
108: }
|