GDAL的使用

  • 栅格位置(像素或者是行坐标)和地理参考坐标之间的转换可以通过仿射变换实现,仿射矩阵可以通过GDALDataset::GetGeoTransform()得到,依据下面的公式将像素/行坐标转换到地理参考空间:
    X g e o = G T ( 0 ) + X p i x e l . G T ( 1 ) + Y l i n e . G T ( 2 ) Y g e o = G T ( 3 ) + X p i x e l . G T ( 4 ) + Y l i n e . G T ( 5 ) X_{geo} = GT(0) + Xpixel.GT(1) + Yline.GT(2) \\ Y_{geo} = GT(3) + Xpixel.GT(4) + Yline.GT(5) Xgeo=GT(0)+Xpixel.GT(1)+Yline.GT(2)Ygeo=GT(3)+Xpixel.GT(4)+Yline.GT(5)
    其中像素坐标左上角为 ( 0 , 0 ) (0,0) (0,0) ( G T ( 0 ) , G T ( 3 ) ) (GT(0),GT(3)) (GT(0),GT(3))是栅格左上角坐标, G T ( 1 ) GT(1) GT(1)是像素宽度, G T ( 5 ) GT(5) GT(5)是像素的高度;
  • 可以通过地理控制点(GCP)来描述栅格数据集地理参考,关联了栅格位置和地理参考系统的一个或者多个位置,一个数据集会有一套控制点,控制点通过GDALDataset::GetGCPProjection()得到,每个控制点包含Char pszId(控制点标识符),Char pszInfo(通常是空串),double dfGCPPixel+double dfGCPLine(像素、线的位置是控制点在栅格的位置),double dfGCPX+double dfGCPY+double dfGCPZ(地理参考位置),本条和上一条都描述了栅格位置和地理参考坐标之间的关系;
  • 栅格波段GDALRasterBand
  • 颜色表:像素值被用作颜色表的下标;
try:
    import gdal
except:
    from osgeo import gdal	# gdal1.6
from osgeo.gdalconst import *	# 常用的常量

# 要读取数据之前需要载入数据驱动
# 注册所有数据驱动
gdal.AllRegister()
# 某一类型的数据驱动,按照数据格式加载
driver = gdal.GetDriverByName('GTiff')
driver.Register()

# 查看系统支持的数据格式,其中shortname就是上面GetDriverByName的参数,对于不同的gdal版本GetDriver的结果可能不同
drv_count = gdal.GetDriverCount()
for idx in range(drv_count):
		driver = gdal.GetDriver(idx)
		print( "%10s: %s" % (driver.ShortName, driver.LongName))

# 读取遥感影像
# 打开GeoTIF文件
dataset = gdal.Open("/gdata/geotiff_file.tif")
# python的dir()函数可以快速查看某对象可用的操作
dataset.GetDescription() 	# 获得栅格的描述信息
dataset.RasterCount 	# 获得栅格数据集的波段数
dataset.RasterXSize 	# 栅格数据的宽度(X方向上的像素个数)
dataset.RasterYSize 	# 栅格数据的高度(Y方向上的像素个数)
dataset.GetGeoTransform() 	# 栅格数据的六参数,这六个参数包括 左上角坐标 , 像元X、Y方向大小 , 旋转 等信息。 要注意, Y 方向的像元大小为负值
GetProjection() 	# 栅格数据的投影
dataset.GetMetadata()		# 获取元数据

# 获取数据集的信息
band = dataset.GetRasterBand(1)		# 获取第一个波段,下标从0开始
band.XSize, band.YSize, band.DataType	# 宽高和数据类型
# 数据类型对应
# 未知或未指定类型 gdalconst.GDT_Unknown 0
# 8位无符整型 gdalconst.GDT_Byte 1
# 16位无符整型 gdalconst.GDT_UInt16 2
# 16位整型 gdalconst.GDT_Int16 3
# 32位无符整型 gdalconst.GDT_UInt32 4
# 32位整型值 gdalconst.GDT_Int32 5
# 32位浮点型 gdalconst.GDT_Float32 6
# 64位浮点型 gdalconst.GDT_Float64 7
# 16位复数整型 gdalconst.GDT_CInt16 8
# 32位复数整型 gdalconst.GDT_CInt32 9
# 32位复数浮点型 gdalconst.GDT_CFloat32 10
# 64位复数浮点型 gdalconst.GDT_CFloat64 11
band.GetNoDataValue()		# 无意义填充值
band.GetMaximum()
band.GetMinimum()
band.ComputeRasterMinMax()

