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. 测试代码(读取一张影像的长、宽、波段数、坐标系)
csharp 复制代码
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. 示例代码
csharp 复制代码
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. 多边形转栅格(只保留多边形区域内的栅格)

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

基于上面的测试数据,则可以通过调整栅格化参数来实现:

csharp 复制代码
//执行栅格化
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);
相关推荐
almighty275 小时前
C# 阿里云 OSS 图片上传步骤及浏览器查看方法
c#·图片上传·c# 阿里云 oss·阿里云 oss
Python大数据分析@18 小时前
Python 语言有什么奇技淫巧吗?
开发语言·python·c#
Envyᥫᩣ18 小时前
C#中的设计模式:构建更加优雅的代码
开发语言·c#
CHHC188021 小时前
C#工作流示例(WorkflowCore)
c#·工作流
oscar9991 天前
少儿编程C++快速教程之——2. 字符串处理
开发语言·c++·c#·字符串·少儿
时光追逐者1 天前
.NET 使用 CsvHelper 快速读取和写入 CSV 文件
c#·.net·.net core·csv
INSO1 天前
查漏补缺之Polly
c#
c#上位机1 天前
wpf中资源的使用
c#·wpf
GISBox1 天前
GISBox矢量服务使用指南:从数据导入到服务发布
react.js·json·gis
Zzz_睡不醒1 天前
JS(正则表达式)
javascript·正则表达式·c#