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

news/2024/5/19 21:08:27 标签: c#, .netcore, 空间计算

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

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

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

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

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

👻安装完成之后

  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文件中

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

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

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

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


http://www.niftyadmin.cn/n/5191786.html

相关文章

HP惠普光影精灵7笔记本Victus by HP 16.1英寸游戏本16-d0000原装出厂Windows11.21H2预装OEM系统

下载链接:https://pan.baidu.com/s/1LGNeQR1AF1XBJb5kfZca5w?pwdhwk6 提取码:hwk6 可适用的型号: 16-d0111tx,16-d0112tx,16-d0125tx,16-d0127tx,16-d0128tx,16-d0129tx&#…

check-update] get changed dataId error, code: 403

前言 新部署的项目 启动后 控制台一直报错 简要内容 [check-update] get changed dataId error, code: 403 具体内容如下 2023-11-17 11:34:44.015 ERROR [com.alibaba.nacos.client.Worker.longPolling.fixed-10.226.4.98_8848-cfbc33a4-3911-4fab-9c5d-bfb11ef20654] [,,,]…

【 OpenGauss源码学习 —— 列存储(update)】

列存储(Insert) 概述相关函数CStoreUpdate::ExecUpdate 函数JunkFilter 结构体CStoreInsert::BatchInsert 函数bulkload_rows::append_one_vector 函数bulkload_rows::append_in_column_orientation我函数 ExecVecUpdate 函数CStoreUpdate::EndUpdate 函…

python转义大括号的作用

# 1.如何输出下面这个话 {Python}中使用{}表示大括号 # 2.python语法 print("{{Python}}中使用{{}}表示大括号") # 输出:{Python}中使用{}表示大括号 在上述代码中,我们对大括号进行了转义,输出的结果为"{Python}中使用{}表…

mysql表字段数据类型对应java类型

下面是常见的 MySQL 数据表字段数据类型以及对应的 Java 类型列表: 整数类型:TINYINT -> byte 或 BooleanSMALLINT -> shortMEDIUMINT -> intINT -> intBIGINT -> long浮点数类型:FLOAT -> floatDOUBLE -> doubleDECIM…

git基本操作(配图超详细讲解)

个人主页:Lei宝啊 愿所有美好如期而遇 目录 创建git本地仓库 配置仓库 认识工作区,暂存区,版本库 修改文件 版本回退 撤销修改 删除文件 创建git本地仓库 要提前说的是,仓库是进⾏版本控制的⼀个⽂件⽬录。我们要想对⽂…

【广州华锐互动】自然灾害科普3D体验展厅:培养安全意识,共创美好未来

在人类历史的进程中,灾难始终是我们不可避免的挑战。地震、洪水、火灾等自然灾害无情地摧毁我们的家园,带走我们的亲人。然而,随着科技的进步,我们已经有了更多的手段来预防和应对这些灾难。在这个背景下,自然灾害科普…

uview使用u-action-sheet添加滚动条

0 效果 1 修改uview源码 node_modules/uview-ui/u-action-sheet/u-action-sheet.vue