# 访问栅格数据集的数据
dataset.ReadRaster() 	# 读取图像数据(以二进制的形式)
dataset.ReadAsArray() 	# 读取图像数据(以数组的形式),返回的是numpy的array
# 参数
# xoff,yoff :指定想要读取的部分原点位置在整张图像中距离全图原点的位置(以像元为单位)
# xsize,ysize : 指定要读取部分图像的矩形的长和宽(以像元为单位)
# buf_xsize,buf_ysize :可以在读取出一部分图像后进行缩放。那么就用这两个参数来定义缩放后图像最终的宽和高, GDAL 将帮你缩放到这个大小
# buf_type :可以对读出的数据的类型进行转换(比如原图数据类型是short,你要把它们缩小成byte)
# band_list :适应多波段的情况。可以指定要读取的波段

# 查看图片信息
!gdalinfo /gdata/lu75i1.tif	
# 访问索引图像:所读的数据知识真实数据的索引,而不是灰度图像
dataset = gdal.Open('/gdata/lu75i1.tif')
band = dataset.GetRasterBand(1)
band.GetRasterColorInterpretation()		# 返回2,gdalconst.GCI_PaletteIndex,表示索引图
colormap = band.GetRasterColorTable()	# 获取颜色表
colormap.GetPaletteInterpretation()		# 获取颜色表的类型
colormap.GetCount()	# 颜色数量
for i in range(colormap.GetCount() - 10, colormap.GetCount()):
   print("%i:%s" % (i, colormap.GetColorEntry(i)))	# 获得颜色的四值元祖,例如rgb,cmyk
# 我们通过ReadRaster读出的数据值只是对应到这个表的一个索引而已。 
# 我们需要通过读出这些数据,并在真实数据表中找出真实数据, 重新组织成一个RGB表才能用来绘制。
# 如果不经过对应, 绘制出来的东西可能没有任何意义
# GTiff颜色表存储时是16位的,但是读取之后自动进行了处理变为0-255

# 创建影像
driver = gdal.GetDriverByName( 'GTiff' )
dst_filename = '/tmp/x_tmp.tif'
dst_ds = driver.Create( dst_filename, 512, 512, 1, gdal.GDT_Byte )
from osgeo import osr
dst_ds.SetGeoTransform( [ 444720, 30, 0, 3751320, 0, -30 ] )
srs = osr.SpatialReference()
srs.SetUTM( 11, 1 )
srs.SetWellKnownGeogCS( 'NAD27' )
dst_ds.SetProjection( srs.ExportToWkt() )
raster = numpy.zeros( (512, 512) )
dst_ds.GetRasterBand(1).WriteArray( raster )

ref:
https://www.osgeo.cn/pygis/gdal.html

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

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

相关文章

远动通讯屏,组成和功能介绍

远动通讯屏,组成和功能介绍 远动通讯屏是基于电网安全建设而投入的远方监控厂站信息、远方切除电网负荷的设备;主经是由远动装置、通讯管理机、交换机、GPS对时装置、数字通道防雷器、模拟通道防雷器、屏柜及附件等设备组成。变电站远动通讯系统是指对广…

安装oh-my-zsh(命令行工具)

文章目录 一、安装zsh、git、wget二、安装运行脚本1、curl/wget下载2、手动下载 三、切换主题1、编辑配置文件2、切换主题 四、安装插件1、zsh-syntax-highlighting(高亮语法错误)2、zsh-autosuggestions(自动补全) 五、更多优化配…

顺序表的实现(迈入数据结构的大门)(2)

目录 顺序表的头插(SLPushFront) 此时:我们有两个思路(数组移位) 顺序表的头删(学会思维的变换)(SLPopFront) 顺序表的尾插(SLPushBack) 有尾插就有尾删 既然头与尾部的插入与删除都有,那必然少不了指定位置的插入删除 查找…

汽车之家,如何在“以旧换新”浪潮中大展拳脚?

北京车展刚刚落幕,两重利好正主导汽车市场持续升温:新能源渗透率首破50%,以及以旧换新详细政策进入落地期。 图源:中国政府网 在政策的有力指引下,汽车产业链的各个环节正经历着一场深刻的“连锁反应”。在以旧换新的…

\boldsymbol无法使用

检查是否导入了 unicode-math 宏包、 没有加粗效果 正常加粗了 2024-5-9-15点35分

(八)JSP教程——application对象

application对象是一个比较重要的对象,服务器在启动后就会产生这个application对象,所有连接到服务器的客户端application对象都是相同的,所有的客户端共享这个内置的application对象,直到服务器关闭为止。 可以使用application对…

【SpringBoot记录】自动配置原理(1):依赖管理

前言 我们都知道SpringBoot能快速创建Spring应用,其核心优势就在于自动配置功能,它通过一系列的约定和内置的配置来减少开发者手动配置的工作。下面通过最简单的案例分析SpringBoot的功能特性,了解自动配置原理。 SpringBoot简单案例 根据S…

