我添加了一个检查,以确定多边形坐标的顺序是否错误,如果验证了条件,我想要修复它,但我得到的Reverse()函数已被弃用:
List<Coordinate> polygonCoords = new List<Coordinate>();
foreach(LatLngDto latlng in latlngs.LatLngs)
{
Coordinate vertex = new Coordinate(latlng.Lng, latlng.Lat);
polygonCoords.Add(vertex);
}
polygonCoords.Add(new Coordinate(latlngs.LatLngs[0].Lng, latlngs.LatLngs[0].Lat));
var geometryFactory = NtsGeometryServices.Instance.CreateGeometryFactory(srid: 4326);
var customShape = geometryFactory.CreatePolygon(polygonCoords.ToArray());
if (!customShape.Shell.IsCCW)
{
customShape = (Polygon)customShape.Reverse();
}
List<int> gridCellCodes = (from gc in grid5KmCellRepo.GetAll()
where gc.Grid5KmCellCoords.Intersects(customShape)
select gc.Grid5KmCellId).ToList();我应该使用什么?
我没有找到任何关于NetTopologySuite的相关文档,方法仍然在他们的文档中:https://nettopologysuite.github.io/NetTopologySuite/api/NetTopologySuite.Geometries.Geometry.html#NetTopologySuite_Geometries_Geometry_Reverse
发布于 2021-02-03 17:10:16
重载Polygon.Reverse()已过时,基本实现Geometry.Reverse()未过时。
customShape = (Polygon)(((Geometry)customShape).Reverse());应该会让Obsolete警告消失。
https://stackoverflow.com/questions/66018928
复制相似问题