Issue
After clicking on the ’Search‘ button and zooming in on a region of the map, how do you get the geographic coordinates in longitude and latitude of the borders of this displayed region?
from mpl_toolkits.basemap import Basemap
import matplotlib.pyplot as plt
import numpy as np
def on_xlim_change(*args):
pass
# Here I would like to get the coordinates in lat and long of the zoomed map
fig = plt.figure(figsize=(7,8),dpi=300,facecolor=(0.3,0.7,0.4,0.2))
ax = fig.add_subplot(111)
long1=-180; long2=180; lat1=-90; lat2=90
m = Basemap(projection='mill',llcrnrlat=lat1,urcrnrlat=lat2,llcrnrlon=long1,urcrnrlon=long2,resolution='i')
m.fillcontinents(color='coral',lake_color='aqua')
m.drawmapboundary(fill_color='aqua')
m.drawcoastlines(linewidth=0.3)
m.drawcountries(linewidth=0.15)
m.drawmeridians(np.arange(-180,180,30),dashes=[1,0],linewidth=0.1,labels=[False,False,True,False],fontname='Times New Roman',fontsize=4)
m.drawparallels(np.arange(-90,90,30),dashes=[1,0],linewidth=0.1,labels=[False,True,False,False],fontname='Times New Roman',fontsize=4)
ax.callbacks.connect('xlim_changed',on_xlim_change)
plt.show()
Solution
The plot limits are available through the methods get_xlim
and get_ylim
from your Axes
object:
xmin, xmax = ax.get_xlim()
ymin, ymax = ax.get_ylim()
These limits are in projection coordinates, and you can convert them to geographic coordinates by calling your Basemap
object with the additional keyword argument inverse=True
:
lonmin, latmin = m(xmin, ymin, inverse=True)
lonmax, latmax = m(xmax, ymax, inverse=True)
Answered By - molinav
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.