Для этого вам необходимо преобразовать точку из координат осей, чтобы отобразить координаты, затем в координаты данных и, наконец, в координаты широты / долготы. Таким образом, вам нужны преобразования из matplotlib и cartopy .
Точка 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](https://i.stack.imgur.com/VrwWr.png)