找回密码
 会员注册
查看: 30|回复: 0

python--gdaltif图像坐标投影坐标经纬度转换(理清i和j的顺序)

[复制链接]

2万

主题

0

回帖

7万

积分

超级版主

积分
73258
发表于 2024-9-4 14:28:34 | 显示全部楼层 |阅读模式
【太长不看版】tif是一张具有地理编码信息的图像。gdal能读出里面的基本地理编码信息,根据这6个基本的信息,可以推导出其他需要的地理信息。trans(0)左上像素左上角的x坐标。trans(1)w-e像素分辨率/像素宽度。trans(2)行旋转(通常为零)。trans(3)左上像素左上角的y坐标。trans(4)列旋转(通常为零)。trans(5)n-s像素分辨率/像素高度(北上图像为负值)【详细举例版】nXSize=dataset.RasterXSize#列数nYSize=dataset.RasterYSize#行数img_lons=np.zeros((nYSize,nXSize))img_lats=np.zeros((nYSize,nXSize))trans=dataset.GetGeoTransform()prosrs=osr.SpatialReference()prosrs.ImportFromWkt(dataset.GetProjection())geosrs=prosrs.CloneGeogCS()。ct=osr.CoordinateTransformation(prosrs,geosrs)forcolinrange(nXSize):forrowinrange(nYSize):px=trans[0]+col*trans[1]+row*trans[2]#lonspy=trans[3]+col*trans[4]+row*trans[5]#latscoords=ct.TransformPoint(px,py)lat=coords[0]lon=coords[1]img_lons[row,col]=lonimg_lats[row,col]=lat网上很多代码都是错的,将col和row的位置弄反了。实际上并不复杂。以这个公式为例“px=trans[0]+col*trans[1]+row*trans[2]”,trans[2]是旋转角度,通常为0,因此公式变为“px=trans[0]+col*trans[1]”,px是我们要计算的x轴方向上的坐标,而col代表列数(XSize),trans[1]是x方向的分辨率。换句话说,col是x方向上的间隔个数,而trans[1]是x方向上每个间隔的宽度。因此  “px=trans[0]+col*trans[1]”→ 每个px=原点+间隔数*间隔宽度。(如果我讲清楚了,可以给我一个小赞赞吗,谢谢哈哈哈(∩_∩))【注意tif本身是否带有投影信息】上一段代码先将图像坐标(即tran的6个参数)→转化为了投影坐标(即px、py)再→转为经纬度(lon、lat)这是对于有投影的tif图像的处理;若tif本身没有投影信息,则以上代码算出的px、py即为经纬度。检查投影信息方法:print(dataset.GetProjection())--若输出为空字符串则无投影。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

QQ|手机版|心飞设计-版权所有:微度网络信息技术服务中心 ( 鲁ICP备17032091号-12 )|网站地图

GMT+8, 2025-1-12 21:03 , Processed in 0.509428 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表