GDAL+C#实现矢量多边形转栅格

1. 开发环境测试

参考C#配置GDAL环境,确保GDAL能使用,步骤简述如下:

  1. 创建.NET Framework 4.7.2的控制台应用

注意:
项目路径中不要有中文,否则可能报错:can not find proj.db

  1. 在NuGet中安装GDAL 3.9.1和GDAL.Native 3.9.1
  2. 测试代码(读取一张影像的长、宽、波段数、坐标系)
using OSGeo.GDAL;
using System;

namespace TestGDAL
{
    internal class Program
    {
        static void Main(string[] args)
        {
            Configure();
            Test();
            Console.ReadLine();
        }
        public static void Configure()
        {
            GdalConfiguration.ConfigureGdal();
            GdalConfiguration.ConfigureOgr();
            Gdal.AllRegister();
        }
        public static void Test()
        {
            Dataset ds = Gdal.Open(@"./测试.tif", Access.GA_ReadOnly);
            int rasterX = ds.RasterXSize;//影像宽度
            int rasterY = ds.RasterYSize;//影像高度
            int bandCount = ds.RasterCount;//波段数

            double[] tmpD = new double[6];
            ds.GetGeoTransform(tmpD); //影像坐标变换参数

            //影像坐标系信息(WKT格式字符串)
            string proj = ds.GetProjection();

            //用一个消息弹窗把信息显示出来
            Console.WriteLine($"宽度={rasterX},高度={rasterY},波段数={bandCount}");
            Console.WriteLine($"坐标系={proj}");
        }
    }
}

2. 多边形转栅格(按包围盒区域)

参考:C#调用GDAL实现矢量转栅格

  1. 用ArcMap创建一个shp面数据,用于后续输入。
    基于投影坐标系WGS_1984_UTM_Zone_50N,绘制了三个面,并添加属性字段Code,该字段将作为栅格数据的值。
    在这里插入图片描述
  2. 示例代码
using OSGeo.GDAL;
using OSGeo.OGR;
using System;
using OSGeo.OSR;
using Driver = OSGeo.GDAL.Driver;

namespace TestGDAL
{
    public class Test2
    {
        static string shpPath = @"./polygon.shp";
        public static void Run()
        {
            //初始化GDAL和OGR
            GdalConfiguration.ConfigureGdal();
            Gdal.AllRegister();
            Ogr.RegisterAll();

            // 获取矢量图层
            DataSource vectorDS = Ogr.Open(shpPath, 0);
            Layer vectorLayer = vectorDS.GetLayerByIndex(0);

            //设置栅格化参数,按1000行1000列来栅格化
            Envelope extent = new Envelope();
            vectorLayer.GetExtent(extent, 0);
            double xMin = extent.MinX;
            double xMax = extent.MaxX;
            double yMin = extent.MinY;
            double yMax = extent.MaxY;
            int xSize = 1000;
            int ySize = 1000;
            double xRes = (xMax - xMin) / xSize;
            double yRes = (yMax - yMin) / ySize;

            Console.WriteLine("Extent: " + extent.MaxX + " " + extent.MinX + " " + extent.MaxY + " " + extent.MinY);
            Console.WriteLine("X resolution: " + xRes);
            Console.WriteLine("Y resolution: " + yRes);

            // 创建栅格化输出文件
            var time = DateTime.Now.ToString("yy-MM-dd HH-mm-ss");
            string rasterFile = $"./output[{time}].tif";
            Driver rasterDriver = Gdal.GetDriverByName("GTiff");
            Dataset rasterDS = rasterDriver.Create(rasterFile, xSize, ySize, 1, DataType.GDT_Float32, null);

            // 设置栅格化文件参考系
            SpatialReference rasterSRS = vectorLayer.GetSpatialRef();
            rasterSRS.ExportToWkt(out string wkt, null);
            rasterDS.SetProjection(wkt);
            rasterDS.SetGeoTransform(new double[] { xMin, xRes, 0, yMax, 0, -yRes });
            Console.WriteLine("Projection:\n " + wkt);

            //设置属性字段为Code
            string[] rasterizeOptions = new string[] { "ATTRIBUTE=" + "Code" };
            
            //执行栅格化
            Gdal.RasterizeLayer(rasterDS, 1, new int[] { 1 }, vectorLayer, IntPtr.Zero, IntPtr.Zero, 1, new double[] { 1 }, rasterizeOptions, null, null);

            //将结果输出并关闭文件
            rasterDS.FlushCache();
            rasterDS.Dispose();
            vectorDS.Dispose();
        }
    }
}
  1. 栅格化效果图

