JTS Java空间几何计算、距离、最近点、subLine等计算

文章目录

  • 前言
  • 地理坐标系和投影坐标系
    • 地理坐标系
    • 投影坐标系
    • 地图投影
    • 墨卡托/Web墨卡托
  • 常见坐标系
  • 地理坐标系和投影坐标系互转
    • EPSG:3857和EPSG:4326
    • Java各坐标系之间的转换(高斯、WGS84经纬度、Web墨卡托、瓦片坐标)
  • Geotools
  • JTS
    • vividsolutions和locationtech jts
    • 创建几何对象
      • 点-Point
      • 多点-MultiPoint
      • 线-LineString
      • 多线-MultiLineString
      • 闭合线-LinearRing
      • 多边形-Polygon
      • 多个多边形-MultiPolygon
      • 几何[集合](https://so.csdn.net/so/search?q=集合&spm=1001.2101.3001.7020)列表-GeometryCollection
    • 几何关系判断(返回值 boolean)
    • 几何关系分析(返回值 几何对象)
    • 距离、长度、面积计算
    • 按照代码包把所有功能介绍下
    • 图形可视化化WKT数据(好用的一比)
    • 项目实战
      • 几何到另一个几何最近的点
      • 求几何的交点
      • 利用缓冲画圆
      • 根据起始点求一个线的子线
      • 计算道路与起点之间指定距离之间的交点坐标

前言

项目需求,需要很多的空间几何计算,例如:点、线、面之间的距离、面积、长度、相交、最短距离点等,由于相关文档是真的缺乏,墙内墙外看了大量的博客和文档收集和验证了很久。现将结论和知识点整理发出来。

地理坐标系和投影坐标系

地理坐标系

地理坐标系(Geographic coordinate system),是以经纬度为地图的存储单位。很明显地理坐标系是球面坐标系统。我们要将地球上的数字化信息存放到球面坐标系统上,如何进行操作呢?地球是一个不规则的椭球,如何将数据信息以科学的方法存放到椭球上?这必然要求
我们找到这样的一个椭球体。这样的椭球体具有特点:可以量化计算的。具有长半轴,短
半轴,偏心率。以下几行便是Krasovsky_1940椭球及其相应参数。
Spheroid: Krasovsky_1940
Semimajor Axis: 6378245.000000000000000000
Semiminor Axis: 6356863.018773047300000000
Inverse Flattening(扁率): 298.300000000000010000
然而有了这个椭球体以后还不够,还需要一个大地基准面将这个椭球定位。在坐标系统描
述中,可以看到有这么一行:
Datum: D_Beijing_1954
表示,大地基准面是D_Beijing_1954。

投影坐标系

投影坐标系统,实质上便是平面坐标系统,其地图单位通常为米。

投影的意义:将球面坐标转化为平面坐标的过程便称为投影。

地理坐标系右下角显示Degrees(度)表示经纬度;投影显示的是Meters(米)

imgimg

平常看到的WGS84、高德、百度坐标系都是地理坐标系,当我们需要计算距离、面积、长度时需要用投影坐标系

地图投影

利用一定数学法则把地球表面转换到平面上的理论和方法称为地图投影。由于地球表面是一个不可展平的曲面,所以运用任何数学方法进行投影转换都会产生误差和变形,为按照不同的需求缩小误差,就产生了各种投影方式,如圆柱投影、圆锥投影、等角投影、等面积投影、切投影、割投影等。

img

墨卡托/Web墨卡托

一种正轴等角切圆柱投影。

  • 等角:保证对象形状不变以及方向位置正确。
  • 圆柱:保证纬线经线平行相互垂直且经线间隔相同。
  • 缺点:纬线间隔从赤道向两级逐渐增大,面积变形大。
  • Web墨卡托:Google首创,把地球模拟为球体而非椭球体,近似等角。

img

常见坐标系

WGS84坐标系
地球坐标系,国际上通用的坐标系。设备一般包含GPS芯片或者北斗芯片获取的经纬度为WGS84地理坐标系。

GCJ02坐标系
火星坐标系,是由中国国家测绘局制订的地理信息系统的坐标系统。由WGS84坐标系经加密后的坐标系。

BD09坐标系
百度地图使用坐标系,GCJ02坐标系经加密后的坐标系。

转换方法

国际通用的转换做法:
img
百度的做法:
img

地理坐标系和投影坐标系互转

需要2个依赖库,这里要注意org.geotool库的下载源。

<dependency><groupId>org.locationtech.jts</groupId><artifactId>jts-core</artifactId><version>1.18.1</version>
</dependency>
<dependency><groupId>org.geotools</groupId><artifactId>gt-epsg-hsql</artifactId><version>22-RC</version>
</dependency>
<dependency><groupId>org.geotools</groupId><artifactId>gt-main</artifactId><version>22-RC</version>
</dependency>
<repositories><repository><id>geotools</id><name>geotools</name><url>http://maven.icm.edu.pl/artifactory/repo/</url><releases><enabled>true</enabled></releases></repository>
</repositories>

转换代码示例

    // WGS84(一般项目中常用的是CSR:84和EPSG:4326)CoordinateReferenceSystem sourceCRS = CRS.decode("CRS:84");// Pseudo-Mercator(墨卡托投影)CoordinateReferenceSystem targetCRS = CRS.decode("EPSG:3857");MathTransform transform = CRS.findMathTransform(sourceCRS, targetCRS, false);Geometry geometryMercator = JTS.transform(geometry, transform);// 面积、周长System.out.println(geometryMercator.getArea());System.out.println(geometryMercator.getLength());

JTS包下的Geometry等类其实是代表的空间几何,它所提供的几何计算只是单纯的值计算,而我们提到的根据GIS经纬度等获取面积周长等其实是需要放到对应坐标系中才有意义。

EPSG:3857和EPSG:4326

墨卡托坐标 EPSG:3857 坐标系。投影坐标系,EPSG:3857 的数据一般是这种的。[12914838.35,4814529.9],看上去相对数值较大。不利于存储,比较占内存。

WGS-84:是国际标准,GPS坐标(Google Earth使用、或者GPS模块)
EPSG:4326 的数据一般是这种的。[22.37,114.05]。利于存储,可读性高

// 2437 GCJ-02:中国坐标偏移标准,Google Map、高德、腾讯使用

Java各坐标系之间的转换(高斯、WGS84经纬度、Web墨卡托、瓦片坐标)

另一种方式,之后研究

https://blog.csdn.net/u010410697/article/details/110003422

Geotools

Geotools是一个java类库,它提供了很多的标准类和方法来处理空间数据,同时这个类库是构建在OGC标准之上的,是OGC思想的一种实现。而OGC是国际标准,所以geotools将来必定会成为开源空间数据处理的主要工具,目前的大部分开源软件,如udig,geoserver等,对空间数据的处理都是由geotools来做支撑。而其他很多的web服务,命令行工具和桌面程序都可以由geotools来实现。

JTS

中文文档:https://max.book118.com/html/2019/0624/6154225215002041.shtm
工具包+相关文档下载:https://download.csdn.net/download/abu935009066/16208250

JTS(Java Topology Suite) Java拓扑套件,是Java的处理地理数据的API,它提供以下功能:

  1. 实现了OGC关于简单要素SQL查询规范定义的空间数据模型
  2. 一个完整的、一致的、基本的二维空间算法的实现,包括二元运算(例如touch和overlap)和空间分析方法(例如intersection和buffer)
  3. 一个显示的精确模型,用算法优雅的解决导致dimensional collapse(尺度坍塌–专业名词不知道对不对,暂时这样译)的情况。
  4. 健壮的实现了关键计算几何操作
  5. 提供著名文本格式的I/O接口
  6. JTS是完全100%由Java写的

JTS支持一套完整的二元谓词操作。二元谓词方法将两个几何图形作为参数,返回一个布尔值来表示几何图形是否有指定的空间关系。它支持的空间关系有:相等(equals)、分离(disjoint)、相交(intersect)、相接(touches)、交叉(crosses)、包含于(within)、包含(contains)、覆盖/覆盖于(overlaps)。同时,也支持一般的关系(relate)操作符。relate可以被用来确定维度扩展的九交模型(DE-9IM),它可以完全的描述两个几何图形的关系。

https://locationtech.github.io/jts/

https://github.com/locationtech/jts

vividsolutions和locationtech jts

maven仓库
img

看了下vividsolutions于2015年就停在更新了,好像在哪儿看过,jts由vividsolutions变为的locationtech,一个爹 应该是。选locationtech这个就完事了

创建几何对象

JTS提供了以下空间数据类型:

多数的空间数据模型都是遵从这个的。

img

private GeometryFactory geometryFactory = new GeometryFactory();

点-Point

ByCoordinate坐标

Coordinate coord = new Coordinate(109.013388, 32.715519);
Point point = geometryFactory.createPoint( coord );

ByWKT

WKTReader reader = new WKTReader( geometryFactory );
Point point = (Point) reader.read("POINT (109.013388 32.715519)");

多点-MultiPoint

WKTReader reader = new WKTReader( geometryFactory );
MultiPoint mpoint = (MultiPoint) reader.read("MULTIPOINT(109.013388 32.715519,119.32488 31.435678)");

线-LineString

Coordinate[] coords  = new Coordinate[] {new Coordinate(2, 2), new Coordinate(2, 2)};
LineString line = geometryFactory.createLineString(coords);
// wkt
WKTReader reader = new WKTReader( geometryFactory );
LineString line = (LineString) reader.read("LINESTRING(0 0, 2 0)");

多线-MultiLineString

Coordinate[] coords1  = new Coordinate[] {new Coordinate(2, 2), new Coordinate(2, 2)};
LineString line1 = geometryFactory.createLineString(coords1);
Coordinate[] coords2  = new Coordinate[] {new Coordinate(2, 2), new Coordinate(2, 2)};
LineString line2 = geometryFactory.createLineString(coords2);
LineString[] lineStrings = new LineString[2];
lineStrings[0]= line1;
lineStrings[1] = line2;
MultiLineString ms = geometryFactory.createMultiLineString(lineStrings);
// wkt
WKTReader reader = new WKTReader( geometryFactory );
MultiLineString line = (MultiLineString) reader.read("MULTILINESTRING((0 0, 2 0),(1 1,2 2))");

闭合线-LinearRing

LinearRing lr = new GeometryFactory().createLinearRing(new Coordinate[]{new Coordinate(0, 0), new Coordinate(0, 10), new Coordinate(10, 10), new Coordinate(10, 0), new Coordinate(0, 0)});

多边形-Polygon

WKTReader reader = new WKTReader( geometryFactory );
Polygon polygon = (Polygon) reader.read("POLYGON((20 10, 30 0, 40 10, 30 20, 20 10))");

多个多边形-MultiPolygon

WKTReader reader = new WKTReader( geometryFactory );
MultiPolygon mpolygon = (MultiPolygon) reader.read("MULTIPOLYGON(((40 10, 30 0, 40 10, 30 20, 40 10),(30 10, 30 0, 40 10, 30 20, 30 10)))");

几何集合列表-GeometryCollection

LineString line = createLine();
Polygon poly =  createPolygonByWKT();
Geometry g1 = geometryFactory.createGeometry(line);
Geometry g2 = geometryFactory.createGeometry(poly);
Geometry[] garray = new Geometry[]{g1,g2};
GeometryCollection gc = geometryFactory.createGeometryCollection(garray);

几何关系判断(返回值 boolean)

关系解释
相等(Equals):几何形状拓扑上相等。
不相交(Disjoint):几何形状没有共有的点。
相交(Intersects):几何形状至少有一个共有点(区别于脱节)
接触(Touches):几何形状有至少一个公共的边界点,但是没有内部点。
交叉(Crosses):几何形状共享一些但不是所有的内部点。
内含(Within):几何形状A的线都在几何形状B内部。
包含(Contains):几何形状B的线都在几何形状A内部(区别于内含)
重叠(Overlaps):几何形状共享一部分但不是所有的公共点,而且相交处有他们自己相同的区域。

举例相交,其他类似

  /*** 至少一个公共点(相交)* @return* @throws ParseException*/public boolean intersectsGeo() throws ParseException{WKTReader reader = new WKTReader( geometryFactory );LineString geometry1 = (LineString) reader.read("LINESTRING(0 0, 2 0, 5 0)");LineString geometry2 = (LineString) reader.read("LINESTRING(0 0, 0 2)");Geometry interPoint = geometry1.intersection(geometry2);//相交点System.out.println(interPoint.toText());//输出 POINT (0 0)return geometry1.intersects(geometry2);}

几何关系分析(返回值 几何对象)

JTS支持基本的空间分析方法。空间分析方法使用一个或两个几何图形作为参数,返回一个新构造的几何图形。

分析解释
缓冲区分析(Buffer)包含所有的点在一个指定距离内的多边形和多多边形
凸壳分析(ConvexHull)包含几何形体的所有点的最小凸壳多边形(外包多边形)
交叉分析(Intersection)A∩B 交叉操作就是多边形AB中所有共同点的集合
联合分析(Union)AUB AB的联合操作就是AB所有点的集合
差异分析(Difference)(A-A∩B) AB形状的差异分析就是A里有B里没有的所有点的集合
对称差异分析(SymDifference)(AUB-A∩B) AB形状的对称差异分析就是位于A中或者B中但不同时在AB中的所有点的集合

img

img

距离、长度、面积计算

  • 1.先把坐标系都转成墨卡托
  • 2.用jts计算距离
  • 3.由于转成墨卡托坐标系,结果比实际偏大,要乘以系数
  		// WGS84(一般项目中常用的是CRS:84和EPSG:4326)CoordinateReferenceSystem sourceCRS = CRS.decode("CRS:84");// Pseudo-Mercator(墨卡托投影)CoordinateReferenceSystem targetCRS = CRS.decode("EPSG:3857");MathTransform transform = CRS.findMathTransform(sourceCRS, targetCRS, false);GeometryFactory GeometryFactory = new GeometryFactory();Coordinate k96 = new Coordinate(117.41722, 31.975379);Coordinate k97 = new Coordinate(117.426387, 31.970712);Geometry line = JTS.transform(GeometryFactory.createLineString(new Coordinate[]{k96, k97}), transform);//double rate1 = Math.cos(Math.toRadians(k96.y)); 距离短的话乘以这个就行, 大概为: 0.8482973000510488double rate = Math.cos((Math.toRadians(k96.y) + Math.toRadians(k97.y)) / 2.000000);//距离长的话用这个System.out.println("rate: " + rate);// 面积、周长System.out.println(line.getArea());// 面积未验证是乘以 rate 还是其平方System.out.println(line.getLength() * rate);Coordinate tmp = new Coordinate(117.417145, 31.975465);Geometry point = JTS.transform(GeometryFactory.createPoint(tmp), transform);System.out.println(point.distance(line) * rate);

按照代码包把所有功能介绍下

img

图形可视化化WKT数据(好用的一比)

工具包+相关文档下载:https://download.csdn.net/download/abu935009066/16208250
偶然间发现可以使用jts中的工具可视化我们的WKT数据。
img

需要java环境

img

项目实战

几何到另一个几何最近的点

GeometryFactory gf = JTSFactoryFinder.getGeometryFactory(null);
WKTReader reader = new WKTReader(gf);
Geometry line2 = reader.read("LINESTRING(0 0, 10 0, 10 10, 20 10)");
Coordinate c = new Coordinate(5, 5);
PointPairDistance ppd = new PointPairDistance();
DistanceToPoint.computeDistance(line2, c, ppd);
System.out.println(ppd.getDistance());
for (Coordinate cc : ppd.getCoordinates()) {System.out.println(cc);
}

求几何的交点

// create ring: P1(0,0) - P2(0,10) - P3(10,10) - P4(0,10)
LinearRing lr = new GeometryFactory().createLinearRing(new Coordinate[]{new Coordinate(0,0), new Coordinate(0,10), new Coordinate(10,10), new Coordinate(10,0), new Coordinate(0,0)});
// create line: P5(5, -1) - P6(5, 11) -> crossing the ring vertically in the middle
LineString ls = new GeometryFactory().createLineString(new Coordinate[]{new Coordinate(5,-1), new Coordinate(5,11)});
// calculate intersection points
Geometry intersectionPoints = lr.intersection(ls);
// simple output of points
for(Coordinate c : intersectionPoints.getCoordinates()){System.out.println(c.toString());
}

利用缓冲画圆

创建一个包含在设定距离内的所有点的面或多面(想要圆,但是没有。。。):

geometry = point
Geometry buffer = geometry.buffer( 2.0 ); // note distance is in same units as geometry

img

根据起始点求一个线的子线

已知:起点、终点、道路
求解:其在道路上的子轨迹
img

        GeometryFactory GeometryFactory = new GeometryFactory();WKTReader reader = new WKTReader(GeometryFactory);Geometry geom = reader.read("LINESTRING(0 0, 10 0, 10 10, 20 10)");LocationIndexedLine lil = new LocationIndexedLine(geom);LinearLocation start = lil.indexOf(new Coordinate(8, 5));LinearLocation end = lil.indexOf(new Coordinate(17, 10));Geometry result = lil.extractLine(start, end);System.out.println(result.toText());
// 结果        
LINESTRING (10 5, 10 10, 17 10)

img

计算道路与起点之间指定距离之间的交点坐标

已知:道路、在道路的距离
求解:到起点坐标距离的点

    public static Coordinate lengthOnLineString2(Geometry roadLine, double length) {LocationIndexedLine locationIndexedLine = new LocationIndexedLine(roadLine);LinearLocation linearLocation = LengthLocationMap.getLocation(roadLine, length);Coordinate result = locationIndexedLine.extractPoint(linearLocation);return result;}

参考:

  • https://blog.csdn.net/yatsov/article/details/80215278
  • https://geotools.org/
  • http://locationtech.github.io/jts/javadoc/overview-summary.html
  • https://www.giserdqy.com/geoanalysis/29813/
  • http://docs.geotools.org/latest/userguide/welcome/architecture.html
  • https://docs.geotools.org/latest/userguide/library/jts/geometry.html
  • https://docs.geotools.org/latest/userguide/library/jts/snap.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/555196.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ecshop nginx php-fpm,ecshop在nginx下配置常见问题

我们前面讲述了nginx安装和配置&#xff0c;知道如何将ecshop建立在linux环境下的nginx上。但是为了让ecshop能更好的在nginx下跑出性能。我们必须对ecshop以及nginx的配置做出调整和改进&#xff0c;不然很容易浪费了nginx的性能。我们将结合一些实际情况&#xff0c;谈谈ecsh…

JTS学习笔记

简介 JTS由加拿大的VividSolutions公司开发&#xff0c;是一个用Java语言描述的几何拓扑套件&#xff0c;遵循OpenGIS的Simple Feature Specification&#xff0c;封装了2D几何类型和非常多的空间分析操作&#xff0c;而且包含了不少常见的计算几何算法实现。 JTS被广泛地应用…

matlab数学实验结课作业答案,matlab数学实验第一次答案

常用的高分子材料大致有哪几类&#xff1f;常用矿物硬度计为指甲和小刀&#xff0c;其中指甲的硬度为 ( )&#xff0c;小刀的硬度为( )。常用的自我增强的方式有六种。()常用的瓶插固定法有 。常用的静态网页制作软件有Dreamweaver、Access等。( )常用除草剂的类型有常见栽培…

填坑:Maven工程引用GeoTools依赖

这两天在做一个系统的后台&#xff0c;需要用到GeoTools做后端空间分析&#xff0c;记录一下自己遇到的问题。 项目通过Maven进行构建&#xff0c;参照文档Maven Quickstart添加GeoTools依赖和远程仓库地址。 <dependencies><dependency><groupId>org.geotoo…

php byte stringbuffer,重拾java基础(十三):String姐妹StringBuffer、StringBuilder总结

重拾java基础(十三)&#xff1a;String姐妹StringBuffer、StringBuilder总结一、StringBuffer类概述buffer&#xff1a;缓冲2. 字符串缓冲区&#xff0c;跟String非常相似&#xff0c;都是用来存字符串数据的3. String类和StringBuffer类中都有一个char数组&#xff0c;它就是缓…

php 页面开启错误提示,php开启与关闭错误提示

windows系统开关php错误提示如果不具备修改php.ini的权限&#xff0c;可以将如下代码加入php文件中&#xff1a;代码如下 复制代码ini_set("display_errors", "On");error_reporting(E_ALL | E_STRICT);当然&#xff0c;如果能够修改php.ini的话&#xff0…

Maven下载jar包时出错、Maven仓库中出现.lastUpdated结尾的文件问题及解决

创建一个新项目&#xff0c;下载依赖时&#xff0c;出现以下错误&#xff0c;在本地maven仓库中的远程镜像地址配置也正确的情况下&#xff0c;分析了以下问题&#xff1a; 在这里插入图片描述1.idea报依赖冲突的错误&#xff0c;打开Project Structure&#xff0c;如果发现相…

ga tsp matlab,遗传算法(GA)求解TSP问题MATLAB程序

本程序求解常见的组合优化问题TSP问题&#xff0c;如果仅仅是用一个程序去求解一个优化问题&#xff0c;显然这样的工作意义并不大。主要是因为求解的好坏往往是很难评价的&#xff0c;另外尤其对于遗传算法来说&#xff0c;遗传算法交叉变异方法不同&#xff0c;交叉率&#x…

墨卡托投影介绍

一、墨卡托投影 墨卡托投影&#xff0c;又称正轴等角圆柱投影&#xff0c;由荷兰地图学家墨卡托(G.Mercator)于1569年创拟。假设地球被套在一个圆柱中&#xff0c;赤道与圆柱相切&#xff0c;然后在地球中心放一盏灯&#xff0c;把球面上的图形投影到圆柱体上&#xff0c;再把…

disallow php,在robots.txt中Disallow: /abc和Disallow: /abc/的区别

站长&#xff1a;不就是多了条斜杠吗&#xff0c;能有多大不同&#xff1f;小编&#xff1a;很多新手站长搞不明白这其中的作用&#xff0c;其实作用区别很大的呦。Disallow: /abc表示禁止蜘蛛索引网站根目录下所有以abc开头的文件夹和文件举例&#xff1a;/abc.html/abcde.php…

Java double转decimal_Java中Double与BigDecimal的相互转换

今天写代码过程中&#xff0c;发现一个Double的变量通过new BigDecimal(Double d)转换为BigDecimal时&#xff0c;有效数字改变了&#xff0c;如下&#xff1a; public class BigDecimalTest {public static void main(String[] arg) {String s1 "123.45";Double d…

oracle数据库日期加一,日期和Oracle数据库

我想知道Oracle环境中的哪个参数导致这个&#xff1a;假设我在两台不同的服务器上有两个数据库。数据库中的数据相同。在sql developer下我写这个查询&#xff1a;select to_char(date_column, DD/MM/YYYY) from my_table;当我在sql developer中检查my_table时&#xff0c;日期…

JTS使用实践

文章目录JTS使用实践一、前言简介环境二、正文基础说明使用记录创建几何要素操作示例JTS使用实践 一、前言 简介 JTS Topology Suite&#xff08;Java Topology Suite&#xff09;是一个开源的Java软件库&#xff0c;它为欧几里得平面线性几何提供了一个对象模型以及一组基本…

matlab 信息融合,MSDF,matlab,多传感器信息融合

MSDF&#xff0c;matlab&#xff0c;多传感器信息融合关注次数&#xff1a; 164下载次数&#xff1a; 15文件大小&#xff1a; 7.52M下载需要积分&#xff1a; 1代码分类&#xff1a;开发平台&#xff1a; matlab上传会员&#xff1a; yhcpp下载代码预览代码Downma.com:专注MAT…

JTS基本概念和使用

简介 JTS是加拿大的 Vivid Solutions公司做的一套开放源码的 Java API。它提供了一套空间数据操作的核心算法。为在兼容OGC标准的空间对象模型中进行基础的几何操作提供2D空间谓词API。 操作 表示Geometry对象 Geometry类型介绍见另一篇文章&#xff1a;WKT WKB和GeoJSON pa…

sde oracle11g,Arcsde post oracle11g报错解决办法

环境&#xff1a;oracle11.2.0.3和oracle10.2.0.1&#xff0c;Arcsde9.3.1在oracle11.2.0.3中创建ab实例&#xff0c;然后使用Arcsde9.3.1 post oracle11.2.0.3创建配置sde&#xff0c;在post过程中报错&#xff0c;错误内容为[Thu Apr 04 10:24:55 2013] ERROR: Unable to loa…

GIS算法:可视化工具JTS TestBuilder

java、python、js都有可以引用的第三方包&#xff0c;实现GIS的空间算法。 java是jts&#xff0c;python是shapely&#xff0c;js是turf。 其中jts值得首先拥有&#xff0c;因为jts提供了一个界面工具JTS TestBuilder&#xff0c;可以在上面绘制图形&#xff0c;验证各种算法…

php aes 3des区别,AES和3DES之间的区别

Post Views:283AES与3DESAES(高级加密标准)和3DES(也称为Triple DES(数据加密标准))是当前数据加密中的两个标准。AES是使用替代置换网络的全新加密&#xff0c;而3DES只是对依靠平衡Feistel网络的旧DES加密的一种改编。基本上&#xff0c;3DES只是将DES应用于加密信息的 3次。…

wkt区域围栏

API文档 http://shengshifeiyang.gitee.io/geotools-learning/ /** * 判断以x,y为坐标的点point(x,y)是否在geometry表示的Polygon中 * param x * param y * param geometry wkt格式 POLYGON((0 0, 10 0, 10 10, 0 10,0 0)) * return */ public static boolean withinGeo(doub…

oracle监听生成trace,监听器控制程序lsnrctl跟踪trace file

Oracle监听器是一个独立的数据库组件&#xff0c;在整个体系中扮演非常重要的作用。即使在windows平台上&#xff0c;监听器listener也被实现成为一个独立的进程程序。在一些与网络相关的故障中&#xff0c;监听器相关故障占了很大部分。了解监听器的工作过程&#xff0c;分析每…