Linux下的SPI通信

SPI通信 一. 1.SPI简介: SPI 是一种高速,全双工,同步串行总线。 SPI 有主从俩种模式通常由一个主设备和一个或者多个从设备组从。SPI不支持多主机。 SPI通信至少需要四根线,分别是 MISO(主设备数据输入,从设备输出),MOSI (主设数据输出从设备输入),SCLK(时钟信号),CS/SS…

leetcode尊享面试100题(549二叉树最长连续序列||,python)

题目不长,就是分析时间太久了。 思路使用dfs深度遍历,先想好这个函数返回什么,题目给出路径可以是子-父-子的路径,那么1-2-3可以,3-2-1也可以,那么考虑dfs返回两个值,对于当前节点node来说&…

BI赋能金融新质生产力,16家金融机构智能BI创新实践分享

2024年政府工作报告强调,要“大力发展科技金融、绿色金融、普惠金融、养老金融、数字金融”,同时“大力推进现代化产业体系建设,加快发展新质生产力”。对于金融行业而言,培育新质生产力是高质量发展的关键着力点。金融机构可以通…

vue项目启动后页面显示‘Cannot GET /’

1、npm run dev命令启动项目的时候没有报错,页面打开却提示 Cannot GET / 2.这个时候只需要找到config文件夹下面的index.js文件。把assetsPublicPath字符串的:‘./’修改成 ‘/’就行了。修改完之后记得关闭项目,然后重新启动。不然不会生效…

度小满——征信报告图建模

目录 背景介绍 发展趋势 技术演进 图在金融风控领域中的演进 度小满图机器学习技术体系 案例 征信报告介绍 征信报告图建模

postman接口测试中文汉化教程

想必同学们对于接口测试工具postman的使用并不陌生,以及最近大为流行的国产工具apifox。对于使用过的同学来说,两者区别以及优缺点很容易别展示出来,postman相比apifox来说更加轻量,但是apifox更加符合国人的使用习惯....中国人给…

Nest 快速上手 —— (三)中间件 / 异常过滤器

一、 中间件(Middleware) 1.特点 中间件是一个在路由处理程序之前被调用的函数。中间件函数可以访问请求和响应对象,以及应用程序请求-响应周期中的next()中间件函数。下一个中间件函数通常由一个名为next的变量表示。 中间件函数可以执行以…

车载测试系列:车载蓝牙测试(三)

HFP测试内容与测试方法 2.3 接听来电:测试手机来电时,能否从车载蓝牙设备和手机侧正常接听】拒接、通话是否正常。 1、预置条件:待测手机与车载车载设备处于连接状态 2、测试步骤: 1)用辅助测试机拨打待测手机&…

BetterMouse for Mac激活版:鼠标增强软件

BetterMouse for Mac是一款鼠标增强软件,旨在取代笨重的、侵入性的和耗费资源的鼠标驱动程序,如罗技选项。它功能丰富,重量轻,效率优化,而且完全隐私安全,试图满足你在MacOS上使用第三方鼠标的所有需求。 B…

新火种AI|AI让大家都变“土”了!

作者:一号 编辑:美美 AI不仅要把人变“土”,还要把人变多样。 这个世界,终究是变“土”了。 今年五一假期,一个名为“Remini”的AI修图APP火遍了全网。注意,是Remini,而不是Redmi&#xff0…

MySQL-集群1

一、为什么要用mysql集群?: mysql单体架构在企业中很少用,原因:①会形成单点故障,没有高可用的效果;②mysql本身是一个I/O能力比较差,并发能力比较差的应用服务,在较高规模的网络I/…

部署JVS服务出现上传文件不可用,问题原因排查。

事情的起因是这样的,部门经理让我部署一下JVS资源共享框架,项目的地址是在这里 项目资源地址 各位小伙伴们做好了,我要开始发车了,全新的“裂开之旅” 简单展示一下如何部署JVS文档 直达链接 撕裂要开始了 本来服务启动的好好…

【计算机毕业设计】基于SSM++jsp的蜀都天香酒楼网站【源码+lw+部署文档+讲解】

目录 摘要 Abstract 目 录 1绪论 1.1研究背景与意义 1.2国内外研究现状 1.3研究内容 1.4论文结构 2相关技术介绍 2.1 B/S模式 2.2 MyEclipse开发环境 2.3 MySQL数据库 2.4 Java语言 2.5 JSP技术 2.6 Tomcat服务器 3系统分析 3.1需求分析 3.2可行性分析 3.2.1经济可行性 3.2.2技…
最新文章