/* * Copyright (c) 2012 Data Harmonisation Panel * * All rights reserved. This program and the accompanying materials are made * available under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the License, * or (at your option) any later version. * * You should have received a copy of the GNU Lesser General Public License * along with this distribution. If not, see <http://www.gnu.org/licenses/>. * * Contributors: * HUMBOLDT EU Integrated Project #030962 * Data Harmonisation Panel <http://www.dhpanel.eu> */ package eu.esdihumboldt.cst.functions.geometric; import java.util.Map; import net.jcip.annotations.Immutable; import com.google.common.collect.ListMultimap; import com.vividsolutions.jts.geom.Coordinate; import com.vividsolutions.jts.geom.GeometryFactory; import com.vividsolutions.jts.geom.Point; import eu.esdihumboldt.hale.common.align.model.impl.PropertyEntityDefinition; import eu.esdihumboldt.hale.common.align.transformation.engine.TransformationEngine; import eu.esdihumboldt.hale.common.align.transformation.function.PropertyValue; import eu.esdihumboldt.hale.common.align.transformation.function.TransformationException; import eu.esdihumboldt.hale.common.align.transformation.function.impl.AbstractSingleTargetPropertyTransformation; import eu.esdihumboldt.hale.common.align.transformation.report.TransformationLog; import eu.esdihumboldt.hale.common.instance.geometry.DefaultGeometryProperty; import eu.esdihumboldt.hale.common.instance.geometry.impl.CodeDefinition; import eu.esdihumboldt.hale.common.schema.geometry.CRSDefinition; import eu.esdihumboldt.hale.common.schema.geometry.GeometryProperty; /** * Ordinates to point function. * * @author Kai Schwierczek */ @Immutable public class OrdinatesToPoint extends AbstractSingleTargetPropertyTransformation<TransformationEngine> implements OrdinatesToPointFunction { /** * @see eu.esdihumboldt.hale.common.align.transformation.function.impl.AbstractPropertyTransformation#evaluate(java.lang.String, * eu.esdihumboldt.hale.common.align.transformation.engine.TransformationEngine, * com.google.common.collect.ListMultimap, * com.google.common.collect.ListMultimap, java.util.Map, * eu.esdihumboldt.hale.common.align.transformation.report.TransformationLog) */ @Override protected Object evaluate(String transformationIdentifier, TransformationEngine engine, ListMultimap<String, PropertyValue> variables, String resultName, PropertyEntityDefinition resultProperty, Map<String, String> executionParameters, TransformationLog log) throws TransformationException { // get x, y and z properties PropertyValue x = variables.get("x").get(0); PropertyValue y = variables.get("y").get(0); PropertyValue z = null; if (!variables.get("z").isEmpty()) z = variables.get("z").get(0); // get crs definition if srs is specified CRSDefinition crsDef = null; String srs = getOptionalParameter(PARAMETER_REFERENCE_SYSTEM, null).as(String.class); if (srs != null) crsDef = new CodeDefinition(srs, null); // convert values to double and create a point double xValue = x.getValueAs(Double.class); double yValue = y.getValueAs(Double.class); Point resultPoint; GeometryFactory geomFactory = new GeometryFactory(); if (z == null) resultPoint = geomFactory.createPoint(new Coordinate(xValue, yValue)); else resultPoint = geomFactory.createPoint(new Coordinate(xValue, yValue, z .getValueAs(Double.class))); // pack result into geometry property and return it GeometryProperty<Point> result = new DefaultGeometryProperty<Point>(crsDef, resultPoint); return result; } }