在这里插入图片描述
在这里插入图片描述

3. 多边形转栅格(只保留多边形区域内的栅格)

在前面基础上,如果只想保留多边形内的栅格,也就是想要下面的效果:

在这里插入图片描述
基于上面的测试数据,则可以通过调整栅格化参数来实现:

//执行栅格化
rasterDS.GetRasterBand(1).SetNoDataValue(0);//0值表示没有值
Gdal.RasterizeLayer(rasterDS, 1, new int[] { 1 }, vectorLayer, 
    IntPtr.Zero, IntPtr.Zero, 0, new double[] { 0 }, rasterizeOptions, null, null);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/894752.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

达梦数据库性能优化

1、SQL执行计划 拿到一条SQL的时候,首先要下达梦手册中提出的有效SQL规范,及是否命中了特殊OR子句的不规范,是否用了复杂的正则表达式,避免重复很高的索引,UINON ALL 是否可以替换UNION操作等,某些场景INSTR函数导致的…

ParallelsDesktop20最新版本虚拟机 一键切换系统 游戏娱乐两不误

让工作生活更高效:Parallels Desktop 20最新版本虚拟机的神奇之处 大家好!👋 今天我要跟大家安利一款让我工作效率飞升的神器——Parallels Desktop 20最新版本虚拟机。作为一个日常需要在不同操作系统间来回穿梭的人,这款软件简直…

【升华】python基础包NumPy学习

NumPy是使用Python进行科学计算的基础软件包。除其他外,它包括: 功能强大的N维数组对象。精密广播功能函数。集成 C/C和Fortran 代码的工具。强大的线性代数、傅立叶变换和随机数功能。 # 1、安装包 $ pip install numpy# 2、进入python的交互式界面 $…

从零开始学PHP之helloworld

前言 每一门编程语言的第一个程序就是输出hell world(别杠,杠就是你对) 开始 上一篇讲完了开发环境的安装,这次讲编辑器的安装,顺带完成上一篇的作业(输出hello world) 安装PHPstorm 我用的…

前端布局与响应式设计综合指南(末)

​🌈个人主页:前端青山 🔥系列专栏:Css篇 🔖人终将被年少不可得之物困其一生 依旧青山,本期给大家带来Css篇专栏内容:前端布局与响应式设计综合指南(末) 目录 61、为什么要初始化CSS样式 62、CSS3 有哪些新特性 63、…

【python】NumPy(三):文件读写

目录 ​前言 NumPy 常见IO函数 save()和load() savez() loadtxt()和savetxt() 练习 前言 在数据分析中,我们经常需要从文件中读取数据或者将数据写入文件,常见的文件格式有:文本文件txt、CSV格式文件(用逗号分隔&#xff…

vue-router钩子中调用ElMessage等样式出错

升级 vue3.5 时遇到奇怪的问题, 页面点击离开没反应 经过排查, 是以下几点相互作用导致此问题 vue 有应用上下文的概念, 例如 runWithContext API,vue-router 在调用钩子时会获取 vue 的应用上下文element-plus 在唤起弹窗时会从 parent 或 应用上下文上拿到 config 信息eleme…

大数据环境 hbase+ phoenix idea

1、选择jdk 2、添加驱动 3、添加数据源

【精选】基于javaweb的流浪动物领养系统(源码+定制+开发)

博主介绍: ✌我是阿龙,一名专注于Java技术领域的程序员,全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师,我在计算机毕业设计开发方面积累了丰富的经验。同时,我也是掘金、华为云、阿里云、InfoQ等平台…

《重置MobaXterm密码并连接Linux虚拟机的完整操作指南》

目录 引言 一、双击MobaXterm_Personal_24.2进入,但是忘记密码。 那么接下来请跟着我操作。 二、点击此链接,重设密码。 三、下载完成后,现在把这个exe文件解压。注意解压要与MobaXterm_Personal_24.2.exe在同一目录下哦,不然…

从零入门AI篡改图片检测(金融场景)#Datawhale十月组队学习

1.大赛背景 在全球人工智能发展和治理广受关注的大趋势下,由中国图象图形学学会、蚂蚁集团、云安全联盟CSA大中华区主办,广泛联合学界、机构共同组织发起全球AI攻防挑战赛。本次比赛包含攻防两大赛道,分别聚焦大模型自身安全和大模型生成内容…

pc轨迹回放制作

亲爱的小伙伴,在您浏览之前,烦请关注一下,在此深表感谢! 课程主题:pc轨迹回放制作 主要内容:制作车辆轨迹操作页,包括查询条件、动态轨迹回放、车辆轨迹详情表单等 应用场景:车辆…

sqli-labs less-25a

Sqli-labs less-25a 判断注入类型,列数及注入点 构造 http://192.168.140.130/sq/Less-25a/?id1 回显正常 http://192.168.140.130/sq/Less-25a/?id1’ 报错 构造 http://192.168.140.130/sq/Less-25a/?id1 and 11 回显正常 http://192.168.140.130/sq/Less-25a…

RabbitMQ 入门(三)SpringAMQP五种消息类型(Basic Queue)

一、Spring AMQP 简介 SpringAMQP是基于RabbitMQ封装的一套模板,并且还利用SpringBoot对其实现了自动装配,使用起来非常方便。 SpringAmqp的官方地址:https://spring.io/projects/spring-amqp SpringAMQP提供了三个功能: - 自动…

唐布拉不是家,而我途径它(一)

唐布拉不是家,而我途径它 旅途是一本书,风吹哪页读哪页,笔搁哪句写哪句。 最后一站在唐布拉的尼勒克,晚上11点才到,车停在门口,打开车门就看到这句话: 希望你快乐 今天 明天 天天刚下完雨&am…

2024年诺贝尔物理学奖揭晓:AI背后的“造梦者”是谁?

想象一下,你早上醒来,智能音箱为你播放天气和新闻,中午你用手机刷视频,精准的推荐内容简直和你心有灵犀,晚上回家,自动驾驶汽车安全地把你送回家。这一切看似理所当然,背后却有一双无形的手推动…

双向链表常见接口实现

一 . 链表的分类 链表的结构非常多样,以下情况组合起来就有8种( 2 * 2 * 2 ) 链表结构 : 1.1 单向/双向 1 . 单向 : 只能往一个方向遍历 (仅有一个指针 --> 指向下一个结点的地址), 如下图 : 只能从d1找到d2 , d2 找不到d1 2 . 双向 : 能从两个方向遍历 ( 有指向下一个结点…

Leetcode 841. 钥匙和房间

1.题目基本信息 1.1.题目描述 有 n 个房间,房间按从 0 到 n – 1 编号。最初,除 0 号房间外的其余所有房间都被锁住。你的目标是进入所有的房间。然而,你不能在没有获得钥匙的时候进入锁住的房间。 当你进入一个房间,你可能会在…

深度解析服务级别协议(SLA):保障业务稳定性的关键承诺

前言: 在当今数字化时代,企业的业务连续性和稳定性至关重要。服务级别协议(SLA)作为服务提供商与客户之间的正式承诺,是确保服务质量、可用性、责任的重要工具。SLA不仅定义了服务提供商应达到的服务指标,还…

华为ENSP Truck命令指南:从入门到精通的全方位解析 引言

博客标题:华为ENSP Truck命令指南:从入门到精通的全方位解析 引言 在网络工程的世界里,华为ENSP(Enterprise Network Simulation Platform)作为一款强大的网络模拟工具,为我们提供了在虚拟环境中实践和学习…