Note
Go to the end to download the full example code.
Plotting lines
Plotting lines is handled by the pygmt.Figure.plot
method.
import pygmt
Plot lines
Create a Cartesian figure using the pygmt.Figure.basemap
method. Pass lists
containing two values to the x
and y
parameters of the
pygmt.Figure.plot
method. By default, a 0.25-points thick, black, solid
line is drawn between these two data points.
fig = pygmt.Figure()
fig.basemap(region=[0, 10, 0, 10], projection="X15c/10c", frame=True)
fig.plot(x=[1, 5], y=[5, 9])
fig.show()
data:image/s3,"s3://crabby-images/d4625/d46257e3b0447d8cce32b85fe9c062ae7d09deaf" alt="lines"
Additional line segments can be added by including more data points in the lists
passed to x
and y
.
fig = pygmt.Figure()
fig.basemap(region=[0, 10, 0, 10], projection="X15c/10c", frame=True)
fig.plot(x=[1, 5, 8], y=[5, 9, 4])
fig.show()
data:image/s3,"s3://crabby-images/77f95/77f95c27f69aa138ecb04c441c35b94d5a6f02cf" alt="lines"
To plot multiple lines, pygmt.Figure.plot
needs to be used for each line
separately.
fig = pygmt.Figure()
fig.basemap(region=[0, 10, 0, 10], projection="X15c/10c", frame=True)
fig.plot(x=[1, 5, 8], y=[5, 9, 4])
fig.plot(x=[2, 4, 9], y=[3, 7, 5])
fig.show()
data:image/s3,"s3://crabby-images/84753/847537cef64021d6a08aae5a3955ea52739e0170" alt="lines"
Change line attributes
The line attributes can be set by the pen
parameter which takes a string
argument with the optional values width,color,style.
fig = pygmt.Figure()
fig.basemap(region=[0, 10, 0, 10], projection="X15c/10c", frame=True)
# Set the pen width to "5p" (5 points), and use the default color "black" and the
# default style "solid"
fig.plot(x=[1, 8], y=[3, 9], pen="5p")
fig.show()
data:image/s3,"s3://crabby-images/2cf05/2cf0576dc9f1a579f0ff859c8283ae205330b94b" alt="lines"
The line color can be set and is added after the line width to the pen
parameter.
fig = pygmt.Figure()
fig.basemap(region=[0, 10, 0, 10], projection="X15c/10c", frame=True)
# Set the line color to "red", use the default style "solid"
fig.plot(x=[1, 8], y=[3, 9], pen="5p,red")
fig.show()
data:image/s3,"s3://crabby-images/f8894/f8894cd0beec25a7bc689548a5402afa57739bda" alt="lines"
The line style can be set and is added after the line width or color to the
pen
parameter.
fig = pygmt.Figure()
fig.basemap(region=[0, 10, 0, 10], projection="X15c/10c", frame=True)
# Set the line style to "..-" (dot dot dash), use the default color "black"
fig.plot(x=[1, 8], y=[3, 9], pen="5p,..-")
fig.show()
data:image/s3,"s3://crabby-images/efc60/efc60ee716b38a4a4477eb2e153b03f9e13a7400" alt="lines"
The line width, color, and style can all be set in the same pen
parameter.
For a gallery example showing other pen
settings, see
Line styles.
fig = pygmt.Figure()
fig.basemap(region=[0, 10, 0, 10], projection="X15c/10c", frame=True)
# Draw a 7-points thick, green line with style "-.-" (dash dot dash)
fig.plot(x=[1, 8], y=[3, 9], pen="7p,green,-.-")
fig.show()
data:image/s3,"s3://crabby-images/74195/741955a746380f74f72ff449bb3bd580a9e94495" alt="lines"
Total running time of the script: (0 minutes 0.949 seconds)