导入shapefile后如何遮罩外部区域(basemap/matplotlib)

7
我正在使用Matplotlib在美国东海岸和加拿大的基础地图上绘制数据。除了基本层(填充轮廓图)之外,我还使用Matplotlib的readshapefile工具叠加了该重点区域的shapefile。 我想知道如何遮蔽形状文件之外的所有网格数据。显然,我可以通过Matplotlib执行maskocean命令,但我仍会留下圣劳伦斯河以西的填充轮廓。有人知道如何做吗?我在网上搜索并没有太多成功。
def make_map(lon,lat,param):
    fig, ax = plt.subplots()
    ax.axis('off')
    x1 = -83.
    x2 = -57.
    y1 = 37.
    y2 = 50.
    projection='merc'
    resolution='h'
    m = Basemap(projection=projection, llcrnrlat=y1, urcrnrlat=y2, llcrnrlon=x1,
                urcrnrlon=x2, resolution=resolution)
    x,y = m((lon-360.),lat)
    m.ax = ax
    my_cmap = cm.get_cmap('coolwarm')
    pp = m.contourf(x, y, param, 30, cmap=my_cmap, extend='both')  
    m.drawmapscale(-67, 39.5, -70, 43.5, 500, fontsize=8, barstyle='fancy') 
    return fig, m, x, y

def drawstates(ax, shapefile='../StateProv_UTMrp'):
        shp = m.readshapefile(shapefile, 'states',zorder = 1, drawbounds=True)
        for nshape, seg in enumerate(m.states):
            poly = Polygon(seg, facecolor='w',alpha=0.0, edgecolor='k')
            ax.add_patch(poly)

fig, m, x, y = make_map(lon, lat, param)
drawstates(m.ax)
1个回答

2

我认为我刚刚找到的这篇文章可以帮助你。但是我不确定它是否是完整的答案。

http://basemaptutorial.readthedocs.org/en/latest/clip.html

(注:该链接为一个关于地图制作技术的教程,其中介绍了如何使用Basemap库对地图进行裁剪等操作)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接