
org.geomajas.command.geometry.GeometryMergeCommand Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of geomajas-command Show documentation
Show all versions of geomajas-command Show documentation
Geomajas server: Main - commands
The newest version!
/*
* This is part of Geomajas, a GIS framework, http://www.geomajas.org/.
*
* Copyright 2008-2016 Geosparc nv, http://www.geosparc.com/, Belgium.
*
* The program is available in open source according to the GNU Affero
* General Public License. All contributions in this program are covered
* by the Geomajas Contributors License Agreement. For full licensing
* details, see LICENSE.txt in the project root.
*/
package org.geomajas.command.geometry;
import java.util.ArrayList;
import java.util.List;
import org.geomajas.annotation.Api;
import org.geomajas.command.CommandHasRequest;
import org.geomajas.command.dto.GeometryMergeRequest;
import org.geomajas.command.dto.GeometryMergeResponse;
import org.geomajas.global.ExceptionCode;
import org.geomajas.global.GeomajasException;
import org.geomajas.service.DtoConverterService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import com.vividsolutions.jts.geom.Geometry;
import com.vividsolutions.jts.geom.GeometryCollection;
import com.vividsolutions.jts.geom.GeometryFactory;
import com.vividsolutions.jts.geom.PrecisionModel;
/**
*
* This command merges multiple geometries into a single geometry.
*
*
* @author Pieter De Graef
* @since 1.11.0
*/
@Component
@Api
public class GeometryMergeCommand implements CommandHasRequest {
@Autowired
private DtoConverterService converter;
@Override
public GeometryMergeRequest getEmptyCommandRequest() {
return new GeometryMergeRequest();
}
@Override
public GeometryMergeResponse getEmptyCommandResponse() {
return new GeometryMergeResponse();
}
@Override
public void execute(GeometryMergeRequest request, GeometryMergeResponse response) throws Exception {
List clientGeometries = request.getGeometries();
if (clientGeometries == null || clientGeometries.size() == 0) {
throw new GeomajasException(ExceptionCode.PARAMETER_MISSING, "request");
}
if (clientGeometries.size() == 1) {
response.setGeometry(clientGeometries.get(0));
return;
}
int precision = request.getPrecision();
List geometries = new ArrayList();
for (org.geomajas.geometry.Geometry geometry : clientGeometries) {
geometry.setPrecision(precision);
geometries.add(converter.toInternal(geometry));
}
PrecisionModel precisionModel;
if (precision == -1) {
precisionModel = new PrecisionModel(PrecisionModel.FLOATING);
precision = 20;
} else {
precisionModel = new PrecisionModel(Math.pow(10.0, precision));
}
GeometryFactory factory = new GeometryFactory(precisionModel, geometries.get(0).getSRID());
// Calculate the union:
double buffer = 0;
if (request.usePrecisionAsBuffer()) {
buffer = Math.pow(10.0, -(precision - 1));
}
GeometryCollection geometryCollection = (GeometryCollection) factory.buildGeometry(geometries);
Geometry union = geometryCollection.buffer(buffer);
response.setGeometry(converter.toDto(union));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy