JTS空间坐标Geometry使用

Geomtery子类图

Geomtery子类图

创建Geometry


GeometryFactory geometryFactory = JTSFactoryFinder.getGeometryFactory();

// 点
Coordinate coord = new Coordinate(1, 1);
Point point = geometryFactory.createPoint(coord);

// 线
Coordinate[] coordinates =  new Coordinate[] {new Coordinate(0, 2), new Coordinate(2, 0), new Coordinate(8, 6) };
LineString line = geometryFactory.createLineString(coordinates);

// 面
Coordinate[] coords  =  new Coordinate[] {new Coordinate(4, 0), new Coordinate(2, 2), new Coordinate(4, 4), new Coordinate(6, 2), new Coordinate(4, 0) };
LinearRing ring = geometryFactory.createLinearRing(coords);
LinearRing holes[] = null; // use LinearRing[] to represent holes
Polygon polygon = geometryFactory.createPolygon(ring, holes);

// 圆
CurvedGeometryFactory curvedFactory = new CurvedGeometryFactory(geometryFactory, Double.MAX_VALUE);
CoordinateSequence coords =  PackedCoordinateSequenceFactory.DOUBLE_FACTORY.create(new double[] {10, 14, 6, 10, 14, 10}, 2);
CircularString arc = (CircularString) curvedFactory.createCurvedGeometry(coords);

Geometry转换坐标系


CoordinateReferenceSystem sourceCRS = CRS.decode("EPSG:4326");
CoordinateReferenceSystem targetCrs = CRS.decode("EPSG:4490");

boolean lenient = true; // allow for some error due to different datums
MathTransform transform = CRS.findMathTransform(sourceCRS, targetCrs, lenient);

Geometry geometry2 = JTS.transform(geometry, transform);

Geometry方法


// 空间判断
// 不相交
boolean disjoint = geometry.disjoint(geometry2);
// 相交
boolean intersects = geometry.intersects(geometry2);
// 相切,内部不相交
boolean touches = geometry.touches(geometry2);


// 被包含
boolean within = geometry.within(geometry2);
//包含,只针对几何内部而言,不计算边界
boolean contains = geometry.contains(geometry2);
//覆盖,不区分集合边界与内部
boolean covers = geometry.covers(geometry);

//相交,不能是相切或者包含
boolean crosses = geometry.crosses(geometry);
//相交
boolean overlaps = geometry.overlaps(geometry2);
// 两个几何的空间关系
IntersectionMatrix relate1 = geometry.relate(geometry2);

//空间计算
//求交集
Geometry intersection = geometry.intersection(geometry2);
//求并集
Geometry union = geometry.union(geometry);
//geometry-交集
Geometry difference = geometry.difference(geometry2);
// 并集-交集
Geometry symDifference = geometry.symDifference(geometry);
// 几何缓冲生成新几何
Geometry buffer1 = geometry.buffer(2);
// 生成包含几何的最小凸多边形
Geometry convexHull = geometry.convexHull();
// 两个几何的最小距离
double distance = geometry.distance(geometry);

// 面积
double area = geometry.getArea();
//几何类型
String geometryType = geometry.getGeometryType();
// 边界
Geometry boundary = geometry.getBoundary();
// 获取中心点
Point centroid = geometry.getCentroid();

Geometry 与 WKT 转换


// geometry转wkt
//方法一
WKTWriter2 wktWriter2 = new WKTWriter2()
String wkt = wktWriter2.write(geometry)
//方法二
String text = geometry.toText();


// wkt转geometry
WKTReader2 wktReader2 = WKTReader2()
Point point = (Point) wktReader2.read("POINT (1 1)");

LineString line = (LineString) wktReader2.read("LINESTRING(0 2, 2 0, 8 6)");

Polygon polygon = (Polygon) wktReader2.read("POLYGON((20 10, 30 0, 40 10, 30 20, 20 10))");

pom.xml

<dependencies>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-shapefile</artifactId>
            <version>${geotools.version}</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-epsg-hsql</artifactId>
            <version>${geotools.version}</version>
        </dependency>
    </dependencies>
  <repositories>
    <repository>
      <id>osgeo</id>
      <name>OSGeo Release Repository</name>
      <url>https://repo.osgeo.org/repository/release/</url>
      <snapshots><enabled>false</enabled></snapshots>
      <releases><enabled>true</enabled></releases>
    </repository>
    <repository>
      <id>osgeo-snapshot</id>
      <name>OSGeo Snapshot Repository</name>
      <url>https://repo.osgeo.org/repository/snapshot/</url>
      <snapshots><enabled>true</enabled></snapshots>
      <releases><enabled>false</enabled></releases>
    </repository>
  </repositories>

原文链接:https://www.cnblogs.com/walkAlwaysInCode/p/17331474.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JTS空间坐标Geometry使用 - Python技术站

(0)
上一篇 2023年4月23日
下一篇 2023年4月24日

相关文章

  • springboot使用校验框架validation校验的示例

    下面我将为您详细讲解 “springboot使用校验框架validation校验的示例”。 1. 简介 Spring Boot是一个非常受欢迎的Java开发框架,同样,校验数据是每个Web应用的基本要求之一。在Spring Boot中,可以使用Validation框架轻松地完成数据校验。 Validation是Java Bean Validation API…

    Java 2023年5月19日
    00
  • Java 8中的18个常用日期处理(收藏)

    Java 8中的18个常用日期处理(收藏) 介绍 Java 8以前的日期处理方式比较麻烦,Java 8引入了新的日期时间API,也称为JSR-310,使对日期和时间的处理更加简便。本文将介绍Java 8中的18个常用日期处理方法。 1. 获取当天的日期 LocalDate today = LocalDate.now(); 使用LocalDate.now()方…

    Java 2023年5月20日
    00
  • 快速定位Java 内存OOM的问题

    快速定位Java 内存OOM的问题完整攻略 什么是Java OOM? Java Out Of Memory(简称Java OOM)指的是Java虚拟机向操作系统申请内存失败,导致异常终止程序运行的问题。原因可能是Java堆内存不足,也可能是永久代、元空间等内在资源耗尽。 快速定位Java OOM的过程 1. 分析异常数据 当Java OOM产生时,JVM会把…

    Java 2023年5月27日
    00
  • JDK8时间相关类超详细总结(含多个实例)

    JDK8时间相关类超详细总结(含多个实例) 为什么需要时间相关的类? 在程序设计中,我们经常需要使用到时间相关的操作,例如获取当前时间、将时间转换成特定格式、计算时间差等。而Java的JDK 8中提供了许多时间类的操作,可以方便地进行时间处理。 JDK8时间相关类 Instant Instant类表示时间点,它是相对于时间线上的一个点,可以精确到纳秒级别。常…

    Java 2023年5月20日
    00
  • Java基础教程之整数运算

    Java基础教程之整数运算攻略 Java是一种强类型语言,其中包含了整数类型及其运算操作。本文将详细讲解Java基础教程中的整数运算,包括基本概念、运算规则和示例说明。 基本概念 Java中的整数类型主要有四种:byte、short、int和long,对应的存储空间分别为1、2、4和8个字节。整数运算包括加、减、乘、除和取模等操作。 运算规则 Java中的整…

    Java 2023年5月26日
    00
  • Spring mvc 实现用户登录的方法(拦截器)

    下面是实现Spring MVC用户登录的方法(拦截器)的详细攻略: 1. 拦截器的作用 拦截器(Interceptor)在Spring MVC中是一个非常重要的组成部分,它主要用于拦截请求和响应,进行预处理和后处理。拦截器可以应用在如下场景: 用户身份验证 用户请求日志记录 请求响应的编码和解码 访问控制与权限验证等 在用户登录的场景中,我们可以通过拦截器来…

    Java 2023年5月16日
    00
  • 关于Maven混合配置私有仓库和公共仓库的问题

    这里是一份关于Maven混合配置私有仓库和公共仓库的完整攻略: 1. 添加私有仓库 如果你想要将私有仓库添加到你的Maven配置中,可以按照以下步骤: 1.1. 在pom.xml中添加私有仓库 将以下代码添加到你的pom.xml中,替换${私有仓库地址}为你的私有仓库地址: <repositories> <repository> &l…

    Java 2023年5月20日
    00
  • 计算机网络面试问题集锦(附答案)

    以下是针对“计算机网络面试问题集锦(附答案)”的完整攻略。 1. 了解面试题目类型及基本知识点 首先,我们需要了解计算机网络面试题目的种类和计算机网络基本知识点。可能会包括以下几种类型的问题: 基础概念(如OSI七层模型,TCP/IP协议族等) 网络协议(如UDP,TCP,HTTP等的原理和应用场景) 网络编程(如socket编程,HTTP服务器搭建等) 网…

    Java 2023年5月20日
    00
合作推广
合作推广
分享本页
返回顶部