在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层

如图,我现在有一组经纬度点位Point,接下来我们将他装换为多边形Polygon格式

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第1张图片

使用QGIS => 图层 => 添加图层 => 添加分隔文本图层 => 打开这个csv点位文件

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第2张图片

打开后如左下图,csv文件中的四个点位都显示在地图中,我们现在要做的就是,如何在c#中使用代码,像右下图一样,把这四个点位连接起来。

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第3张图片

 操作之前我们需要安装一个nuget包 NetTopologySuite

NetTopologySuite是一个.NET库,它提供了一系列的类和方法来处理地理空间数据。这个库主要用于处理和操作地理空间数据,包括点、线、多边形等几何图形的创建、查询、分析和转换等操作。它实现了开放地理空间联盟(OGC)的简单特性访问规范,并提供了对地理空间数据库的支持。

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第4张图片

安装完成之后

  1. 创建一个长度为5的坐标数组coordinates,并初始化它。每个坐标都是一个Coordinate对象,包含经度和纬度两个属性。

  2. 使用这个坐标数组创建一个LinearRing对象。线性环是一个封闭的线性几何对象,它的首尾坐标点是相同的,这里的线性环就是多边形的边界。

  3. 使用这个线性环创建一个Polygon对象。多边形是一个封闭的二维几何对象,由一个外部线性环和零个或多个内部线性环(代表洞)组成。这里创建的多边形只有一个外部线性环,没有内部线性环。

在下面代码中,我直接将csv中的四个点位,放到数组中,但是可以看见我往数组中放的却是5组点位,这是因为在创建一个多边形或线性环时,需要确保形状是封闭的。也就是说,开始的点和结束的点必须是同一个点。在这个例子中,第一条坐标和第五条坐标是相同的,这样就形成了一个封闭的多边形。

using NetTopologySuite.Geometries;

class MyClass
{
    public static void Main(string[] args)
    {
        Coordinate[] coordinates = new Coordinate[5]
        {
            new Coordinate(119.0156902,32.08318989),
            new Coordinate(119.016566,32.08127968),
            new Coordinate(119.0150461,	32.0807794),
            new Coordinate(119.0141703,32.08268962),
            new Coordinate(119.0156902,32.08318989),
        };
        // 创建一个线性环
        LinearRing ring = new LinearRing(coordinates);

        //创建一个多边形
        Polygon polygon = new Polygon(ring);

        Console.WriteLine(polygon.ToString());
    }
}

运行程序后我们将一个Polygon对象打印在控制台

POLYGON ((119.0156902 32.08318989, 119.016566 32.08127968, 119.0150461 32.0807794, 119.0141703 32.08268962, 119.0156902 32.08318989))

将这条字符串像刚刚的point一样放到csv文件中

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第5张图片

然后一样的步骤使用QGIS打开,但是几何图形定义的时候要选择几何图形字段为polygon

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第6张图片

我们一开始的四个点位已经成为一个面了,接下来我们将它保存为shp

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第7张图片

在图层中右键这个面 => 导出 => 要素另存为 格式选择ESRI Shapefile

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第8张图片在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第9张图片

点击ok,目录下就有这个面的矢量文件了,点转面转矢量的工作就完成了

在c#中如何将多个点位(Point)转换为多边形(Polygon)并装换为shp图层_第10张图片

你可能感兴趣的:(c#,.netcore,空间计算)