Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP: DOC: Add advanced tutorial "Creating legends" #3594

Draft
wants to merge 45 commits into
base: main
Choose a base branch
from
Draft
Changes from 24 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
42c07fb
Add code legend via tringio
yvonnefroehlich Sep 21, 2024
6f7751d
Merge remote-tracking branch 'origin/main' into add-gallery-legend-spec
yvonnefroehlich Sep 28, 2024
c4e2baa
Merge remote-tracking branch 'origin/main' into add-gallery-legend-spec
yvonnefroehlich Oct 18, 2024
b1d10ea
Merge remote-tracking branch 'origin/main' into add-gallery-legend-spec
yvonnefroehlich Nov 5, 2024
9db4522
Merge remote-tracking branch 'origin/main' into add-gallery-legend-spec
yvonnefroehlich Nov 6, 2024
79f6b3e
Update docstring
yvonnefroehlich Nov 6, 2024
497a275
Addm more docs
yvonnefroehlich Nov 6, 2024
3012359
Add remaining section | Move file to tutorials
yvonnefroehlich Nov 6, 2024
3cfefea
Add width
yvonnefroehlich Nov 6, 2024
b81a42a
Fix shinx gallery layout
yvonnefroehlich Nov 6, 2024
8ec4388
Fix forma | Remove execution permission
yvonnefroehlich Nov 6, 2024
17d5f15
Add more documentation
yvonnefroehlich Nov 6, 2024
f429342
Use Cartesian projection
yvonnefroehlich Nov 6, 2024
9633aad
Update title
yvonnefroehlich Nov 6, 2024
4fe8473
Adjust file name
yvonnefroehlich Nov 6, 2024
b6f6045
Use Mercator projection
yvonnefroehlich Nov 6, 2024
bf84f6a
Adjust position of example data point
yvonnefroehlich Nov 6, 2024
ac0b469
Adjust width of legend
yvonnefroehlich Nov 6, 2024
6d40cea
Merge branch 'main' into add-gallery-legend-spec
yvonnefroehlich Nov 10, 2024
e4a966b
Improve docs
Nov 10, 2024
e0ef881
Use long list for 'region' | Fix typo | Improve comments
yvonnefroehlich Nov 10, 2024
46e8340
Adjust position of legend instead of datapoint
yvonnefroehlich Nov 11, 2024
907c219
Add docs
yvonnefroehlich Nov 11, 2024
92f76bc
Fix highlighting | Remove sentence
yvonnefroehlich Nov 11, 2024
f806a06
Fix typos
yvonnefroehlich Nov 11, 2024
de182e8
Add highighting
yvonnefroehlich Nov 11, 2024
7077497
Use link syntax
yvonnefroehlich Nov 11, 2024
991d56f
Add hilighting
yvonnefroehlich Nov 11, 2024
0ea13d4
Merge branch 'main' into add-gallery-legend-spec
yvonnefroehlich Nov 11, 2024
4e9d842
Fix link
yvonnefroehlich Nov 11, 2024
49773b4
Mention other plotting method with have the 'label' parameter for legend
yvonnefroehlich Nov 12, 2024
a47babf
Use multiple symbols to show legend layout
yvonnefroehlich Nov 12, 2024
a367101
Improve docs
yvonnefroehlich Nov 12, 2024
db75fee
Add blank line
yvonnefroehlich Nov 12, 2024
eb72131
Add comments
yvonnefroehlich Nov 12, 2024
02da95a
Combine subsections
yvonnefroehlich Nov 12, 2024
3afe1fd
Fix typo
yvonnefroehlich Nov 12, 2024
038f9c4
Improve formulation
yvonnefroehlich Nov 12, 2024
5eeff8b
Fix coding style
yvonnefroehlich Nov 12, 2024
380a58f
Add docs for legend codes
yvonnefroehlich Nov 13, 2024
55c8215
Rewrap to 88 chars
yvonnefroehlich Nov 18, 2024
60054fc
Merge branch 'main' into add-gallery-legend-spec
yvonnefroehlich Nov 26, 2024
d2cefc0
Merge branch 'main' into add-gallery-legend-spec
yvonnefroehlich Dec 15, 2024
63e5b29
Merge branch 'main' into add-gallery-legend-spec
yvonnefroehlich Jan 2, 2025
21a3d53
Merge branch 'main' into add-gallery-legend-spec
yvonnefroehlich Jan 16, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
142 changes: 142 additions & 0 deletions examples/tutorials/advanced/legends.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,142 @@
"""
Creating legends
================

The :meth:`pygmt.Figure.legend` method creates legends, whereby auto-legends as
well as manually created legends are supported.
"""

# %%
import io

import pygmt

# %%
# Create an auto-legend
# ---------------------
#
# For auto-legends, the ``label`` parameter of :meth:`pygmt.Figure.plot` has to
# be specified to state the desired text in the legend entry (white spaces are
# allowed). Optionally, to adjust the legend, users can append different modifiers
# to the string passed to ``label`. A list of all available modifiers can be
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# found at :gmt-docs:`gmt.html#l-full`. To create a multiple-column legend **+N**
# is used with the desired number of columns; see also gallery example
# https://www.pygmt.org/dev/gallery/embellishments/legend.html.
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# By default, the legend is placed in the Upper Right corner with an offset of 0.1
# centimeters in x and y directions and a box with white fill and a 1-point thick,
# black, solid outline is drawn around the legend.

fig = pygmt.Figure()
fig.basemap(region=[-5, 5, -5, 5], projection="X5c", frame=True)

fig.plot(x=0, y=0, style="c0.25c", fill="orange", label="orange circle")
seisman marked this conversation as resolved.
Show resolved Hide resolved
fig.legend()

fig.show()


# %%
# Adjust the position
# -------------------
# Use the ``position`` parameter to adjust the position of the legend. For the
# different ways to specifiy the placement of an plotting element (e.g., legends,
# colorbars) on a plot in GMT, please refer to the Technical Reference TODO (: .
# Add an offset via **+o** for the x and y directions. Addionally append **+w**
# to adjust the ``width of the legenth. Note, no box is drawn by default if
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# ``position`` is used.

fig = pygmt.Figure()
fig.basemap(region=[-5, 5, -5, 5], projection="X5c", frame=True)

fig.plot(x=0, y=0, style="c0.25c", fill="orange", label="orange circle")
fig.legend(position="jLT+o0.3c/0.2c")

fig.show()


# %%
# Add a box
# ---------
# Use the ``box`` parameter for adjusting the box around the legend. Append
# **g+** to fill the legend with a color or pattern [Default is a white fill].
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# The outline of the box an be adjusted by appending **p**. The default of
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# ``position`` is preserved.


fig = pygmt.Figure()
fig.basemap(region=[-5, 5, -5, 5], projection="X5c", frame=True)

fig.plot(x=0, y=0, style="c0.25c", fill="orange", label="orange circle")
fig.legend(position="jTL+o0.3c/0.2c", box=True)

fig.shift_origin(xshift="w+1c")
fig.basemap(region=[-5, 5, -5, 5], projection="X5c", frame=True)

fig.plot(x=0, y=0, style="c0.25c", fill="orange", label="orange circle")
fig.legend(position="jTL+o0.3c/0.2c", box="+p2p,cyan+gblue@70")

fig.show()


# %%
# Create a manual legend
# ----------------------
#
# For more complicated legends in GMT, users need to write an ASCII file with
# instructions for the layout of the legend items. In PyGMT it is addionaly
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# possible to provide this information as an ``io.StringIO`` object. Both, the
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# ASCII file or the ``io.StringIO`` object are passed to the ``spec`` parameter
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# of :meth:`pygmt.Figure.legend`.
#
seisman marked this conversation as resolved.
Show resolved Hide resolved
# The example below is orientated on the upstream GMT example at
# https://docs.generic-mapping-tools.org/dev/legend.html#examples.


# %%
# First, we set up an ``io.StringIO`` object.
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved

spec_io = io.StringIO(
"""
G -0.1c
H 24p,Times-Roman My Map Legend
D 0.2c 1p
N 2
V 0 1p
S 0.1c c 0.15c p300/12 0.25p 0.3c This circle is hachured
S 0.1c e 0.15c yellow 0.25p 0.3c This ellipse is yellow
S 0.1c w 0.15c green 0.25p 0.3c This wedge is green
S 0.1c f 0.25c blue 0.25p 0.3c This is a fault
S 0.1c - 0.15c - 0.25p,- 0.3c A contour
S 0.1c v 0.25c magenta 0.5p 0.3c This is a vector
S 0.1c i 0.15c cyan 0.25p 0.3c This triangle is boring
D 0.2c 1p
V 0 1p
N 1
M 5 5 600+u+f
G 0.05c
I @SOEST_block4.png 3i CT
G 0.05c
G 0.05c
L 9p,Times-Roman R Smith et al., @%5%J. Geophys. Res., 99@%%, 2000
G 0.1c
T Let us just try some simple text that can go on a few lines.
T There is no easy way to predetermine how many lines may be required
T so we may have to adjust the height to get the right size box.
"""
)

# %%
# Now, we can add a legend based on this ``io.StringIO`` object. For
yvonnefroehlich marked this conversation as resolved.
Show resolved Hide resolved
# multi-columns legends, width (**+w**) has to be specified via a the
# ``position`` parameter.

fig = pygmt.Figure()
# Note, that we are now using a Mercator projection
fig.basemap(region=[-5, 5, -5, 5], projection="M10c", frame=True)

# Pass the io.StringIO object to the spec parameter
fig.legend(spec=spec_io, position="jMC+w9c", box="+p1p,gray50+ggray95")

fig.show()

# sphinx_gallery_thumbnail_number = 4