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


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

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

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

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

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

    👻安装完成之后

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

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

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

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

    1. using NetTopologySuite.Geometries;
    2. class MyClass
    3. {
    4. public static void Main(string[] args)
    5. {
    6. Coordinate[] coordinates = new Coordinate[5]
    7. {
    8. new Coordinate(119.0156902,32.08318989),
    9. new Coordinate(119.016566,32.08127968),
    10. new Coordinate(119.0150461, 32.0807794),
    11. new Coordinate(119.0141703,32.08268962),
    12. new Coordinate(119.0156902,32.08318989),
    13. };
    14. // 创建一个线性环
    15. LinearRing ring = new LinearRing(coordinates);
    16. //创建一个多边形
    17. Polygon polygon = new Polygon(ring);
    18. Console.WriteLine(polygon.ToString());
    19. }
    20. }

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

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

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

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

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

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

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

  • 相关阅读:
    JMeter基础 —— 使用Badboy录制JMeter脚本!
    RTSP协议学习
    辅助知识-第1 章 项目立项管理
    java代码编写,抓取贝壳网前10条数据
    【第7篇】AI语音交互原理介绍
    最新支付宝蚂蚁森林自动偷能量,解放双手
    fastjson漏洞批量检测工具
    Autox.js和Auto.js4.1.1手机编辑器不好用我自己写了一个编辑器
    vue3 区别于 vue2 的“与众不同”
    如何备份VMware虚拟机
  • 原文地址:https://blog.csdn.net/weixin_65243968/article/details/134472832