當前位置: 首頁>>代碼示例>>Java>>正文


Java JTS.toGeometry方法代碼示例

本文整理匯總了Java中org.geotools.geometry.jts.JTS.toGeometry方法的典型用法代碼示例。如果您正苦於以下問題:Java JTS.toGeometry方法的具體用法?Java JTS.toGeometry怎麽用?Java JTS.toGeometry使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.geotools.geometry.jts.JTS的用法示例。


在下文中一共展示了JTS.toGeometry方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: call

import org.geotools.geometry.jts.JTS; //導入方法依賴的package包/類
public Object call(Properties bindings, Object[] args) {
    if(args.length==2){
        String lat = args[0].toString();
        String lng = args[1].toString();

        double[] latlng = {
            Double.parseDouble(lat),
            Double.parseDouble(lng)
        };
        
        GeometryBuilder builder = new GeometryBuilder(DefaultGeographicCRS.WGS84);
        
        return JTS.toGeometry(builder.createPoint(latlng).getDirectPosition());
    }
    return new EvalError(ControlFunctionRegistry.getFunctionName(this) + " expects 2 arguments");
}
 
開發者ID:ryanfb,項目名稱:georefine,代碼行數:17,代碼來源:CreatePoint.java

示例2: clipTile

import org.geotools.geometry.jts.JTS; //導入方法依賴的package包/類
/**
 * Apply clipping to the features in a tile. The tile and its features should already be in map space.
 *
 * @param tile
 *            tile to put features in
 * @param scale
 *            scale
 * @param panOrigin
 *            When panning on the client, only this parameter changes. So we need to be aware of it as we calculate
 *            the maxScreenEnvelope.
 * @throws GeomajasException oops
 */
public void clipTile(InternalTile tile, double scale, Coordinate panOrigin) throws GeomajasException {
	log.debug("clipTile before {}", tile);
	List<InternalFeature> orgFeatures = tile.getFeatures();
	tile.setFeatures(new ArrayList<InternalFeature>());
	Geometry maxScreenBbox = null; // The tile's maximum bounds in screen space. Used for clipping.
	for (InternalFeature feature : orgFeatures) {
		// clip feature if necessary
		if (exceedsScreenDimensions(feature, scale)) {
			log.debug("feature {} exceeds screen dimensions", feature);
			InternalFeatureImpl vectorFeature = (InternalFeatureImpl) feature.clone();
			tile.setClipped(true);
			vectorFeature.setClipped(true);
			if (null == maxScreenBbox) {
				maxScreenBbox = JTS.toGeometry(getMaxScreenEnvelope(tile, panOrigin));
			}
			Geometry clipped = maxScreenBbox.intersection(feature.getGeometry());
			vectorFeature.setClippedGeometry(clipped);
			tile.addFeature(vectorFeature);
		} else {
			tile.addFeature(feature);
		}
	}
	log.debug("clipTile after {}", tile);
}
 
開發者ID:geomajas,項目名稱:geomajas-project-server,代碼行數:37,代碼來源:TiledFeatureService.java

示例3: buildBoundsViewparam

import org.geotools.geometry.jts.JTS; //導入方法依賴的package包/類
private String buildBoundsViewparam(ReferencedEnvelope bbox) throws UnsupportedEncodingException {
    Polygon poly = JTS.toGeometry(bbox);
    String boundsWKT = "bounds:'"+ poly.toText()+"';";
    boundsWKT = boundsWKT.replaceAll(", ", "|");
    boundsWKT = URLEncoder.encode(boundsWKT, "UTF-8");
    return boundsWKT;
}
 
開發者ID:stefan0722,項目名稱:gs-mvt,代碼行數:8,代碼來源:SlippyTilesController.java

示例4: testEpsg

import org.geotools.geometry.jts.JTS; //導入方法依賴的package包/類
@Test
public void testEpsg() throws Exception {
	MockHttpServletRequest request = new MockHttpServletRequest();
	request.setRequestURI("/rest/beans");
	request.setMethod("GET");
	MockHttpServletResponse response = new MockHttpServletResponse();
	// check attribute equality
	request.setParameter("queryable", "stringAttr");
	request.setParameter("stringAttr_eq", "bean1");
	request.setParameter("epsg", "900913");
	ModelAndView mav = adapter.handle(request, response, restController);
	view.render(mav.getModel(), request, response);
	response.flushBuffer();
	Object json = new JSONParser().parse(response.getContentAsString());
	Assert.assertTrue(json instanceof JSONObject);
	JSONObject jsonObject = (JSONObject) json;
	JSONArray features = (JSONArray) jsonObject.get("features");
	JSONObject feature = (JSONObject) features.get(0);
	JSONObject geometry = (JSONObject) feature.get("geometry");
	GeometryJSON g = new GeometryJSON(0);
	Geometry m = g.read(geometry.toJSONString());
	Envelope envelope = new Envelope(0, 1, 0, 1);
	Geometry orig = JTS.toGeometry(envelope);
	Geometry m2 = geoservice.transform(orig, "EPSG:4326", "EPSG:900913");
	// equality check on buffer, JTS equals does not do the trick !
	Assert.assertTrue(m.buffer(0.01).contains(m2));
	Assert.assertTrue(m2.buffer(0.01).contains(m));
}
 
