Cartopy:将点从轴坐标转换为纬度/经度坐标

时间:2019-06-19 08:09:47

标签: python matplotlib cartopy

我正在使用Cartopy(TransverseMercator投影)绘制地图。我在坐标轴(p_a = (0.1, 0.9)中有一个点,我需要它的经/纬度坐标(即在PlateCarree投影中的经纬度)。我该如何实现?

1 个答案:

答案 0 :(得分:3)

为此,您需要将点从轴坐标转换为显示坐标,然后转换为数据坐标,最后转换为纬度/经度坐标。因此,您需要从matplotlibcartopy进行转换。

p_a = (0.1, 0.9)似乎在有效纬度/经度坐标之外(默认ccrs.TransverseMercator())。因此,我使用p_a = (0.6, 0.6)

import cartopy.crs as ccrs
import matplotlib.pyplot as plt

proj = ccrs.TransverseMercator()
proj_cart = ccrs.PlateCarree() 

f, ax = plt.subplots(subplot_kw=dict(projection=proj))
ax.coastlines()

# define point
p_a = (0.6, 0.6)

# plot point in Axes coordinates
ax.plot(*p_a, transform=ax.transAxes, marker='o', ms=10)

# convert from Axes coordinates to display coordinates
p_a_disp = ax.transAxes.transform(p_a)

# convert from display coordinates to data coordinates
p_a_data = ax.transData.inverted().transform(p_a_disp)

# convert from data to cartesian coordinates
p_a_cart = proj_cart.transform_point(*p_a_data, src_crs=proj)

# make sure we are correct
ax.plot(*p_a_cart, transform=proj_cart, marker='x', ms=10)

这将产生下图:

original and transformed point