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


Java Geometry類代碼示例

本文整理匯總了Java中org.locationtech.jts.geom.Geometry的典型用法代碼示例。如果您正苦於以下問題:Java Geometry類的具體用法?Java Geometry怎麽用?Java Geometry使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: testNegExtPolyRings

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
@Test
public void testNegExtPolyRings() {
    try {
        // Single MultiPolygon with two triangles that have negative area from shoelace formula
        // Support for 'V1' MVTs.
        final JtsMvt mvt = loadMvt(
                "src/test/resources/mapbox/vector_tile_js/multi_poly_neg_exters.mvt",
                MvtReader.RING_CLASSIFIER_V1);
        final List<Geometry> geoms = getAllGeometries(mvt);

        assertEquals(1, geoms.size());
        assertTrue(geoms.get(0) instanceof MultiPolygon);
    } catch (IOException e) {
        fail(e.getMessage());
    }
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:17,代碼來源:MvtReaderTest.java

示例2: getDatabaseObject

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
@Override
public Object getDatabaseObject(GeometryObject geomObj, Connection connection) throws SQLException {
	Geometry geometry = null;

	switch (geomObj.getGeometryType()) {
	case POLYGON:
		geometry = convertPolygonToJTS(geomObj);
		break;
	case LINE_STRING:
	case POINT:
	case MULTI_LINE_STRING:
	case MULTI_POINT:
	case ENVELOPE:
	case MULTI_POLYGON:
	case SOLID:
	case COMPOSITE_SOLID:
		break;
	}

	if (geometry == null)
		throw new SQLException("Failed to convert geometry to internal database representation.");

	return geometry;		
}
 
開發者ID:3dcitydb,項目名稱:importer-exporter,代碼行數:25,代碼來源:GeometryConverterAdapter.java

示例3: validate

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
/**
 * Validate the JtsLayer.
 *
 * @param name mvt layer name
 * @param geometries geometries in the tile
 * @throws IllegalArgumentException when {@code name} or {@code geometries} are null
 */
private static void validate(String name, Collection<Geometry> geometries) {
    if (name == null) {
        throw new IllegalArgumentException("layer name is null");
    }
    if (geometries == null) {
        throw new IllegalArgumentException("geometry collection is null");
    }
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:16,代碼來源:JtsLayer.java

示例4: encode

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
/**
 * Encode a {@link JtsMvt} to byte[] ready for writing to a file.
 *
 * @param mvt input to encode to bytes
 * @param mvtLayerParams tile creation parameters
 * @param userDataConverter converts {@link Geometry#userData} to MVT feature tags
 * @return bytes ready for writing to a .mvt
 */
public static byte[] encode(JtsMvt mvt, MvtLayerParams mvtLayerParams, IUserDataConverter userDataConverter) {

    // Build MVT
    final VectorTile.Tile.Builder tileBuilder = VectorTile.Tile.newBuilder();

    for(JtsLayer layer : mvt.getLayers()) {
        final Collection<Geometry> layerGeoms = layer.getGeometries();

        // Create MVT layer
        final VectorTile.Tile.Layer.Builder layerBuilder =
                MvtLayerBuild.newLayerBuilder(layer.getName(), mvtLayerParams);
        final MvtLayerProps layerProps = new MvtLayerProps();

        // MVT tile geometry to MVT features
        final List<VectorTile.Tile.Feature> features = JtsAdapter.toFeatures(
                layerGeoms, layerProps, userDataConverter);
        layerBuilder.addAllFeatures(features);
        MvtLayerBuild.writeProps(layerBuilder, layerProps);

        // Build MVT layer
        final VectorTile.Tile.Layer vtl = layerBuilder.build();
        tileBuilder.addLayers(vtl);
    }

    // Build MVT
    return tileBuilder.build().toByteArray();
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:36,代碼來源:MvtEncoder.java

示例5: singleLayer

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
@Test
public void singleLayer() throws IOException {
    Collection<Geometry> geometries = PointGen.australia();

    JtsLayer layer = new JtsLayer("animals", geometries);
    JtsMvt mvt = new JtsMvt(singletonList(layer));

    final byte[] encoded = MvtEncoder.encode(mvt);
    assertEquals(mvt, decode(encoded));
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:11,代碼來源:MvtEncoderTest.java

示例6: australia

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
private static Collection<Geometry> australia() {
    return getPoints(
            createPoint("Koala"),
            createPoint("Wombat"),
            createPoint("Platypus"),
            createPoint("Dingo"),
            createPoint("Croc"));
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:9,代碼來源:MvtEncoderTest.java

示例7: uk

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
private static Collection<Geometry> uk() {
    return getPoints(
            createPoint("Hare"),
            createPoint("Frog"),
            createPoint("Robin"),
            createPoint("Fox"),
            createPoint("Hedgehog"),
            createPoint("Bulldog"));
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:10,代碼來源:MvtEncoderTest.java

示例8: usa

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
private static Collection<Geometry> usa() {
    return getPoints(
            createPoint("Cougar"),
            createPoint("Raccoon"),
            createPoint("Beaver"),
            createPoint("Wolf"),
            createPoint("Bear"),
            createPoint("Coyote"));
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:10,代碼來源:MvtEncoderTest.java

示例9: testLayerCollection

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
@Test
public void testLayerCollection() {
    String layerName = "Points of Interest";
    List<Geometry> geometries = new ArrayList<>();

    JtsLayer layer = new JtsLayer(layerName, geometries);

    String actualName = layer.getName();
    String expectedName = layerName;
    assertEquals(expectedName, actualName);

    Collection<Geometry> actualGeometry = layer.getGeometries();
    Collection<Geometry> expectedGeometry = geometries;
    assertEquals(expectedGeometry, actualGeometry);
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:16,代碼來源:JtsLayerTest.java

示例10: testAddGeometry

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
@Test
public void testAddGeometry() {
    String layerName = "Points of Interest";
    List<Geometry> geometries = new ArrayList<>();

    Point point = createPoint(new int[]{51, 0});

    JtsLayer layer = new JtsLayer(layerName, geometries);
    layer.getGeometries().add(point);

    assertTrue(layer.getGeometries().contains(point));
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:13,代碼來源:JtsLayerTest.java

示例11: testAddGeometries

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
@Test
public void testAddGeometries() {
    String layerName = "Points of Interest";
    List<Geometry> geometries = new ArrayList<>();

    Point point = createPoint(new int[]{50, 0});
    Point point2 = createPoint(new int[]{51, 1});
    Collection<Geometry> points = Arrays.asList(point, point2);

    JtsLayer layer = new JtsLayer(layerName, geometries);
    layer.getGeometries().addAll(points);

    assertTrue(layer.getGeometries().containsAll(Arrays.asList(point, point2)));
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:15,代碼來源:JtsLayerTest.java

示例12: simpleTest

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
@Test
public void simpleTest() {
    try {
        // Load multipolygon z0 tile
        final JtsMvt mvt = loadMvt("src/test/resources/vec_tile_test/0/0/0.mvt");

        List<Geometry> geoms = getAllGeometries(mvt);

        // Debug stats of multipolygon
        final JtsGeomStats stats = JtsGeomStats.getStats(geoms);
        LoggerFactory.getLogger(MvtReaderTest.class).info("Stats: {}", stats);
    } catch (IOException e) {
        fail(e.getMessage());
    }
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:16,代碼來源:MvtReaderTest.java

示例13: getAllGeometries

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
private List<Geometry> getAllGeometries(JtsMvt mvt) {
    List<Geometry> allGeoms = new ArrayList<>();
    for (JtsLayer l : mvt.getLayers()) {
        allGeoms.addAll(l.getGeometries());
    }
    return allGeoms;
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:8,代碼來源:MvtReaderTest.java

示例14: getPoints

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
private static Collection<Geometry> getPoints(Point... points) {
    return asList(points);
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:4,代碼來源:MvtEncoderTest.java

示例15: TileGeomResult

import org.locationtech.jts.geom.Geometry; //導入依賴的package包/類
/**
 * Create TileGeomResult, which contains the intersection of geometry and MVT geometry.
 *
 * @param intGeoms geometry intersecting tile
 * @param mvtGeoms geometry for MVT
 * @throws NullPointerException if intGeoms or mvtGeoms are null
 */
public TileGeomResult(List<Geometry> intGeoms, List<Geometry> mvtGeoms) {
    JdkUtils.requireNonNull(intGeoms);
    JdkUtils.requireNonNull(mvtGeoms);
    this.intGeoms = intGeoms;
    this.mvtGeoms = mvtGeoms;
}
 
開發者ID:wdtinc,項目名稱:mapbox-vector-tile-java,代碼行數:14,代碼來源:TileGeomResult.java


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