開發者ID:geomajas,項目名稱:geomajas-project-server,代碼行數:29,代碼來源:RestControllerTest.java

示例5: CrsTransformImpl

import org.geotools.geometry.jts.JTS; //導入方法依賴的package包/類
/**
 * Constructor.
 *
 * @param id id
 * @param source source CRS
 * @param target target CRS
 * @param mathTransform transformation
 * @param transformableBbox bounding bow of transformable area
 */
public CrsTransformImpl(String id, Crs source, Crs target, MathTransform mathTransform,
		Bbox transformableBbox) {
	this(id, source, target, mathTransform);
	if (null != transformableBbox) {
		this.transformableBbox = transformableBbox;
		this.transformableEnvelope =
				new Envelope(transformableBbox.getX(), transformableBbox.getMaxX(), transformableBbox.getY(),
						transformableBbox.getMaxY());
		this.transformableGeometry = JTS.toGeometry(transformableEnvelope);
	}
}
 
開發者ID:geomajas,項目名稱:geomajas-project-server,代碼行數:21,代碼來源:CrsTransformImpl.java

示例6: clipToWorld

import org.geotools.geometry.jts.JTS; //導入方法依賴的package包/類
private Literal clipToWorld(Literal geometry) {
    if(geometry != null) {
        Geometry g = geometry.evaluate(null, Geometry.class);
        if(g != null) {
            Envelope env = g.getEnvelopeInternal();
            // first, limit to world
            if(!WORLD.contains(env)) {
                g = sanitizePolygons(g.intersection(JTS.toGeometry(WORLD)));
            }
            
            // second, postgis will always use the shortest distance between two
            // points, if an arc is longer than 180 degrees the opposite will
            // be used instead, so we have to slice the geometry in parts
            env = g.getEnvelopeInternal();
            if(Math.sqrt(env.getWidth() * env.getWidth() + env.getHeight() * env.getHeight()) >= 180) {
                // slice in 90x90 degrees quadrants, none of them has a diagonal longer than 180
                final List<Polygon> polygons = new ArrayList<Polygon>();
                for(double lon = Math.floor(env.getMinX()); lon < env.getMaxX(); lon+= 90) {
                    for (double lat = Math.floor(env.getMinY()); lat < env.getMaxY(); lat += 90) {
                        Geometry quadrant = JTS.toGeometry(new Envelope(lon, lon + 90, lat, lat + 90));
                        Geometry cut = sanitizePolygons(g.intersection(quadrant));
                        if(!cut.isEmpty()) {
                            if(cut instanceof Polygon) {
                                polygons.add((Polygon) cut);
                            } else {
                                for (int i = 0; i < cut.getNumGeometries(); i++) {
                                    polygons.add((Polygon) cut.getGeometryN(i));
                                }
                            }
                        }
                    }
                }
                g = toPolygon(g.getFactory(), polygons);
            }
            
            geometry = CommonFactoryFinder.getFilterFactory(null).literal(g);

        }
    }
    
    return geometry;
}
 
開發者ID:DennisPallett,項目名稱:gt-jdbc-monetdb,代碼行數:43,代碼來源:FilterToSqlHelper.java

示例7: getTransformableGeometry

import org.geotools.geometry.jts.JTS; //導入方法依賴的package包/類
@Override
public Geometry getTransformableGeometry() {
	return JTS.toGeometry(getTransformableEnvelope());
}
 
開發者ID:geomajas,項目名稱:geomajas-project-server,代碼行數:5,代碼來源:GeoServiceTest.java

示例8: VectorTileEncoder

import org.geotools.geometry.jts.JTS; //導入方法依賴的package包/類
/**
 * Create a {@link VectorTileEncoder} with the given extent value.
 * <p>
 * The extent value control how detailed the coordinates are encoded in the
 * vector tile. 4096 is a good default, 256 can be used to reduce density.
 * <p>
 * The polygon clip buffer value control how large the clipping area is
 * outside of the tile for polygons. 0 means that the clipping is done at
 * the tile border. 8 is a good default.
 *
 * @param extent  a int with extent value. 4096 is a good value.
 * @param targetBbox the bbox defined for the target tile
 * @param simplificationFactor the factor for simplification
 * @param smallGeometryThreshold defines the threshold in length / area when geometries should be skipped in output. 0 or negative means all geoms are included
 */
public VectorTileEncoder(int extent, Envelope targetBbox, double simplificationFactor, double smallGeometryThreshold) {
    this.autoScale = true;
    this.extent = extent;
    this.clipGeometry = JTS.toGeometry(targetBbox);
    this.simplificationFactor = simplificationFactor;
    this.smallGeometryThreshold = smallGeometryThreshold;
}
 
開發者ID:stefan0722,項目名稱:gs-mvt,代碼行數:23,代碼來源:VectorTileEncoder.java


注:本文中的org.geotools.geometry.jts.JTS.toGeometry方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。