NetTopologySuite将坐标转换为另一个坐标系

时间:2017-07-11 13:06:05

标签: xamarin nettopologysuite

我正在尝试使用NetTopologySuite将我的坐标转换为不同的坐标系。但我无法让它发挥作用。我的初始转换是从WGS84到Lambert72。

我在stackoverflow上的某个地方发现了这个示例,但我无法让它工作:

public static double CalculateDistance(this MvxCoordinates baseLocation, double targetLat, double targetLon)
    {
        CoordinateSystemFactory csFact = new CoordinateSystemFactory();
        CoordinateTransformationFactory ctFact = new CoordinateTransformationFactory();

        ICoordinateSystem utm35ETRS = Coo.CreateFromWkt(
            "PROJCS[\"ETRS89 / ETRS-TM35\",GEOGCS[\"ETRS89\",DATUM[\"D_ETRS_1989\",SPHEROID[\"GRS_1980\",6378137,298.257222101]],PRIMEM[\"Greenwich\",0],UNIT[\"Degree\",0.017453292519943295]],PROJECTION[\"Transverse_Mercator\"],PARAMETER[\"latitude_of_origin\",0],PARAMETER[\"central_meridian\",27],PARAMETER[\"scale_factor\",0.9996],PARAMETER[\"false_easting\",500000],PARAMETER[\"false_northing\",0],UNIT[\"Meter\",1]]");

        IProjectedCoordinateSystem utm33 = ProjectedCoordinateSystem.WGS84_UTM(33, true);

        ICoordinateTransformation trans = ctFact.CreateFromCoordinateSystems(utm35ETRS, utm33);

        Coordinate[] points = new Coordinate[]
        {
            new Coordinate(290586.087, 6714000), new Coordinate(290586.392, 6713996.224),
            new Coordinate(290590.133, 6713973.772), new Coordinate(290594.111, 6713957.416),
            new Coordinate(290596.615, 6713943.567), new Coordinate(290596.701, 6713939.485)
        };

        //Coordinate[] tpoints = trans.MathTransform.TransformList(points).ToArray();
        //for (int i = 0; i < points.Length; i++)
        //    Assert.That(tpoints[i].Equals(trans.MathTransform.Transform(points[i])));
    }

此代码的一大问题是它使用ProjNET4GeoAPI,这与Xamarin核心项目不兼容

1 个答案:

答案 0 :(得分:1)

ProjNet4GeoAPI的最新预发布现在支持.NET Standard 1.0和.NET Standard 2.0目标。