繁体   English   中英

如何使用 NetTopologySuite 以米为单位获取两点几何的距离?

[英]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;
}

我需要以米为单位计算距离。

您可以使用毕达哥拉斯定理来计算距离。

以下是步骤:

  1. 获取增量
    • double int deltaX = Math.Abs​​(point1.X - point2.X);
    • double int deltaY = Math.Abs​​(point1.Y - point2.Y);
  2. 毕达哥拉斯公式
    • 双倍距离 = Math.Sqrt((deltaX * deltaX) + (deltaY * deltaY));

如果你想计算一个 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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM