[英]Matplotlib Basemap: Removing Ocean
我有一個網格圖,我想在底圖中覆蓋大陸。 我正在使用這段代碼:
from mpl_toolkits.basemap import Basemap
import matplotlib.pyplot as plt
m = Basemap(width=12000000,height=9000000,projection='lcc',
resolution=None,lat_1=45.,lat_2=55,lat_0=50,lon_0=-107.)
m.drawlsmask(land_color='coral',ocean_color='aqua',lakes=True)
plt.show()
提到這一點,我的要求是相反的。 我希望大陸位於網格圖或我擁有的圖像之上,因此只能看到海洋區域的網格。
您的要求:
要獲得情節,您必須在涉及的每個圖層中使用“zorder”。 要繪制的數據必須適當地轉換。 這是您可以嘗試的代碼,以及它生成的輸出圖。
from mpl_toolkits.basemap import Basemap
import matplotlib.pyplot as plt
import numpy as np
m = Basemap(projection='lcc', width=12000000, height=9000000,
resolution='c', lat_1=45., lat_2=55, lat_0=50, lon_0=-107.)
# if resolution is None, coastlines wont draw
# draw only land areas with zorder=20
# any other layers with zorder below 20 will be hidden by land areas
m.drawlsmask(land_color='coral', ocean_color='none', lakes=True, zorder=20)
m.drawcoastlines(linewidth=0.3, color='gray', zorder=25)
filename = "small_01.png" #use your image here
lonmin, lonmax, latmin, latmax = (-130, -40, 35, 45) # set limits of the image
# compute the limits of the image in data coordinates
left, bottom = m (lonmin, latmin)
top, right = m(lonmax, latmax)
image_extent = (left, right, bottom, top)
ax = plt.gca()
# set zorder < 20, to plot the image below land areas
ax.imshow(plt.imread(filename), extent=image_extent, zorder=15)
# plot some meshgrid data
# set zorder above image, but below land
xs = np.linspace(-130, -60, 20)
ys = np.linspace(20, 60, 10)
x2d, y2d = np.meshgrid(xs, ys)
#ax.plot(*m(x2d, y2d), 'ro', zorder=16) # faster
ax.scatter(*m(x2d, y2d), s=2, zorder=16)
plt.show()
編輯 1
一些有用的代碼片段:
# This plots shaded relief terrain covering land and sea.
m.shadedrelief(zorder = 25)
# This plots only ocean/sea parts on top.
m.drawlsmask(land_color='none', ocean_color='aqua', zorder=26)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.