Note
Click here to download the full example code
Coastlines and borders
Plotting coastlines and borders is handled by pygmt.Figure.coast
.
import pygmt
Shorelines
Use the shorelines
parameter to plot only the shorelines:
fig = pygmt.Figure()
fig.basemap(region="g", projection="W15c", frame=True)
fig.coast(shorelines=True)
fig.show()
data:image/s3,"s3://crabby-images/e1df2/e1df28c5bf69a98589d43f15325d9ae530e7398c" alt="coastlines"
Out:
<IPython.core.display.Image object>
The shorelines are divided in 4 levels:
coastline
lakeshore
island-in-lake shore
lake-in-island-in-lake shore
You can specify which level you want to plot by passing the level number and a GMT pen configuration. For example, to plot just the coastlines with 0.5 thickness and black lines:
fig = pygmt.Figure()
fig.basemap(region="g", projection="W15c", frame=True)
fig.coast(shorelines="1/0.5p,black")
fig.show()
data:image/s3,"s3://crabby-images/a13d5/a13d50a3a213a0f6f5cf99bed44f46967c694d86" alt="coastlines"
Out:
<IPython.core.display.Image object>
You can specify multiple levels (with their own pens) by passing a list to
shorelines
:
fig = pygmt.Figure()
fig.basemap(region="g", projection="W15c", frame=True)
fig.coast(shorelines=["1/1p,black", "2/0.5p,red"])
fig.show()
data:image/s3,"s3://crabby-images/4864b/4864b0d22748c41887561c77b55e55b92e11f9a2" alt="coastlines"
Out:
<IPython.core.display.Image object>
Resolutions
The coastline database comes with 5 resolutions. The resolution drops by 80% between levels:
"c"
: crude"l"
: low (default)"i"
: intermediate"h"
: high"f"
: full
oahu = [-158.3, -157.6, 21.2, 21.8]
fig = pygmt.Figure()
for res in ["c", "l", "i", "h", "f"]:
fig.coast(resolution=res, shorelines="1p", region=oahu, projection="M5c")
fig.shift_origin(xshift="5c")
fig.show()
data:image/s3,"s3://crabby-images/8f46b/8f46b51dcfa8dd80472ec8a012df5d5d19d57634" alt="coastlines"
Out:
<IPython.core.display.Image object>
Land and water
Use the land
and water
parameters to specify a fill color for land
and water bodies. The colors can be given by name or hex codes (like the ones
used in HTML and CSS):
fig = pygmt.Figure()
fig.basemap(region="g", projection="W15c", frame=True)
fig.coast(land="#666666", water="skyblue")
fig.show()
data:image/s3,"s3://crabby-images/3734f/3734f490774706e1a03344128af441b1fc2f0c27" alt="coastlines"
Out:
<IPython.core.display.Image object>
Total running time of the script: ( 0 minutes 6.140 seconds)