[英]How to get the distance of two point geometry in meters using NetTopologySuite?
如何使用 NetTopologySuite 以米为单位获取两点几何的距离。
我使用了 Distance() 函数,但我得到了一些值,但我无法识别这些值的单位。 对于 ac# 应用程序,忽略 20 米的容差值可以忽略。
using NetTopologySuite.Geometries;
using GeoAPI.Geometries;
private static double findistance()
{
var geomFactory = new GeometryFactory(new PrecisionModel(), 4326);
IGeometry geometry1 = geomFactory.CreatePoint(new Coordinate(12.977299, 77.571075));
IGeometry geometry2 = geomFactory.CreatePoint(new Coordinate(12.977277, 77.571258));
var distance = geometry1.Distance(geometry2);
return distance;
}
我需要以米为单位计算距离。
您可以使用毕达哥拉斯定理来计算距离。
以下是步骤:
如果你想计算一个 3D 点,除了计算 DeltaZ 然后公式是距离 = X^2 + Y^2 + Z^2 之外,它是相同的步骤
每个文档,SRID 4326 代表下面的定义
GEOGCS["WGS 84",
DATUM["WGS_1984",
SPHEROID["WGS 84",6378137,298.257223563,AUTHORITY["EPSG","7030"]],
AUTHORITY["EPSG","6326"]],
PRIMEM["Greenwich",0,AUTHORITY["EPSG","8901"]],
UNIT["degree",0.01745329251994328,AUTHORITY["EPSG","9122"]],
AUTHORITY["EPSG","4326"]]
UNIT["degree"...
告诉我们您得到的结果以度为单位。 如果我们将这些点转换为投影坐标系,我们可以以米为单位计算距离。 ProjNET4GeoAPI
包可以为我们做到这一点。
private static double findDistance()
{
CoordinateTransformationFactory ctfac = new CoordinateTransformationFactory();
var from = GeographicCoordinateSystem.WGS84;
var to = ProjectedCoordinateSystem.WebMercator;
var trans = ctfac.CreateFromCoordinateSystems(from, to);
var mathTransform = trans.MathTransform;
var p1Coordinate = new GeoAPI.Geometries.Coordinate(12.977299, 77.571075);
var p2Coordinate = new GeoAPI.Geometries.Coordinate(12.977277, 77.571258);
p1Coordinate = mathTransform.Transform(p1Coordinate);
p2Coordinate = mathTransform.Transform(p2Coordinate);
return p1Coordinate.Distance(p2Coordinate);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.