如何从Sentinel-1合成孔径雷达(SAR)卫星图像的x,y位置获取地理坐标?
例如,我可以访问下载的图像信息sg
,
from snappy import ProductIO
from snappy import PixelPos
path='path_name'
product = ProductIO.readProduct(path)
sg = product.getSceneGeoCoding()
但是如何使用ESA's snap engine within Python获得sg
中所需点(x,y)的纬度和经度?
答案 0 :(得分:1)
使用下面的自定义函数,我们可以轻松地将图像sg
中的任何点转换为其坐标(纬度,经度):
def LatLon_from_XY(ProductSceneGeoCoding, x, y):
#From x,y position in satellite image (SAR), get the Latitude and Longitude
geopos = ProductSceneGeoCoding.getGeoPos(PixelPos(x, y), None)
latitude = geopos.getLat()
longitude = geopos.getLon()
return latitude, longitude
UPD: 由于各种快照版本更新,上述功能可能无法正常工作。下面的功能通常应该可以正常工作。
def LatLon_from_XY(product, x, y):
geoPosType = jpy.get_type('org.esa.snap.core.datamodel.GeoPos')
geocoding = product.getSceneGeoCoding()
geo_pos = geocoding.getGeoPos(snappy.PixelPos(x, y), geoPosType())
if str(geo_pos.lat)=='nan':
raise ValueError('x, y pixel coordinates not in this product')
else:
return geo_pos.lat, geo_pos.lon
例如对于给定的sg
产品,我们可以获得像素(x = 12000,y = 2000)的坐标为
latitude, longitude = LatLon_from_XY(sg, 12000, 2000)