.. index:: ! legend
.. include:: module_core_purpose.rst_

********
legend
********

|legend_purpose|

Synopsis
--------

.. include:: common_SYN_OPTs.rst_

**gmt legend** [ *specfile* ]
|-D|\ *refpoint*
[ |SYN_OPT-B| ]
[ |-C|\ *dx*/*dy* ]
[ |-F|\ *box* ]
[ |-J|\ *parameters* ]
[ |-M|\ [**h**\|\ **e**] ]
[ |SYN_OPT-R| ]
[ |-S|\ *scale* ]
[ |-T|\ *file* ]
[ |SYN_OPT-U| ]
[ |SYN_OPT-V| ]
[ |SYN_OPT-X| ]
[ |SYN_OPT-Y| ]
[ |SYN_OPT-p| ]
[ |SYN_OPT-qi| ]
[ |SYN_OPT-t| ]
[ |SYN_OPT--| ]

.. module_common_begins

Description
-----------

Makes legends that can be overlaid on maps. It reads
specific legend-related information from an input file [or standard input].
Unless otherwise noted, annotations will be made using the primary
annotation font and size in effect (i.e., :term:`FONT_ANNOT_PRIMARY`)

.. figure:: /_images/GMT_seislegend.*
   :width: 600 px
   :align: center

   Example of a map legend, here for seismicity in the Pacific region.

Required Arguments
------------------

.. _-D:

**-D**\ [**g**\|\ **j**\|\ **J**\|\ **n**\|\ **x**]\ *refpoint*\ **+w**\ *width*\ [/*height*]\ [**+j**\ *justify*]\ [**+l**\ *spacing*]\ [**+o**\ *dx*\ [/*dy*]]
    Defines the reference point on the map for the legend using one of four coordinate systems:

    .. include:: explain_refpoint.rst_

    Append **+w**\ *width*\ [/*height*] to set the width (and height) of the legend box
    in plot coordinates (inches, cm, etc.). If unit is % (percentage) then *width* as
    computed as that fraction of the map width. If *height* is given as percentage then
    then *height* is recomputed as that fraction of the legend *width* (not map height).
    **Note**: If **+w** is not given then we compute
    the width within the *Postscript* code.  Currently, this is only possible if just
    legend codes **D**, **H**, **L**, **S**, or **V** are used and that the number of symbol
    columns (**N**) is 1. If *height* is zero or not given then we estimate *height* based
    the expected vertical extent of the items to be placed.
    By default, the anchor point on the legend is assumed to be the bottom left corner (BL), but this
    can be changed by appending **+j** followed by a 2-char justification code *justify* (see :doc:`text`).
    **Note**: If **-Dj** is used then *justify* defaults to the same as *refpoint*,
    if **-DJ** is used then *justify* defaults to the mirror opposite of *refpoint*.
    Use **+l**\ *spacing* to change the line-spacing factor in units of the current
    font size [1.1].

Optional Arguments
------------------

*specfile*
    This ASCII file contains instructions for the layout of items in the
    legend. Each legend item is described by a unique record. All
    records begin with a unique character that is common to all records
    of the same kind. The order of the legend items is implied by the
    order of the records.  See |-M| for mixing legend items set by a
    *specfile* and those set implicitly via **-l** by previous modules
    under modern mode.

.. |Add_-B| replace:: |Add_-B_links|
.. include:: explain_-B.rst_
    :start-after: **Syntax**
    :end-before: **Description**

.. _-C:

**-C**\ *dx*/*dy*
    Sets the clearance between the legend frame and the internal items [4\ **p**/4\ **p**].

.. _-F:

**-F**\ [**+c**\ *clearances*][**+g**\ *fill*][**+i**\ [[*gap*/]\ *pen*]][**+p**\ [*pen*]][**+r**\ [*radius*]]\
[**+s**\ [[*dx*/*dy*/][*shade*]]]

    Without further options, draws a rectangular border around the legend using :term:`MAP_FRAME_PEN`. The following
    modifiers can be appended to |-F|, with additional explanation and examples provided in the :ref:`Background-panel`
    cookbook section:

    .. include:: explain_-F_box.rst_

    **Note**: If legend *width* is not set via |-D| then modifier **+r** in |-F| is disabled.

.. |Add_-J| replace:: |Add_-J_links|
.. include:: explain_-J.rst_
    :start-after: **Syntax**
    :end-before: **Description**

.. _-M:

**-M**\ [**h**\|\ **e**]
    Modern mode only and pertains the situation where there are two ways to provide legend info:
    Specify one or two schemes in the order you desire via directives:

    - **h**: Hidden, auto-generated legend information created by prior plotting-modules' **-l**
      option
    - **e**: Explicitly given information from input file(s) given on the command line (or via
      standard input).

    Default is **he**, meaning we will first place any hidden auto-generated legend items (if any)
    and then we append the explicitly given information (if present).  **Note**: For classic
    mode an input file must be given or else we will attempt read from standard input.

.. |Add_-R| replace:: |Add_-R_links|
.. include:: explain_-R.rst_
    :start-after: **Syntax**
    :end-before: **Description**

.. _-S:

**-S**\ *scale*
    Scale all symbol sizes by a common *scale* [1].

.. _-T:

**-T**\ *file*
    Modern mode only: Write hidden legend specification file to *file*.

.. |Add_-U| replace:: |Add_-U_links|
.. include:: explain_-U.rst_
    :start-after: **Syntax**
    :end-before: **Description**

.. |Add_-V| replace:: |Add_-V_links|
.. include:: explain_-V.rst_
    :start-after: **Syntax**
    :end-before: **Description**

.. |Add_-XY| replace:: |Add_-XY_links|
.. include:: explain_-XY.rst_
    :start-after: **Syntax**
    :end-before: **Description**

.. |Add_perspective| unicode:: 0x20 .. just an invisible code
.. include:: explain_perspective.rst_

.. include:: explain_-qi.rst_

.. include:: explain_-t.rst_

.. include:: explain_help.rst_

Legend Codes
------------

Fourteen different record types are recognized, and
the syntax for each of these records are presented below:

**#** *comment*
    Records starting with # and blank lines are skipped.
**A** *cptname*
    Symbol or cell color fills may be given indirectly via a *z*-value
    which can be used for the color look-up via the given CPT *cptname*.
    You may switch to other *cptname* by repeating this command.
**B** *cptname offset height* [ *optional arguments* ]
    The **B** record will plot a horizontal color bar, :doc:`colorbar`-style
    in the middle, starting at *offset* from the left edge, and of the
    given *height*. You may add any additional :doc:`colorbar` options as well.
    Any of the modifiers
    [**+e**\ [**b**\|\ **f**][*length*]][**+h**][**+m**\ [**a**\|\ **c**\|\ **l**\|\ **u**]][**+n**\ [*txt*]] may be
    appended to the *height* argument, while other module options
    |-B| |-I| |-L| |-M| |-N| |-S| |-Z| and **-p** may be appended as
    *optional arguments* at the end of the record.
    See :doc:`colorbar` for details on all modifiers and options.
**C** *textcolor*
    The **C** record specifies the color with which the remaining text
    is to be printed via z=\ *value* (requires a prior **A** code as well).
    When **C** is used in a legend then your font specifications cannot also
    contain a color specification since we will append ,\ *textcolor* to the font.
    Use **-** to reset to default color.
**D** [*offset*] *pen* [**-**\|\ **+**\|\ **=**]
    The **D** record results in a horizontal line with specified *pen*
    across the legend with one quarter of the line-spacing left blank
    above and below the line. Two gaps of *offset* units are left blank
    between the horizontal line and the left and right frame sides [0]. If
    no pen is given we use :term:`MAP_GRID_PEN_PRIMARY`, and if *pen* is
    set to **-** then no visible line is drawn (we just remember the location
    as a possible start/stop point for a vertical line; see **V**).  To *not* add the
    quarter line-spacing before the line, add **-**.  To *not* add the spacing
    after the line, add **+**.  For no spacing at all, add **=**
    [Default places a quarter line-spacing both before and after the line].
**F** *fill1 fill2 ... filln*
    Specify fill (color of pattern) for cells.  Alternatively, you can
    specify an indirect color via z=\ *value* (requires a prior **A** code).
    If only *fill1* is given
    then it is used to fill the entire row, otherwise give one fill value
    for each active column (see **N**).  If any fill is - then no fill
    takes place [Default].
**G** *gap*
    The **G** record specifies a vertical gap of the given length. In
    addition to the standard units (**i**, **c**, **p**) you may use
    **l** for lines. A negative *gap* will move the current line upwards (thus closing a gap).
**H** *font*\|\ **-** *header*
    The **H** record plots a centered text string using the specified
    font parameters. Use **-** to default to size and fonttype of :term:`FONT_TITLE`.
**I** *imagefile width justification*
    Place an EPS or raster image in the legend justified relative to
    the current point. The image *width* determines the size of the image on the page.
**L** *font*\|\ **-** *justification label*
    The **L** record plots a (L)eft, (C)entered, or (R)ight-justified
    text string within a column using the specified font parameters. Use
    **-** to default to the size and font type of :term:`FONT_LABEL`.
**M** *slon*\|\ **-** *slat* *length*\ [**+a**\ *align*][**+f**][**+l**\ [*label*]][**+u**] [**-F**\ *param*] [ **-R**\ *w/e/s/n* **-J**\ *param* ]
    Place a map scale in the legend. Specify *slon slat*, the point on
    the map where the scale applies (*slon* is only meaningful for
    certain oblique projections. If not needed, you must specify **-**
    instead). Give *length*, the length of the scale in km (for other units
    append **e** (meter), **f** (foot), **M** (mile), **n** (nautical
    mile), or **u** (survey foot)). Append **+f** for a fancy map scale
    [Default is plain].
    Append **+l** to the *length* to select the default label
    which equals the distance unit (meter, feet, km, miles, nautical
    miles, survey feet) and is justified on top of the scale [t]. Change
    this by giving your own label (append **+l**\ *label*). Change label
    alignment with **+a**\ *align* (choose among **l**\ (eft),
    **r**\ (ight), **t**\ (op) , and **b**\ (ottom)).
    Apply **+u** to append the unit to all distance annotations along
    the scale. If you want to place a map panel behind the scale,
    add a suitable |-F| panel option (see :doc:`basemap` for details
    on panels as well as map scale modifiers).
    All **+**\ *modifiers* must be appended to *length* to make a single
    string argument.  If the |-R| |-J| supplied to the module is
    different than the projection needed for the scale (or not given at
    all, e.g., with **-Dx**), supply the two optional |-R| |-J| settings
    as well.
**N** [*ncolumns* or *relwidth1 relwidth2 ... relwidthn*]
    Change the number of columns in the legend [1]. This only affects
    the printing of symbols (**S**) and labels (**L**). The number of
    columns stay in effect until **N** is used again.  To get columns
    of unequal width, instead provide the relative width of each column
    separated by whitespace.  The sum of these widths are equated to the
    legend width set via |-D|.  If no argument is given the we set
    *n_columns* to 1.
**P** *paragraph-mode-header-for-text*
    Start a new text paragraph by specifying all the parameters needed
    (see :doc:`text` |-M| record description). Note that the module knows
    what all those values should be, so normally you can leave the
    entire record (after P) blank or leave it out all together. If you
    need to set at least one of the parameters directly, you must
    specify all and set the ones you want to leave at their default
    value to **-**.
**S** [*dx1 symbol size fill pen* [ *dx2 text* ]]
    Plots the selected symbol with specified diameter, fill, and outline
    (see :doc:`plot`). The symbol is centered at *dx1* from the left margin
    of the column, with the optional explanatory *text* starting *dx2*
    from the margin, printed with :term:`FONT_ANNOT_PRIMARY`. If *dx1* is given
    as **-** then it is automatically computed from half the largest symbol size.
    If *dx2* is given as **-** then it is automatically computed as the largest
    symbol size plus one character width at the current annotation font size.
    Use **-** if no *fill* or outline (*pen*) is required. Alternatively, the *fill*
    may be specified indirectly via z=\ *value* and the color is assigned
    via the CPT look-up (requires a prior **A** code).  When plotting just a
    symbol, without text, *dx2* and *text* can be omitted.  The *dx1* value
    can also be given as a justification code **L**\ , **C**\ , or **R** which justifies the
    symbol with respect to the current column.  If no arguments are given
    to **S** then we simply skip to the next column.  Three :doc:`plot`
    symbols may take special modifiers: front (**f**), quoted line (**q**)  and vector (**v**).
    You can append modifiers to the symbol and affect how the fronts, quoted lines and
    vectors are presented (see :doc:`plot` man page for modifiers).
    The module will determine default settings for all modifiers and
    secondary arguments if not provided.  A few other symbols (the rectangles,
    ellipse, wedge, mathangle) may take more than a single argument size.
    Note that for a line segment you should use the horizontal dash symbol (**-**).
    If just a single size if given then we will provide reasonable
    arguments to plot the symbol  (See `Defaults`_).
    Alternatively, combine the required arguments into a single, comma-separated
    string and use that as the symbol size (again, see :doc:`plot` for details on
    the arguments needed).
**T** *paragraph-text*
    One or more of these **T** records with *paragraph-text* printed
    with :term:`FONT_ANNOT_PRIMARY`. To specify special positioning and
    typesetting arrangements, or to enter a paragraph break, use the
    optional **P** record.
**V** [*offset*] *pen*
    The **V** record draws a vertical line between columns (if more than
    one) using the selected *pen*.  Here, *offset* is analogous to the offset
    for the **D** records but in the vertical direction [0].  The first time
    **V** is used we remember the vertical position of the last **D** line,
    and the second time **V** is set we draw from that past location to the
    most recent location of the **D** line.  Thus, **D** must be used to
    mark the start and stop of a vertical line (so **V** must follow **D**).
    If no horizontal line is desired simply give - as *pen* to **D**.

Defaults
--------

When attributes are not provided, or extended symbol information (for symbols taking more than just an overall size) are
not given as comma-separated quantities, we will provide the following defaults:

Geographic symbols: If *size* is given as **-** then we default to the character height at the current annotation font size.

Line/vector: If *size* is given as **-** then we default to a length of 2.5 times the character width at the current annotation font size.

Front: The *size* argument is *length*\ [/*gap*\ [*ticklength*]]. Front symbol is left-side (here, that means upper side) box,
with *ticklength* set 30% of the given symbol *length* (if not specified separately), and *gap* defaulting to -1 (one
entered front symbol) if not specified.  Modifiers to the symbol argument can be provided.

Vector: Head size is 30% of given symbol size.

Ellipse: Minor axis is 65% of major axis (the symbol size), with an azimuth of 0 degrees.

Rectangle: Height is 65% of width (the symbol size).

Rotated rectangle: Same, with a rotation of 30 degrees.

Rounded rectangle: Same as rectangle, but with corner radius of 10% of width.

Mathangle: Angles are -10 and 45 degrees, with arrow head size 30% of symbol size.

Wedge: Angles are -30 and 30 degrees.

Note On Legend Height
---------------------

As |-D| suggests, leaving the *height* off forces a calculation of the
expected height. This is an exact calculation except in the case of
legends that place paragraph text. Here we simply do a first-order
estimate of how many typeset lines might appear. Without access to font
metrics this estimate will occasionally be off by 1 line. If so, note
the reported height (with |-V|) and specify a slightly larger or
smaller height in |-D|.

Windows Remarks
---------------

Note that under Windows, the percent sign (%) is a variable indicator
(like $ under Unix). To indicate a plain percentage sign in a batch
script you need to repeat it (%%); hence the font switching mechanism
(@%\ *font*\ % and @%%) may require twice the number of percent signs.
This only applies to text inside a script or that otherwise is processed
by DOS. Data files that are opened and read by the module do not need
such duplication.

.. module_common_ends

Examples
--------

.. include:: explain_example.rst_

.. include:: oneliner_info.rst_

To add an example of a legend to a Mercator plot (map.ps) with the given
specifications, use::

    gmt begin legend
    gmt makecpt -Cpanoply -T-8/8 -H > tt.cpt
    gmt set FONT_ANNOT_PRIMARY 12p
    gmt legend -R0/10/0/10 -JM6i -Dx0.5i/0.5i+w5i+jBL+l1.2 -C0.1i/0.1i -F+p+gazure1+r -B5f1 << EOF
    # Legend test for gmt pslegend
    # G is vertical gap, V is vertical line, N sets # of columns, D draws horizontal line,
    # H is ps=legend.ps
    #
    G -0.1i
    H 24p,Times-Roman My Map Legend
    D 0.2i 1p
    N 2
    V 0 1p
    S 0.1i c 0.15i p300/12 0.25p 0.3i This circle is hachured
    S 0.1i e 0.15i yellow 0.25p 0.3i This ellipse is yellow
    S 0.1i w 0.15i green 0.25p 0.3i This wedge is green
    S 0.1i f 0.25i blue 0.25p 0.3i This is a fault
    S 0.1i - 0.15i - 0.25p,- 0.3i A contour
    S 0.1i v 0.25i magenta 0.5p 0.3i This is a vector
    S 0.1i i 0.15i cyan 0.25p 0.3i This triangle is boring
    D 0.2i 1p
    V 0 1p
    N 1
    M 5 5 600+u+f
    G 0.05i
    I @SOEST_block4.png 3i CT
    G 0.05i
    B tt.cpt 0.2i 0.2i -B0
    G 0.05i
    L 9p,Times-Roman R Smith et al., @%5%J. Geophys. Res., 99@%%, 2000
    G 0.1i
    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.
    EOF
    rm -f tt.cpt
    gmt end show


Auto-legends
------------

In modern mode, some modules can access the **-l** option and build the legend
*specfile* from individual entries for each command.  The **-l** option takes an optional
label and allows optional modifiers **+d**, **+g**, **+n**, **+h**, **+j**, **+l**, and **+v**
that follow the corresponding uppercase legend codes discussed above.  In addition,
there is **+f** to set header (H) or label (L) font,  **+s** to set the symbol size (or line length)
to use for the current entry, and **+x** to scale all symbols uniformly (see |-S| above).
Some defaults are hardwired: We draw a white rectangular panel with
a 1 point black outline offset from the justification point (**+j**) by 0.2 cm.  To use
different settings you must call **legend** explicitly before :doc:`end` does so
implicitly instead.  **Note**: With an explicit call to **legend** you can also use |-T| to
save the auto-generate *specfile*, make modification to it, and then pass that to **legend**
directly.

See Also
--------

:doc:`gmt`, :doc:`gmt.conf`,
:doc:`gmtcolors`, :doc:`gmtlogo`
:doc:`basemap`, :doc:`text`,
:doc:`plot`
