| Title: | Extended Legends and Axes for 'ggplot2' | 
| Version: | 0.2.4 | 
| Description: | A 'ggplot2' extension that focusses on expanding the plotter's arsenal of guides. Guides in 'ggplot2' include axes and legends. 'legendry' offers new axes and annotation options, as well as new legends and colour displays. | 
| License: | MIT + file LICENSE | 
| URL: | https://teunbrand.github.io/legendry/, https://github.com/teunbrand/legendry | 
| BugReports: | https://github.com/teunbrand/legendry/issues | 
| Depends: | ggplot2 (≥ 3.5.2), R (≥ 4.1.0) | 
| Imports: | cli, grid (≥ 4.1.0), gtable, lifecycle, rlang (≥ 1.1.0), scales (≥ 1.1.1), vctrs (≥ 0.6.0) | 
| Suggests: | knitr, ragg, rmarkdown, svglite, systemfonts, testthat (≥ 3.0.0), vdiffr, withr | 
| Config/testthat/edition: | 3 | 
| Encoding: | UTF-8 | 
| RoxygenNote: | 7.3.3 | 
| NeedsCompilation: | no | 
| Packaged: | 2025-09-14 09:25:42 UTC; Teun | 
| Author: | Teun van den Brand | 
| Maintainer: | Teun van den Brand <tahvdbrand@gmail.com> | 
| Repository: | CRAN | 
| Date/Publication: | 2025-09-14 09:50:02 UTC | 
legendry: Extended Legends and Axes for 'ggplot2'
Description
 
A 'ggplot2' extension that focusses on expanding the plotter's arsenal of guides. Guides in 'ggplot2' include axes and legends. 'legendry' offers new axes and annotation options, as well as new legends and colour displays.
Author(s)
Maintainer: Teun van den Brand tahvdbrand@gmail.com (ORCID) [copyright holder]
See Also
Useful links:
- Report bugs at https://github.com/teunbrand/legendry/issues 
ggproto objects in legendry
Description
The legendry package relies on an extension system of
ggplot2 through ggproto class objects, which
allow cross-package inheritance of objects such as geoms, stats, facets,
scales and coordinate systems. For the purpose of making plots, users are
invited to wholly ignore these objects, since interacting with these
objects is preferred through various constructor functions. The
legendry package introduces a new <Guide> ggproto class to support
variations on axes, legends and colourbars.
See Also
The documentation over at ggproto.
Bracket options
Description
These functions construct various sorts of brackets. They construct a matrix
that can be supplied as the bracket argument in primitive_bracket().
Usage
bracket_line()
bracket_square()
bracket_chevron()
bracket_round(angle = 180, n = 100)
bracket_sigmoid(curvature = 10, n = 100)
bracket_atan(curvature = 5, n = 100)
bracket_curvy(angle = 225, n = 100)
Arguments
| angle | A  | 
| n | An  | 
| curvature | A  | 
Details
When designing custom bracket shapes, the expectation is both columns are are a number between 0 and 1. The first column follows the direction of the guide whereas the second column is orthogonal to that direction.
Value
A <matrix[n, 2]> with coordinates for points on the brackets.
Functions
-  bracket_line(): A simple line as bracket. Hasn = 2points.
-  bracket_square(): A square bracket. Hasn = 4points.
-  bracket_chevron(): A chevron (V-shape) that makes a bracket. Hasn = 3points.
-  bracket_round(): One circular arc that makes a bracket.
-  bracket_sigmoid(): Two sigmoid curves stacked on top of one another to form a bracket.
-  bracket_atan(): Two arctangent curves stacked on top of one another to form a bracket.
-  bracket_curvy(): Four circular arcs that make a bracket.
Examples
plot(bracket_sigmoid(), type = 'l')
Cap options
Description
These functions construct various sorts of caps. They construct a matrix
that can be supplied as the shape argument in gizmo_barcap().
Usage
cap_triangle()
cap_round(n = 100)
cap_arch(n = 100)
cap_ogee(n = 100)
cap_none()
Arguments
| n | An  | 
Details
When designing custom cap shapes, the expectation is that the first point
starts at the (0, 0) coordinate and the last point ends at the (0, 1)
coordinate. The first column follows the orthogonal direction of the bar
whereas the second column follows the direction of the bar.
Value
A <matrix[n, 2]> with coordinates for points on the brackets.
Functions
-  cap_triangle(): An equilateral triangle withn = 3points.
-  cap_round(): A semicircle.
-  cap_arch(): Two circular arcs forming an equilateral Gothic arch.
-  cap_ogee(): Four circular arcs forming an 'ogee' arch.
-  cap_none(): No cap.
Examples
plot(cap_arch(), type = 'l')
common parameters in legendry
Description
This is a collection of common parameters so they needn't be re-documented each time.
Arguments
| title | A  | 
| theme | A  | 
| position | A  | 
| order | A positive  | 
| available_aes | A  | 
| direction | A  | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| override.aes | A named  | 
Compose guides in a cross
Description
This guide composition has a central guide optionally surrounded by other guides on all four sides.
Usage
compose_crux(
  key = NULL,
  centre = "none",
  left = "none",
  right = "none",
  top = "none",
  bottom = "none",
  args = list(),
  complete = FALSE,
  theme = NULL,
  theme_defaults = list(),
  reverse = FALSE,
  order = 0,
  title = waiver(),
  position = waiver(),
  available_aes = NULL
)
Arguments
| key | A standard key specification. The key is shared
among all guides that have  | 
| centre,left,right,top,bottom | Guides to use in composition per position. Each guide can be specified as one of the following: 
 | 
| args | A  | 
| complete | A  | 
| theme | A  | 
| theme_defaults | A  | 
| reverse | A  | 
| order | A positive  | 
| title | A  | 
| position | Where this guide should be drawn: one of  | 
| available_aes | A  | 
Value
A <ComposeCrux> guide object.
See Also
Other composition: 
compose_ontop(),
compose_sandwich(),
compose_stack(),
guide-composition
Examples
# Roughly recreating a colour bar with extra text on top and bottom
crux <- compose_crux(
  centre = gizmo_barcap(), left = "axis_base",
  right = "axis_base",
  top = primitive_title("A lot"),
  bottom = primitive_title("A little")
)
ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = cty)) +
  guides(colour = crux)
Compose guides on top of one another
Description
This guide can place place other guides on top of one another.
Usage
compose_ontop(
  ...,
  args = list(),
  key = NULL,
  title = waiver(),
  angle = waiver(),
  theme = NULL,
  order = 0,
  position = waiver(),
  available_aes = NULL
)
Arguments
| ... | Guides to stack in composition. Each guide can be specified as one of the following: 
 | 
| args | A  | 
| key | A standard key specification. The key is shared
among all guides that have  | 
| title | A  | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| theme | A  | 
| order | A positive  | 
| position | A  | 
| available_aes | A  | 
Value
A <ComposeOntop> composite guide object.
See Also
Other composition: 
compose_crux(),
compose_sandwich(),
compose_stack(),
guide-composition
Examples
# Using the ontop composition to get two types of ticks with different
# lengths
ggplot(mpg, aes(displ, hwy)) +
  geom_point() +
  guides(x = compose_ontop(
    guide_axis_base(
      key_manual(c(2, 4, 6)),
      theme = theme(
        axis.ticks = element_line(colour = "limegreen"),
        axis.ticks.length = unit(11, "pt")
      )
    ),
    guide_axis_base(
      key_manual(c(3, 5, 7)),
      theme = theme(
        axis.ticks = element_line(colour = "tomato"),
        axis.ticks.length = unit(5.5, "pt")
      )
    )
  ))
Compose guides as a sandwich
Description
This guide composition has a middle guide flanked by two parallel guides.
Usage
compose_sandwich(
  key = key_auto(),
  middle = gizmo_barcap(),
  text = "none",
  opposite = "none",
  args = list(),
  suppress_labels = "opposite",
  complete = TRUE,
  theme = NULL,
  theme_defaults = list(),
  reverse = FALSE,
  order = 0,
  title = waiver(),
  position = waiver(),
  available_aes = NULL
)
Arguments
| key | A standard key specification. The key is shared
among all guides that have  | 
| middle | Guide to use as the middle guide. Each guide can be specified as one of the following: 
 | 
| text,opposite | Guides to use at the  | 
| args | A  | 
| suppress_labels | A  | 
| complete | A  | 
| theme | A  | 
| theme_defaults | A  | 
| reverse | A  | 
| order | A positive  | 
| title | A  | 
| position | Where this guide should be drawn: one of  | 
| available_aes | A  | 
Details
The sandwich composition is effectively the same as a crux composition lacking two opposing arms.
Value
A <ComposeSandwich> guide object.
See Also
Other composition: 
compose_crux(),
compose_ontop(),
compose_stack(),
guide-composition
Examples
# A standard plot with a sandwich guide
ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = cty)) +
  guides(colour = compose_sandwich(
    middle = "colourbar",
    text = "axis_base",
    opposite = primitive_bracket(key = key_range_manual(
      start = c(10, 20), end = c(25, 30), name = c("A", "B")
    ))
  ))
Compose guides as stack
Description
This guide can stack other guides.
Usage
compose_stack(
  ...,
  args = list(),
  key = NULL,
  title = waiver(),
  side.titles = waiver(),
  angle = waiver(),
  theme = NULL,
  order = 0,
  drop = NULL,
  position = waiver(),
  available_aes = NULL
)
Arguments
| ... | Guides to stack in composition. Each guide can be specified as one of the following: 
 | 
| args | A  | 
| key | A standard key specification. The key is shared
among all guides that have  | 
| title | A  | 
| side.titles | A  | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| theme | A  | 
| order | A positive  | 
| drop | An  | 
| position | A  | 
| available_aes | A  | 
Value
A <ComposeStack> guide object.
See Also
Other composition: 
compose_crux(),
compose_ontop(),
compose_sandwich(),
guide-composition
Examples
ggplot() +
  geom_function(fun = dnorm, xlim = c(-3, 3)) +
  guides(x = compose_stack(
    "axis", "axis",
    side.titles = c("first", "second")
  )) +
  # Add margin to make room for side titles
  theme(plot.margin = margin(5.5, 5.5, 5.5, 11))
Guide gizmo: capped colour bar
Description
This guide displays a colour bar with optional caps at either ends of the bar.
Usage
gizmo_barcap(
  key = "sequence",
  shape = "triangle",
  size = NULL,
  show = NA,
  alpha = NA,
  oob = "keep",
  theme = NULL,
  position = waiver(),
  direction = NULL
)
Arguments
| key | A sequence key specification. Defaults to
 | 
| shape | A cap specification by providing one of the following: 
 | 
| size | A  | 
| show | A  | 
| alpha | A  | 
| oob | An out-of-bounds handling function that affects the cap colour. Can be one of the following: 
 | 
| theme | A  | 
| position | A  | 
| direction | A  | 
Value
A <GizmoBarcap> object.
See Also
Other gizmos: 
gizmo_density(),
gizmo_grob(),
gizmo_histogram(),
gizmo_stepcap()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy, colour = cty)) +
  geom_point()
# Just a bar
p + scale_colour_viridis_c(guide = gizmo_barcap())
# Caps show up when there is data outside the limits
p + scale_colour_viridis_c(
  limits = c(10, 30),
  guide  = gizmo_barcap()
)
# The scale's out-of-bounds handler determines cap colour
p + scale_colour_viridis_c(
  limits = c(10, 30), oob = scales::oob_squish,
  guide = gizmo_barcap()
)
# Customising display of the guide
p +
  scale_colour_viridis_c(
    oob = scales::oob_squish,
    guide = gizmo_barcap(
      shape = "arch", show = c(FALSE, TRUE),
      size = unit(2, "cm"),
      theme = theme(legend.key.height = unit(4, "cm"))
    )
  ) +
  theme(
    legend.frame = element_rect(colour = "black"),
    legend.key.width = unit(0.5, "cm")
  )
Guide gizmo: kernel density estimate
Description
This guide displays a kernel density estimate (KDE) of the aesthetic. If the
aesthetic is colour or fill, the shape will reflect this.
Usage
gizmo_density(
  key = waiver(),
  density = NULL,
  density.args = list(),
  density.fun = stats::density,
  just = 0.5,
  oob = "keep",
  alpha = NA,
  theme = NULL,
  position = waiver(),
  direction = NULL
)
Arguments
| key | A sequence key or binned key specification. Internally defaults to a sequence key when the scale is continuous and a binned key when the scale is binned. | 
| density | One of the following: 
 | 
| density.args | A  | 
| density.fun | A  | 
| just | A  | 
| oob | An out-of-bounds handling function that affects the cap colour. Can be one of the following: 
 | 
| alpha | A  | 
| theme | A  | 
| position | A  | 
| direction | A  | 
Details
Non-finite values such as NA and NaN are ignored while infinite values
such as -Inf and Inf are squished to the limits.
Value
A <GizmoDensity> object.
See Also
Other gizmos: 
gizmo_barcap(),
gizmo_grob(),
gizmo_histogram(),
gizmo_stepcap()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy, colour = cty)) +
  geom_point() +
  scale_colour_viridis_c()
# Density from plot data
p + guides(colour = gizmo_density())
# Using bins instead of gradient
p + guides(colour = gizmo_density("bins"))
# Providing custom values to compute density of
p + guides(colour = gizmo_density(density = runif(1000, min = 5, max = 35)))
# Providing a precomputed density
p + guides(colour = gizmo_density(density = density(mpg$cty, adjust = 0.5)))
# Alternatively, parameters may be passed through density.args
p + guides(colour = gizmo_density(density.args = list(adjust = 0.5)))
Guide gizmo: custom grob
Description
This guide displays a user-provided grob.
Usage
gizmo_grob(
  grob,
  width = grobWidth(grob),
  height = grobHeight(grob),
  hjust = 0.5,
  vjust = 0.5,
  position = waiver()
)
Arguments
| grob | A  | 
| width,height | A [ | 
| hjust,vjust | A  | 
| position | Where this guide should be drawn: one of  | 
Value
A <GizmoGrob> object.
See Also
Other gizmos: 
gizmo_barcap(),
gizmo_density(),
gizmo_histogram(),
gizmo_stepcap()
Examples
circle <- grid::circleGrob()
# A standard plot with grob gizmos
ggplot(mpg, aes(displ, hwy, colour = cty)) +
  geom_point() +
  guides(
    x.sec = gizmo_grob(
      circle, hjust = 0.75,
      width = unit(2, "cm"), height = unit(2, "cm")
    ),
    colour = gizmo_grob(
      circle, width = unit(1, "cm"), height = unit(1, "cm")
    )
  )
Guide gizmo: histogram
Description
This guide displays a histogram of the aesthetic. If the aesthetic is
colour or fill, the shape will reflect this.
Usage
gizmo_histogram(
  key = waiver(),
  hist = NULL,
  hist.args = list(),
  hist.fun = graphics::hist,
  just = 1,
  oob = oob_keep,
  metric = "counts",
  alpha = NA,
  theme = NULL,
  position = waiver(),
  direction = NULL
)
Arguments
| key | A sequence key or binned key specification. Internally defaults to a sequence key when the scale is continuous and a binned key when the scale is binned. | 
| hist | One of the following: 
 | 
| hist.args | A  | 
| hist.fun | A  | 
| just | A  | 
| oob | An out-of-bounds handling function that affects the cap colour. Can be one of the following: 
 | 
| metric | A  | 
| alpha | A  | 
| theme | A  | 
| position | A  | 
| direction | A  | 
Details
Non-finite values such as NA and NaN are ignored while infinite values
such as -Inf and Inf are squished to the limits.
Value
A <GizmoHistogram> object.
See Also
Other gizmos: 
gizmo_barcap(),
gizmo_density(),
gizmo_grob(),
gizmo_stepcap()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy, colour = cty)) +
  geom_point() +
  scale_colour_viridis_c()
# Histogram from plot data
p + guides(colour = gizmo_histogram())
# Using bins instead of gradient
p + guides(colour = gizmo_histogram("bins"))
# Providing custom values to compute histogram
p + guides(colour = gizmo_histogram(hist = runif(1000, min = 5, max = 35)))
# Providing precomputed histogram
p + guides(colour = gizmo_histogram(hist = hist(mpg$cty, breaks = 10)))
# Alternatively, parameters may be passed through hist.args
p + guides(colour = gizmo_histogram(hist.arg = list(breaks = 10)))
Guide gizmo: capped colour steps
Description
This guide displays a binned variant of the colour bar with optional caps at either ends of the bar.
Usage
gizmo_stepcap(
  key = "bins",
  shape = "triangle",
  size = NULL,
  show = NA,
  alpha = NA,
  oob = "keep",
  theme = NULL,
  position = waiver(),
  direction = NULL
)
Arguments
| key | A bins key specificiation. Defaults to
 | 
| shape | A cap specification by providing one of the following: 
 | 
| size | A  | 
| show | A  | 
| alpha | A  | 
| oob | An out-of-bounds handling function that affects the cap colour. Can be one of the following: 
 | 
| theme | A  | 
| position | A  | 
| direction | A  | 
Value
A GizmoStepcap object.
See Also
Other gizmos: 
gizmo_barcap(),
gizmo_density(),
gizmo_grob(),
gizmo_histogram()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy, colour = cty)) +
  geom_point()
# Just some recangles
p + scale_colour_viridis_c(guide = gizmo_stepcap())
# Caps show up when there is data outside the limits
p + scale_colour_viridis_c(
  limits = c(10, 30),
  guide = gizmo_stepcap()
)
# The scale's out-of-bounds handler determines cap colour
p + scale_colour_viridis_c(
  limits = c(10, 30), oob = scales::oob_squish,
  guide = gizmo_stepcap()
)
# Customising the display of the guide
p +
  scale_colour_viridis_c(
    oob = scales::oob_squish,
    guide = gizmo_stepcap(
      shape = "round", show = c(FALSE, TRUE),
      size = unit(1, "cm"),
      theme = theme(legend.key.height = unit(4, "cm"))
    )
  ) +
  theme(
    legend.frame = element_rect(colour = "black"),
    legend.key.width = unit(0.5, "cm")
  )
Guide composition
Description
Guide composition is a meta-guide orchestrating an ensemble of other guides. On their own, a 'composing' guide is not very useful as a visual reflection of a scale.
Usage
new_compose(
  guides,
  args = list(),
  ...,
  available_aes = c("any", "x", "y", "r", "theta"),
  call = caller_env(),
  super = Compose
)
Arguments
| guides | A  
 | 
| args | A  | 
| ... | Additional parameters to pass on to
 | 
| available_aes | A  | 
| call | A call to display in messages. | 
| super | A  | 
Value
A <Compose> (sub-)class guide that composes other guides.
See Also
Other composition: 
compose_crux(),
compose_ontop(),
compose_sandwich(),
compose_stack()
Examples
# The `new_compose()` function is not intended to be used directly
my_composition <- new_compose(list("axis", "axis"), super = ComposeStack)
# Is the same as
my_composition <- compose_stack("axis", "axis")
Guide gizmos
Description
Guide gizmos are a speciality guide components that are very specific to one or a few aesthetics to display.
Typically they can be composed with other guides or guide primitives to form a complete guide.
Guide primitives
Description
Guide primitives are the building blocks of more complex guides. On their own, they are not very useful as a visual reflection of a scale.
Their purpose is to be combined with one another to form a more complex, complete guides that do reflect a scale in some way.
Details
The guide primitives are simple, but flexible in that they are not tailored for one particular aesthetic. That way they can be reused and combined at will.
Custom axis guide
Description
This axis guide is a visual representation of position scales and can
represent the x, y, theta and r aesthetics. It differs from
guide_axis() in that it can accept custom keys
and is can act as an axis for coord_radial() like
guide_axis_theta().
Usage
guide_axis_base(
  key = NULL,
  title = waiver(),
  theme = NULL,
  n.dodge = 1,
  check.overlap = FALSE,
  angle = waiver(),
  cap = "none",
  bidi = FALSE,
  order = 0,
  position = waiver()
)
Arguments
| key | A standard key specification. Defaults to
 | 
| title | A  | 
| theme | A  | 
| n.dodge | An positive  | 
| check.overlap | A  | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| cap | A method to cap the axes. One of the following: 
 | 
| bidi | A  | 
| order | A positive  | 
| position | A  | 
Details
Under the hood, this guide is a stack composition of a line, ticks and labels primitives.
To set minor ticks, use key = "minor", or use the type argument in
key_manual() or key_map().
To use this as a logarithmic axis, set key = "log".
Value
A <Guide> object.
See Also
Other standalone guides: 
guide_axis_dendro(),
guide_axis_nested(),
guide_circles(),
guide_colbar(),
guide_colring(),
guide_colsteps(),
guide_legend_base(),
guide_legend_cross(),
guide_legend_group()
Examples
# A standard plot with custom keys
p <- ggplot(mpg, aes(displ, hwy)) +
  geom_point() +
  scale_x_continuous(
    guide = guide_axis_base(key = key_minor())
  ) +
  scale_y_continuous(
    guide = guide_axis_base(key = key_manual(c(20, 25, 30, 40)))
  )
p
# Is translated to theta axis without fuss
p + coord_radial()
# To use as logarithmic axis:
ggplot(msleep, aes(bodywt, brainwt)) +
  geom_point(na.rm = TRUE) +
  scale_x_continuous(
    transform = "log10",
    guide = guide_axis_base("log")
  )
Dendrogram guide
Description
This axis is a speciality axis for discrete data that has been hierarchically clustered. Please be aware that the guide cannot affect the scale limits, which should be set appropriately. This guide will give misleading results when this step is skipped!
Usage
guide_axis_dendro(
  key = "dendro",
  title = waiver(),
  theme = NULL,
  labels = TRUE,
  space = rel(10),
  vanish = TRUE,
  n.dodge = 1,
  angle = waiver(),
  check.overlap = FALSE,
  ticks = "none",
  axis_line = "none",
  order = 0,
  position = waiver()
)
Arguments
| key | A segment key specification. See more information
in the linked topic. Alternatively, an object of class
 | 
| title | A  | 
| theme | A  | 
| labels,ticks,axis_line | Guides to use as labels, ticks or axis lines. Can be specified as one of the following: 
 | 
| space | Either a  | 
| vanish | Only relevant when the guide is used in the secondary theta
position: a  | 
| n.dodge | An positive  | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| check.overlap | A  | 
| order | A positive  | 
| position | A  | 
Value
A <Guide> object.
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_nested(),
guide_circles(),
guide_colbar(),
guide_colring(),
guide_colsteps(),
guide_legend_base(),
guide_legend_cross(),
guide_legend_group()
Examples
# Hierarchically cluster data
clust <- hclust(dist(scale(mtcars)), "ave")
# Using the guide along with appropriate limits
p <- ggplot(mtcars, aes(disp, rownames(mtcars))) +
  geom_col() +
  scale_y_discrete(limits = clust$labels[clust$order])
# Standard usage
p + guides(y = guide_axis_dendro(clust))
# Adding ticks and axis line
p + guides(y = guide_axis_dendro(clust, ticks = "ticks", axis_line = "line")) +
  theme(axis.line = element_line())
# Controlling space allocated to dendrogram
p + guides(y = guide_axis_dendro(clust, space = unit(4, "cm"))) +
  theme(axis.ticks.y.left = element_line("red"))
# If want just the dendrogram, use `labels = FALSE`
p + guides(y = guide_axis_dendro(clust, labels = FALSE), y.sec = "axis")
Nested axis guide
Description
This axis guide gives extra range annotations to position scales. It can be used to infer nesting structure from labels or annotate ranges.
Usage
guide_axis_nested(
  key = "range_auto",
  regular_key = "auto",
  type = "bracket",
  title = waiver(),
  theme = NULL,
  angle = waiver(),
  cap = "none",
  bidi = FALSE,
  oob = "squish",
  drop_zero = TRUE,
  pad_discrete = NULL,
  levels_text = NULL,
  ...,
  order = 0,
  position = waiver()
)
Arguments
| key | One of the following: 
 | 
| regular_key | A standard key specification for the appearance of regular tick marks. | 
| type | Appearance of ranges, either  | 
| title | A  | 
| theme | A  | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| cap | A method to cap the axes. One of the following: 
 | 
| bidi | A  | 
| oob | A method for dealing with out-of-bounds (oob) ranges. Can be one
of  | 
| drop_zero | A  | 
| pad_discrete | A  | 
| levels_text | A list of  | 
| ... | Arguments passed on to  | 
| order | A positive  | 
| position | A  | 
Details
Under the hood, this guide is a stack composition of a line, ticks, optionally labels and either bracket, box or fence primitives.
By default, the key = "range_auto" will incorporate the 0th
level labels inferred from the scale's labels. These labels will look like
regular labels.
To offer other keys the opportunity to display ranges alongside
regular-looking labels, the regular_key argument can be used to setup a
separate key for display in between the ticks and ranges.
Value
A <Guide> object.
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_dendro(),
guide_circles(),
guide_colbar(),
guide_colring(),
guide_colsteps(),
guide_legend_base(),
guide_legend_cross(),
guide_legend_group()
Examples
# A plot with nested categories on the x-axis
p <- ggplot(mpg, aes(interaction(drv, cyl), hwy)) +
  geom_boxplot()
p + guides(x = "axis_nested")
# Apply styling to brackets
p + guides(x = "axis_nested") +
  theme_guide(bracket = element_line("red", linewidth = 1))
# Don't drop nesting indicators that have 0-width
p + guides(x = guide_axis_nested(drop_zero = FALSE))
# Change additional padding for discrete categories
p + guides(x = guide_axis_nested(pad_discrete = 0))
# Change bracket type
p + guides(x = guide_axis_nested(bracket = "curvy"))
# Use boxes instead of brackets + styling of boxes
p + guides(x = guide_axis_nested(type = "box")) +
  theme_guide(box = element_rect("limegreen", "forestgreen"))
# Using fences instead of brackets + styling of fences
p + guides(x = guide_axis_nested(type = "fence", rail = "inner")) +
  theme_guide(
    fence.post = element_line("tomato"),
    fence.rail = element_line("dodgerblue")
  )
# Use as annotation of a typical axis
# `regular_key` controls display of typical axis
ggplot(mpg, aes(displ, hwy)) +
  geom_point() +
  guides(x = guide_axis_nested(
    key = key_range_manual(start = 2:3, end = 5:6, name = c("First", "Second")),
    regular_key = key_manual(c(2, 2.5, 3, 5, 7))
  ))
Circle size guide
Description
This guide displays the sizes of points as a series of circles. It is
typically paired with geom_point() with
draw_key_point() glyphs.
Usage
guide_circles(
  key = NULL,
  title = waiver(),
  theme = NULL,
  hjust = 0.5,
  vjust = 0,
  text_position = NULL,
  clip_text = FALSE,
  override.aes = list(shape = 1),
  position = waiver(),
  direction = NULL
)
Arguments
| key | A standard key specification. Defaults to
 | 
| title | A  | 
| theme | A  | 
| hjust,vjust | A  | 
| text_position | A string, one of  | 
| clip_text | A  | 
| override.aes | A named  | 
| position | A  | 
| direction | A  | 
Details
Please note that the default size scales scale to area, not radius, so equidistant breaks will appear at irregularly spaced positions due to labelling the diameter of a circle.
This graph was designed with standard round shapes
in mind, i.e. shapes 1, 16, 19 and 21. For that reason, shape = 1 is the
default override.aes argument. Other shapes will probably be drawn but the
quality of their alignment and label placement may be unsatisfactory.
Value
A <GuideCircles> object.
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_dendro(),
guide_axis_nested(),
guide_colbar(),
guide_colring(),
guide_colsteps(),
guide_legend_base(),
guide_legend_cross(),
guide_legend_group()
Examples
# A standard plot
p <- ggplot(mtcars, aes(disp, mpg)) +
  geom_point(aes(size = hp), alpha = 0.3)
# By default, the sizes aren't large enough to make this guide clear
p + scale_size_area(guide = "circles")
# Update with a more approrpriate scale
p <- p +
  scale_size_area(
    max_size = 30,
    limits = c(0, NA),
    breaks = c(0, 25, 100, 250)
  )
p + guides(size = "circles")
# Horizontal orientation
p + guides(size = guide_circles(
  vjust = 0.5, hjust = 0, text_position = "bottom"
))
# Alternative text placement
p + guides(size = guide_circles(
  text_position = "ontop",
  clip_text = TRUE
))
# More styling options
p + guides(size = guide_circles(override.aes = aes(colour = "red")))+
  theme(
    # Key background
    legend.key = element_rect(colour = "black", fill = 'white'),
    # Padding around central shapes
    legendry.legend.key.margin = margin(1, 1, 1, 1, "cm"),
    legend.ticks = element_line(colour = "blue"),
    legend.text.position = "left"
  )
Custom colour bar guide
Description
Similar to guide_colourbar(), this guide
displays continuous colour or fill aesthetics. It has additional options
to display caps at the end of the bar, depending on out-of-bounds values.
Usage
guide_colbar(
  title = waiver(),
  key = "auto",
  first_guide = "axis_base",
  second_guide = first_guide,
  shape = "triangle",
  size = NULL,
  show = NA,
  nbin = 15,
  alpha = NA,
  reverse = FALSE,
  suppress_labels = "second",
  oob = scales::oob_keep,
  theme = NULL,
  vanilla = TRUE,
  position = waiver(),
  available_aes = c("colour", "fill")
)
Arguments
| title | A  | 
| key | A sequence key specification. Defaults to
 | 
| first_guide,second_guide | Guides to flank the colour bar. Each guide can be specified using one of the following: 
 The  | 
| shape | A cap specification by providing one of the following: 
 | 
| size | A  | 
| show | A  | 
| nbin | A positive  | 
| alpha | A  | 
| reverse | A  | 
| suppress_labels | A  | 
| oob | An out-of-bounds handling function that affects the cap colour. Can be one of the following: 
 | 
| theme | A  | 
| vanilla | A  | 
| position | A  | 
| available_aes | A  | 
Details
As colours are always rendered as gradients, it is important to use a
graphics device that can render these. This can be checked by using
check_device("gradients").
Value
A <Guide> object
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_dendro(),
guide_axis_nested(),
guide_circles(),
guide_colring(),
guide_colsteps(),
guide_legend_base(),
guide_legend_cross(),
guide_legend_group()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = cty))
# The colourbar shows caps when values are out-of-bounds (oob)
p + scale_colour_viridis_c(
  limits = c(10, NA),
  guide = "colbar"
)
# It also shows how oob values are handled
p + scale_colour_viridis_c(
  limits = c(10, NA), oob = scales::oob_squish,
  guide = "colbar"
)
# Adjusting the type of cap
p + scale_colour_viridis_c(
  limits = c(10, 30), oob = scales::oob_squish,
  guide = guide_colbar(shape = "round")
)
# One-sided ticks
p + scale_colour_viridis_c(
  guide = guide_colbar(second_guide = "none")
)
# Colour bar with minor breaks
p + scale_colour_viridis_c(
  minor_breaks = scales::breaks_width(1),
  guide = guide_colbar(key = "minor")
)
# Using log ticks on a colourbar
ggplot(msleep, aes(sleep_total, sleep_rem)) +
  geom_point(aes(colour = bodywt), na.rm = TRUE) +
  scale_colour_viridis_c(
    transform = "log10",
    guide = guide_colbar(key = "log")
  )
Colour rings and arcs
Description
Similar to guide_colourbar(), this guide
displays continuous colour or fill aesthetics. Instead of a bar, the
gradient in shown in a ring or arc, which can be convenient for cyclical
palettes such as some provided in the scico package.
Usage
guide_colring(
  title = waiver(),
  key = "auto",
  start = 0,
  end = NULL,
  outer_guide = "axis_base",
  inner_guide = "axis_base",
  nbin = 300,
  reverse = FALSE,
  show_labels = "outer",
  theme = NULL,
  vanilla = TRUE,
  position = waiver(),
  available_aes = c("colour", "fill"),
  ...
)
Arguments
| title | A  | 
| key | A standard key specification. Defaults to
 | 
| start,end | A  | 
| outer_guide,inner_guide | Guides to display on the outside and inside of the colour ring. Each guide can be specified using one of the following: 
 | 
| nbin | A positive  | 
| reverse | A  | 
| show_labels | A  | 
| theme | A  | 
| vanilla | A  | 
| position | A  | 
| available_aes | A  | 
| ... | Arguments forwarded to the  | 
Value
A <Guide> object.
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_dendro(),
guide_axis_nested(),
guide_circles(),
guide_colbar(),
guide_colsteps(),
guide_legend_base(),
guide_legend_cross(),
guide_legend_group()
Examples
# Rings works best with a cyclical palette
my_pal <- c("black", "tomato", "white", "dodgerblue", "black")
p <- ggplot(mpg, aes(displ, hwy, colour = cty)) +
  geom_point() +
  scale_colour_gradientn(colours = my_pal)
# Standard colour ring
p + guides(colour = "colring")
# As an arc
p + guides(colour = guide_colring(
  start = 1.25 * pi, end = 2.75 * pi
))
# Removing the inner tick marks
p + guides(colour = guide_colring(inner_guide = "none"))
# Include labels on the inner axis
p + guides(colour = guide_colring(show_labels = "both"))
# Passing an argument to inner/outer guides
p + guides(colour = guide_colring(angle = 0))
Custom colour steps guide
Description
Similar to guide_coloursteps(), this guide
displays continuous colour or fill aesthetics. It has additional options
to display caps at the end of the bar, depending on out-of-bounds values.
Usage
guide_colsteps(
  title = waiver(),
  key = "bins",
  first_guide = "axis_base",
  second_guide = "axis_base",
  shape = "triangle",
  size = NULL,
  show = NA,
  alpha = NA,
  reverse = FALSE,
  suppress_labels = "second",
  oob = scales::oob_keep,
  theme = NULL,
  position = waiver(),
  vanilla = TRUE,
  available_aes = c("colour", "fill")
)
Arguments
| title | A  | 
| key | A bins key specificiation. Defaults to
 | 
| first_guide,second_guide | Guides to flank the colour steps. Each guide can be specified using one of the following: 
 The  | 
| shape | A cap specification by providing one of the following: 
 | 
| size | A  | 
| show | A  | 
| alpha | A  | 
| reverse | A  | 
| suppress_labels | A  | 
| oob | An out-of-bounds handling function that affects the cap colour. Can be one of the following: 
 | 
| theme | A  | 
| position | A  | 
| vanilla | A  | 
| available_aes | A  | 
Details
As steps are rendered as clipped rectangles, it is important to use a
graphics device that can render clipped paths. This can be checked by using
check_device("clippingPaths").
Value
A <Guide> object
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_dendro(),
guide_axis_nested(),
guide_circles(),
guide_colbar(),
guide_colring(),
guide_legend_base(),
guide_legend_cross(),
guide_legend_group()
Examples
p <- ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = cty))
# The colour steps show caps when values are out-of-bounds
p + scale_colour_viridis_b(
  limits = c(10, NA),
  guide = "colsteps"
)
# It also shows how oob values are handled
p + scale_colour_viridis_b(
  limits = c(10, 30), oob = scales::oob_censor,
  guide = "colsteps"
)
# Adjusting the type of cap
p + scale_colour_viridis_b(
  limits = c(10, 30),
  guide = guide_colsteps(shape = "round")
)
# The default is to use the breaks as-is
p + scale_colour_viridis_b(
  limits = c(10, 30), breaks = c(10, 20, 25),
  guide = "colsteps"
)
# But the display can be set to use evenly spaced steps
p + scale_colour_viridis_b(
  limits = c(10, 30), breaks = c(10, 20, 25),
  guide = guide_colsteps(key = key_bins(even.steps = TRUE))
)
# Using tick marks by swapping side guides
p + scale_colour_viridis_b(
  guide = guide_colsteps(
    first_guide  = "axis_base",
    second_guide = "axis_base"
  )
)
Custom legend guide
Description
This legend closely mirrors ggplot2::guide_legend(), but has two
adjustments. First, guide_legend_base() supports a design argument
for a more flexible layout. Secondly, the legend.spacing.y theme element
is observed verbatim instead of overruled.
Usage
guide_legend_base(
  key = NULL,
  title = waiver(),
  theme = NULL,
  design = NULL,
  nrow = NULL,
  ncol = NULL,
  reverse = FALSE,
  override.aes = list(),
  position = NULL,
  direction = NULL,
  order = 0
)
Arguments
| key | A standard key specification. Defaults to
 | 
| title | A  | 
| theme | A  | 
| design | Specification of the legend layout. One of the following: 
 | 
| nrow,ncol | A positive  | 
| reverse | A  | 
| override.aes | A named  | 
| position | A  | 
| direction | A  | 
| order | A positive  | 
Value
A <GuideLegend> object.
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_dendro(),
guide_axis_nested(),
guide_circles(),
guide_colbar(),
guide_colring(),
guide_colsteps(),
guide_legend_cross(),
guide_legend_group()
Other legend guides: 
guide_legend_cross(),
guide_legend_group()
Examples
# A dummy plot
p <- ggplot(data.frame(x = 1:3, type = c("tic", "tac", "toe"))) +
  aes(x, x, shape = type) +
  geom_point(na.rm = TRUE) +
  scale_shape_manual(values = c(1, 4, NA))
# A design string, each character giving a cell value.
# Newlines separate rows, white space is ignored.
design <- "
  123
  213
  321
"
# Alternatively, the same can be specified using a matrix directly
# design <- matrix(c(1, 2, 3, 2, 1, 3, 3, 2, 1), 3, 3, byrow = TRUE)
p + guides(shape = guide_legend_base(design = design))
# Empty cells can be created using `#`
design <- "
  #2#
  1#3
"
# Alternatively:
# design <- matrix(c(NA, 1, 2, NA, NA, 3), nrow = 2)
p + guides(shape = guide_legend_base(design = design))
Cross legend guide
Description
This is a legend type similar to guide_legend()
that displays crosses, or: interactions, between two variables.
Usage
guide_legend_cross(
  key = NULL,
  title = waiver(),
  swap = FALSE,
  col_text = element_text(angle = 90, vjust = 0.5),
  override.aes = list(),
  reverse = FALSE,
  theme = NULL,
  position = NULL,
  direction = NULL,
  order = 0
)
Arguments
| key | One of the following key specifications: 
 | 
| title | A  | 
| swap | A  | 
| col_text | An  | 
| override.aes | A named  | 
| reverse | A  | 
| theme | A  | 
| position | A  | 
| direction | A  | 
| order | A positive  | 
Value
A <GuideLegend> object.
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_dendro(),
guide_axis_nested(),
guide_circles(),
guide_colbar(),
guide_colring(),
guide_colsteps(),
guide_legend_base(),
guide_legend_group()
Other legend guides: 
guide_legend_base(),
guide_legend_group()
Examples
# Standard use for single aesthetic. The default is to split labels to
# disentangle aesthetics that are already crossed (by e.g. `paste()`)
ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = paste(year, drv))) +
  guides(colour = "legend_cross")
# If legends should be merged between identical aesthetics, both need the
# same legend type.
ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = paste(year, drv), shape = paste(year, drv))) +
  guides(colour = "legend_cross", shape = "legend_cross")
# Crossing two aesthetics requires a shared title and `key = "auto"`. The
# easy way to achieve this is to predefine a shared guide.
my_guide <- guide_legend_cross(key = "auto", title = "My title")
ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = drv, shape = factor(year))) +
  guides(colour = my_guide, shape  = my_guide)
# You can cross more than 2 aesthetics but not more than 2 unique aesthetics.
ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = drv, shape = factor(year), size = factor(drv))) +
  scale_size_ordinal() +
  guides(colour = my_guide, shape = my_guide, size = my_guide)
# You can merge an aesthetic that is already crossed with an aesthetic that
# contributes to only one side of the cross.
ggplot(mpg, aes(displ, hwy)) +
  geom_point(aes(colour = paste(year, drv), shape  = drv)) +
  guides(
    colour = guide_legend_cross(title = "My Title"),
    shape  = guide_legend_cross(title = "My Title", key = "auto")
  )
Grouped legend
Description
This legend resembles ggplot2::guide_legend(), but has the ability to
keep groups in blocks with their own titles.
Usage
guide_legend_group(
  key = "group_split",
  title = waiver(),
  override.aes = list(),
  nrow = NULL,
  ncol = NULL,
  theme = NULL,
  position = NULL,
  direction = NULL,
  order = 0
)
Arguments
| key | A group key specification. Defaults to
 | 
| title | A  | 
| override.aes | A named  | 
| nrow,ncol | A positive  | 
| theme | A  | 
| position | A  | 
| direction | A  | 
| order | A positive  | 
Value
A <GuideLegend> object.
See Also
Other standalone guides: 
guide_axis_base(),
guide_axis_dendro(),
guide_axis_nested(),
guide_circles(),
guide_colbar(),
guide_colring(),
guide_colsteps(),
guide_legend_base(),
guide_legend_cross()
Other legend guides: 
guide_legend_base(),
guide_legend_cross()
Examples
# Standard plot for selection of `msleep`
df <- msleep[c(9, 28, 11, 5, 34, 54, 64, 24, 53), ]
p <- ggplot(df) +
  aes(bodywt, awake, colour = paste(order, name)) +
  geom_point()
# By default, groups are inferred from the name
p + guides(colour = "legend_group")
# You can also use a look-up table for groups
# The lookup table can be more expansive than just the data:
# We're using the full 'msleep' data here instead of the subset
lut <- key_group_lut(msleep$name, msleep$order)
p + aes(colour = name) +
  guides(colour = guide_legend_group(key = lut))
# `nrow` and `ncol` apply within groups
p + guides(colour = guide_legend_group(nrow = 1))
# Groups are arranged according to `direction`
p + guides(colour = guide_legend_group(ncol = 1, direction = "horizontal")) +
  theme(legend.title.position = "top")
# Customising the group titles
p + guides(colour = "legend_group") +
  theme(
    legendry.legend.subtitle.position = "left",
    legendry.legend.subtitle = element_text(
      hjust = 1, vjust = 1, size = rel(0.9),
      margin = margin(t = 5.5, r = 5.5)
    )
  )
# Changing the spacing between groups
p + guides(colour = "legend_group") +
  theme(legendry.group.spacing = unit(0, "cm"))
Group keys
Description
These functions are helper functions for working with grouped data as keys in guides. They all share the goal of creating a guide key, but have different methods.
-  key_group_split()is a function factory whose functions make an attempt to infer groups from the scale's labels.
-  key_group_lut()is a function factory whose functions use a look up table to sort out group membership.
Usage
key_group_split(sep = "[^[:alnum:]]+", reverse = FALSE)
key_group_lut(members, group, ungrouped = "Other")
Arguments
| sep | A  | 
| reverse | A  | 
| members | A vector including the scale's  | 
| group | A vector parallel to  | 
| ungrouped | A  | 
Value
A function to use as the key argument in a guide.
See Also
Other keys: 
key_range,
key_segments,
key_specialty,
key_standard
Examples
# Example scale
values <- c("group A:value 1", "group A:value 2", "group B:value 1")
template <- scale_colour_hue(limits = values)
# Treat the 'group X' part as groups
key <- key_group_split(sep = ":")
key(template)
# Treat the 'value X' part as groups
key <- key_group_split(sep = ":", reverse = TRUE)
key(template)
# Example scale
template <- scale_colour_hue(limits = msleep$name[c(1, 7, 9, 23, 24)])
# A lookup table can have more entries than needed
key <- key_group_lut(msleep$name, msleep$order)
key(template)
# Or less entries than needed
key <- key_group_lut(
  msleep$name[23:24], msleep$order[23:24],
  ungrouped = "Other animals"
)
key(template)
Range keys
Description
These functions are helper functions for working with ranged data as keys in guides. They all share the goal creating of a guide key, but have different methods:
-  key_range_auto()is a function factory whose functions make an attempt to infer ranges from the scale's labels.
-  key_range_manual()uses user-provided vectors to set ranges.
-  key_range_map()makes mappings from a<data.frame>to set ranges.
Usage
key_range_auto(sep = "[^[:alnum:]]+", reverse = FALSE, ...)
key_range_manual(start, end, name = NULL, level = NULL, ...)
key_range_map(data, ..., .call = caller_env())
Arguments
| sep | A  | 
| reverse | A  | 
| ... | 
 | 
| start,end | A vector that can be interpreted by the scale, giving the start and end positions of each range respectively. | 
| name | A  | 
| level | An  | 
| data | A  | 
| .call | A call to display in messages. | 
Details
The level variable is optional and when missing, the guides use an
algorithm similar to IRanges::disjointBins() to avoid overlaps.
The key_range_auto() does not work with expression labels.
Value
For key_range_auto() a function. For key_range_manual() and
key_range_map() a <data.frame> with the <key_range> class.
See Also
Other keys: 
key_group,
key_segments,
key_specialty,
key_standard
Examples
# Example scale
template <- scale_x_discrete(limits = c("A 1", "B 1", "C&1", "D&2", "E&2"))
# By default, splits on all non-alphanumeric characters
auto <- key_range_auto()
auto(template)
# Only split on a specific character
auto <- key_range_auto(sep = "&")
auto(template)
# Treating the letters as outer labels and numbers as inner labels
auto <- key_range_auto(reverse = TRUE)
auto(template)
# Providing custom values
key_range_manual(
  start = c(1, 5,  10),
  end   = c(4, 15, 11),
  level = c(0, 2, 1),
  name  = c("A", "B", "C")
)
# Values from a <data.frame>
key_range_map(presidential, start = start, end = end, name = name)
Segment keys
Description
These functions are helper functions for working with segment data as keys in guides. They all share the goal of creating a guide key, but have different methods:
-  key_segment_manual()directly uses user-provided vectors to set segments.
-  key_segment_map()makes mappings from a<data.frame>to set segments.
-  key_dendro()is a specialty case for coercing dendrogram data to segments. Be aware that setting the key alone cannot affect the scale limits, and will give misleading results when used incorrectly!
Usage
key_segment_manual(value, oppo, value_end = value, oppo_end = oppo, ...)
key_segment_map(data, ..., .call = caller_env())
key_dendro(dendro = NULL, type = "rectangle")
Arguments
| value,value_end | A vector that is interpreted to be along the scale that the guide codifies. | 
| oppo,oppo_end | A vector that is interpreted to be orthogonal to the
 | 
| ... | 
 | 
| data | A  | 
| .call | A call to display in messages. | 
| dendro | A data structure that can be coerced to a dendrogram through
the  | 
| type | A string, either  | 
Value
For key_segments_manual() and key_segments_map(), a <data.frame> with
the <key_range> class.
See Also
Other keys: 
key_group,
key_range,
key_specialty,
key_standard
Examples
# Giving vectors directly
key_segment_manual(
  value = 0:1, value_end = 2:3,
  oppo  = 1:0, oppo_end  = 3:2
)
# Taking columns of a data frame
data <- data.frame(x = 0:1, y = 1:0, xend = 2:3, yend = 3:2)
key_segment_map(data, value = x, oppo = y, value_end = xend, oppo_end = yend)
# Using dendrogram data
clust <- hclust(dist(USArrests), "ave")
key_dendro(clust)(scale_x_discrete())
Speciality keys
Description
These functions are helper functions for working with keys in guides. The functions described here are not widely applicable and may only apply to a small subset of guides. As such, it is fine to adjust the arguments of a speciality key, but swapping types is ill-advised.
-  key_sequence()is a function factory whose functions create a regularly spaced sequence between the limits of a scale. It is used in colour bar guides.
-  key_bins()is a function factory whose function create a binned key given the breaks in the scale. It is used in colour steps guides.
Usage
key_sequence(n = 15)
key_bins(even.steps = FALSE, show.limits = NULL)
Arguments
| n | A positive  | 
| even.steps | A  | 
| show.limits | A  | 
Value
For key_sequence() a function.
See Also
Other keys: 
key_group,
key_range,
key_segments,
key_standard
Examples
# An example scale
template <- scale_fill_viridis_c(limits = c(0, 10), breaks = c(2, 4, 6, 8))
# Retrieving colourbar and colourstep keys
key_sequence()(template)
key_bins()(template)
Standard keys
Description
These functions are helper functions for working with tick marks as keys in guides. They all share the goal of creating a guide key, but have different outcomes:
-  key_auto()is a function factory whose functions extract a typical key from major breaks in a scale.
-  key_manual()uses user-provided vectors to make a key.
-  key_map()makes mappings from a<data.frame>to make a key.
-  key_minor()is a function factory whose functions also extract minor break positions for minor tick marks.
-  key_log()is a function factory whose functions place ticks at intervals in log10 space.
-  key_none()makes an empty key with no entries.
Usage
key_auto(...)
key_manual(
  aesthetic,
  value = aesthetic,
  label = as.character(value),
  type = NULL,
  ...
)
key_map(data, ..., .call = caller_env())
key_minor(...)
key_log(
  prescale_base = NULL,
  negative_small = 0.1,
  expanded = TRUE,
  labeller = NULL,
  ...
)
key_none()
Arguments
| ... | 
 | 
| aesthetic,value | A vector of values for the guide to represent
equivalent to the  | 
| label | A  | 
| type | A  | 
| data | A  | 
| .call | A call to display in messages. | 
| prescale_base | A  | 
| negative_small | A  | 
| expanded | A  | 
| labeller | A  | 
Value
For key_auto(), key_minor() and key_log() a function. For
key_manual() and key_map() a <data.frame> with the <key_standard>
class.
See Also
Other keys: 
key_group,
key_range,
key_segments,
key_specialty
Examples
# An example scale
template <- scale_x_continuous(limits = c(0, 10))
# The auto, minor and log keys operate on scales
key_auto()(template)
key_minor()(template)
# So does the log key
template <- scale_x_continuous(transform = "log10", limits = c(0.1, 10))
key_log()(template)
# Providing custom values
key_manual(
  aesthetic = 1:5,
  label = c("one", "two", "three", "four", "five")
)
# Values from a `<data.frame>`
key_map(ToothGrowth, aesthetic = unique(supp))
# Empty key
key_none()
Guide primitives: boxes
Description
This function constructs a boxes guide primitive.
Usage
primitive_box(
  key = "range_auto",
  angle = waiver(),
  oob = "squish",
  drop_zero = TRUE,
  pad_discrete = 0.4,
  min_size = NULL,
  levels_box = NULL,
  levels_text = NULL,
  theme = NULL,
  position = waiver()
)
Arguments
| key | A range key specification. See more information in the linked topic. | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| oob | A method for dealing with out-of-bounds (oob) ranges. Can be one
of  | 
| drop_zero | A  | 
| pad_discrete | A  | 
| min_size | A [ | 
| levels_box | A list of  | 
| levels_text | A list of  | 
| theme | A  | 
| position | A  | 
Value
A <PrimitiveBox> primitive guide that can be used inside other
guides.
Styling options
Below are the theme options that determine the styling of this guide, which may differ depending on whether the guide is used in an axis or in a legend context.
Common to both types is the following:
-  legendry.boxan<element_rect>for the boxes to draw.
As an axis guide
-  axis.text.{x/y}.{position}an<element_text>for the text inside the boxes.
As a legend guide
-  legend.textan<element_text>for the text inside the boxes.
See Also
Other primitives: 
primitive_bracket(),
primitive_fence(),
primitive_labels(),
primitive_line(),
primitive_segments(),
primitive_spacer(),
primitive_ticks(),
primitive_title()
Examples
# A standard plot
p <- ggplot(mpg, aes(interaction(drv, year), displ)) +
 geom_point()
key <- key_range_manual(c(2, 4), c(5, 6), c("A", "B"))
# Adding as secondary guides
p + guides(
  x.sec = primitive_box(),
  y.sec = primitive_box(key = key)
)
Guide primitive: brackets
Description
This function constructs a brackets guide primitive.
Usage
primitive_bracket(
  key = "range_auto",
  bracket = "line",
  angle = waiver(),
  oob = "squish",
  drop_zero = TRUE,
  pad_discrete = 0.4,
  levels_brackets = NULL,
  levels_text = NULL,
  theme = NULL,
  position = waiver()
)
Arguments
| key | A range key specification. See more information in the linked topic. | 
| bracket | A bracket by providing one of the following: 
 | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| oob | A method for dealing with out-of-bounds (oob) ranges. Can be one
of  | 
| drop_zero | A  | 
| pad_discrete | A  | 
| levels_brackets | A list of  | 
| levels_text | A list of  | 
| theme | A  | 
| position | A  | 
Value
A <PrimitiveBracket> primitive guide that can be used inside other
guides.
Styling options
Below are the theme options that determine the styling of this guide, which may differ depending on whether the guide is used in an axis or a legend context.
Common to both types is the following:
-  legendry.bracketan<element_line>for the line used to draw the brackets.
-  legendry.backet.sizea<unit>setting the space afforded to a bracket.
As an axis guide
-  axis.text.{x/y}.{position}an<element_text>for the text displayed over the brackets.
As a legend guide
-  legend.textan<element_text>for the text displayed over the brackets.
See Also
Other primitives: 
primitive_box(),
primitive_fence(),
primitive_labels(),
primitive_line(),
primitive_segments(),
primitive_spacer(),
primitive_ticks(),
primitive_title()
Examples
# A standard plot
p <- ggplot(mpg, aes(interaction(drv, year), displ)) +
 geom_point()
key <- key_range_manual(c(2, 4), c(5, 6), c("A", "B"))
# Adding as secondary guides
p + guides(
  x.sec = primitive_bracket(),
  y.sec = primitive_bracket(key = key)
)
Guide primitive: fence
Description
This function constructs a fence guide primitive. The customisation options are easier to understand if we view fence 'post' as the vertical pieces of a real world fence, and the 'rail' as the horizontal pieces.
Usage
primitive_fence(
  key = "range_auto",
  rail = "none",
  angle = waiver(),
  oob = "squish",
  drop_zero = TRUE,
  pad_discrete = 0.5,
  levels_text = NULL,
  levels_post = NULL,
  levels_rail = NULL,
  theme = NULL,
  position = waiver()
)
Arguments
| key | A range key specification. See more information in the linked topic. | 
| rail | A  | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| oob | A method for dealing with out-of-bounds (oob) ranges. Can be one
of  | 
| drop_zero | A  | 
| pad_discrete | A  | 
| levels_text | A list of  | 
| levels_post,levels_rail | A list of  | 
| theme | A  | 
| position | A  | 
Value
A <PrimitiveFence> primitive guie that can be used inside other
guides.
Styling options
Below are the theme options that determine the styling of this guide, which may differ depending on whether the guide is used in an axis or legend context.
Common to both types is the following:
-  legendry.fence.postan<element_line>for the line used to draw the pieces orthogonal to the direction of the scale.
-  legendry.fence.railan<element_line>for the line used to draw the pieces parallel to the direction of the scale.
As an axis guide
-  axis.text.{x/y}.{position}an<element_text>for the text displayed.
As a legend guide
-  legend.textan<element_text>for the text displayed.
See Also
Other primitives: 
primitive_box(),
primitive_bracket(),
primitive_labels(),
primitive_line(),
primitive_segments(),
primitive_spacer(),
primitive_ticks(),
primitive_title()
Examples
# A standard plot
p <- ggplot(mpg, aes(interaction(drv, year), displ)) +
  geom_point()
key <- key_range_manual(c(2, 4), c(5, 6), c("A", "B"))
# Adding as secondary guides
p + guides(
  x.sec = primitive_fence(rail = "inner"),
  y.sec = primitive_fence(key = key, rail = "outer")
)
Guide primitive: labels
Description
This function constructs a labels guide primitive.
Usage
primitive_labels(
  key = NULL,
  angle = waiver(),
  n.dodge = 1,
  check.overlap = FALSE,
  theme = NULL,
  position = waiver()
)
Arguments
| key | A standard key specification. See more information in the linked topic. | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| n.dodge | An positive  | 
| check.overlap | A  | 
| theme | A  | 
| position | A  | 
Value
A <PrimitiveLabels> primitive guide that can be used inside other
guides.
Styling options
Below are the theme options that determine the styling of this guide, which may differ depending on whether the guide is used in an axis or in a legend context.
As an axis guide
-  axis.text.{x/y}.{position}an<element_text>for the display of the labels.
As a legend guide.
-  legend.textan<element_text>for the display of the labels.
See Also
Other primitives: 
primitive_box(),
primitive_bracket(),
primitive_fence(),
primitive_line(),
primitive_segments(),
primitive_spacer(),
primitive_ticks(),
primitive_title()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy)) +
 geom_point()
# Adding as secondary guides
p + guides(
  x.sec = primitive_labels(),
  y.sec = primitive_labels(n.dodge = 2)
)
Guide primitive: line
Description
This function constructs a line guide primitive.
Usage
primitive_line(key = NULL, cap = "none", theme = NULL, position = waiver())
Arguments
| key | A standard key specification. See more information in the linked topic. | 
| cap | A method to cap the axes. One of the following: 
 | 
| theme | A  | 
| position | A  | 
Value
A PrimitiveLine primitive guide that can be used inside other
guides.
Styling options
Below are the theme options that determine the styling of this guide, which may differ depending on whether the guide is used in an axis or in a legend context.
As an axis guide
-  axis.line.{x/y}.{position}an<element_line>for the line style.
As a legend guide
-  legend.axis.linean<element_line>for the line style.
See Also
Other primitives: 
primitive_box(),
primitive_bracket(),
primitive_fence(),
primitive_labels(),
primitive_segments(),
primitive_spacer(),
primitive_ticks(),
primitive_title()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy)) +
  geom_point() +
  theme(axis.line = element_line())
# Adding as secondary guides
p + guides(
  x.sec = primitive_line(),
  y.sec = primitive_line(cap = "both")
)
Guide primitives: segments
Description
This function constructs a guide primitive.
Usage
primitive_segments(
  key = NULL,
  space = rel(10),
  vanish = FALSE,
  theme = NULL,
  position = waiver()
)
Arguments
| key | A segment key specification. See more information
in the linked topic. Alternatively, an object of class
 | 
| space | Either a  | 
| vanish | Only relevant when the guide is used in the secondary theta
position: a  | 
| theme | A  | 
| position | A  | 
Value
A <PrimitiveSegments> primitive guide that can be used inside other
guides.
Styling options
Below are the theme options that determine the style of this guide, which may differ depending on whether the guide is used in an axis or in a legend context.
As an axis guide
-  axis.ticks.{x/y}.{position}an<element_line>for display of the segments.
-  axis.ticks.length.{x/y}.{position}a<unit>for the base size of the segments in the orthogonal direction.
As a legend guide
-  legend.ticksan<element_line>for display of the segments.
-  legend.ticks.lengtha<unit>for the base size of the segments in the orthogonal direction.
See Also
Other primitives: 
primitive_box(),
primitive_bracket(),
primitive_fence(),
primitive_labels(),
primitive_line(),
primitive_spacer(),
primitive_ticks(),
primitive_title()
Examples
# Building a key
key <- key_segment_manual(
  value     = c(1.6, 1.6, 3.4, 5.2),
  value_end = c(7.0, 7.0, 3.4, 5.2),
  oppo      = c(1.0, 2.0, 0.0, 0.0),
  oppo_end  = c(1.0, 2.0, 3.0, 3.0)
)
# Using the primitive in a plot
ggplot(mpg, aes(displ, hwy)) +
  geom_point() +
  scale_x_continuous(
    guide = primitive_segments(key = key)
  )
Guide primitive: spacer
Description
This function constructs a spacer guide primitive.
Usage
primitive_spacer(
  space = NULL,
  title = waiver(),
  theme = NULL,
  position = waiver()
)
Arguments
| space | A [ | 
| title | A  | 
| theme | A  | 
| position | A  | 
Value
A <PrimitiveSpacer> primitive guide that can be used inside
other guides.
Styling options
#' Below are the theme options that determine the styling of this guide. This guide does not have option dependent on its role as axis or legend.
-  legendry.guide.spacingA<unit>setting the amount of spacing when thespaceargument isNULL.
See Also
Other primitives: 
primitive_box(),
primitive_bracket(),
primitive_fence(),
primitive_labels(),
primitive_line(),
primitive_segments(),
primitive_ticks(),
primitive_title()
Examples
ggplot(mpg, aes(displ, hwy)) +
  geom_point() +
  guides(
    x = guide_axis_stack("axis", primitive_spacer(unit(1, "cm")), "axis")
  )
Guide primitive: line
Description
This function constructs a ticks guide primitive.
Usage
primitive_ticks(key = NULL, bidi = FALSE, theme = NULL, position = waiver())
Arguments
| key | A standard key specification. See more information in the linked topic. | 
| bidi | A  | 
| theme | A  | 
| position | A  | 
Value
A PrimitiveTicks primitive guide that can be used inside other
guides.
Styling options
Below are the theme options that determine the styling of this guide, which may differ depending on whether the guide is used in an axis or in a legend context.
Common to both types is the following:
As an axis guide
-  axis.ticks.{x/y}.{position}an<element_line>for major tick lines.
-  axis.minor.ticks.{x/y}.{position}an<element_line>for minor tick lines.
-  legendry.axis.mini.ticksan<element_line>internally inheriting from the minor ticks for the smallest ticks in e.g. log axes.
-  axis.ticks.length.{x/y}.{position}a<unit>for the major ticks length.
-  axis.minor.ticks.length.{x/y}.{position}a<unit>for the minor ticks length.
-  legendry.axis.mini.ticks.lengtha<unit>internally inheriting from the minor tick length for the smallest ticks in e.g. log axes.
As a legend guide
-  legend.ticksan<element_line>for major tick lines.
-  legendry.legend.minor.ticksan<element_line>for minor tick lines.
-  legendry.legend.mini.ticksan<element_line>for the smallest ticks in e.g. log axes.
-  legend.ticks.lengtha<unit>for the major ticks length.
-  legendry.legend.minor.ticks.lengtha<unit>for the minor ticks length.
-  legendry.legend.mini.ticks.lengtha<unit>for the smallest ticks in e.g. log axes.
See Also
Other primitives: 
primitive_box(),
primitive_bracket(),
primitive_fence(),
primitive_labels(),
primitive_line(),
primitive_segments(),
primitive_spacer(),
primitive_title()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy)) +
  geom_point()
# Adding as secondary guides
p + guides(x.sec = primitive_ticks(), y.sec = primitive_ticks())
Guide primitive: title
Description
This function constructs a title guide primitive.
Usage
primitive_title(
  title = waiver(),
  angle = waiver(),
  theme = NULL,
  position = waiver()
)
Arguments
| title | A  | 
| angle | A specification for the text angle. Compared to setting the  
 | 
| theme | A  | 
| position | A  | 
Value
A <PrimitiveTitle> primitive guide that can be used inside other
guides.
Styling options
Below are the theme options that determine the styling of this guide, which may differ depending on whether the guide is used in an axis or in a legend context.
As an axis guide
-  axis.title.{x/y}.{position}an<element_text>for the title display.
As a legend guide
-  legend.titlean<element_text>for the title display.
See Also
Other primitives: 
primitive_box(),
primitive_bracket(),
primitive_fence(),
primitive_labels(),
primitive_line(),
primitive_segments(),
primitive_spacer(),
primitive_ticks()
Examples
# A standard plot
p <- ggplot(mpg, aes(displ, hwy)) +
 geom_point()
# Adding as secondary guides
p + guides(
  x.sec = primitive_title("Horizontal Title"),
  y.sec = primitive_title(c("along vertical", "Multiple tiles"))
)
Dendrogram scales
Description
These are speciality scales for use with hierarchically clustered data. The scale automatically orders the limits according to the clustering result and comes with a dendrogram axis.
Usage
scale_x_dendro(
  clust,
  ...,
  expand = waiver(),
  guide = "axis_dendro",
  position = "bottom"
)
scale_y_dendro(
  clust,
  ...,
  expand = waiver(),
  guide = "axis_dendro",
  position = "left"
)
Arguments
| clust | A data structure that can be coerced to an
 | 
| ... | Arguments passed on to  
 | 
| expand | For position scales, a vector of range expansion constants used to add some
padding around the data to ensure that they are placed some distance
away from the axes. Use the convenience function  | 
| guide | A function used to create a guide or its name. See
 | 
| position | For position scales, The position of the axis.
 | 
Details
The scale limits are determined by the order and labels in the clust
argument. While limits is not an argument in these scales, the breaks
argument can still be used to selectively omit some breaks and the labels
can be used for formatting purposes.
Value
A <ScaleDiscretePosition> object that can be added to a plot.
See Also
Examples
# Hierarchically cluster data, separately for rows and columns
car_clust <- hclust(dist(scale(mtcars)), "ave")
var_clust <- hclust(dist(scale(t(mtcars))), "ave")
long_mtcars <- data.frame(
  car = rownames(mtcars)[row(mtcars)],
  var = colnames(mtcars)[col(mtcars)],
  value = as.vector(scale(mtcars))
)
# A standard heatmap adorned with dendrograms
p <- ggplot(long_mtcars, aes(var, car, fill = value)) +
  geom_tile() +
  scale_x_dendro(var_clust) +
  scale_y_dendro(car_clust)
p
# Styling the dendrograms
p +
  guides(
    y = guide_axis_dendro(key_dendro(type = "triangle")),
    x = guide_axis_dendro(space = rel(5))
  ) +
  theme(
    axis.text.y.left = element_text(margin = margin(r = 3, l = 3)),
    axis.ticks.y = element_line("red"),
    axis.ticks.x = element_line(linetype = "dotted")
  )
# In polar coordinates, plus some formatting
p +
  coord_radial(
    theta = "y", inner.radius = 0.5,
    start = 0.25 * pi, end = 1.75 * pi
  ) +
  guides(
    theta = primitive_labels(angle = 90),
    theta.sec = primitive_segments("dendro", vanish = TRUE),
    r = guide_axis_dendro(angle = 0)
  )
Theme wrapper for guides
Description
This function has shorthand names for theme elements relating to guides. It
is intended to be used as the guide_*(theme) argument. Because of this
intent, and due to legends and axes having mutually exclusive theme elements,
this function sets the elements for both simultaneously.
Usage
theme_guide(
  text = NULL,
  line = NULL,
  title = NULL,
  subtitle = NULL,
  text.position = NULL,
  title.position = NULL,
  subtitle.position = NULL,
  ticks = NULL,
  minor.ticks = NULL,
  mini.ticks = NULL,
  ticks.length = NULL,
  minor.ticks.length = NULL,
  mini.ticks.length = NULL,
  spacing = NULL,
  group.spacing = NULL,
  key = NULL,
  key.size = NULL,
  key.width = NULL,
  key.height = NULL,
  key.spacing = NULL,
  key.spacing.x = NULL,
  key.spacing.y = NULL,
  key.margin = NULL,
  frame = NULL,
  byrow = NULL,
  background = NULL,
  margin = NULL,
  bracket = NULL,
  bracket.size = NULL,
  box = NULL,
  fence = NULL,
  fence.post = NULL,
  fence.rail = NULL
)
Arguments
| text | An  | 
| line | An  | 
| title | An  | 
| subtitle | An  | 
| text.position,title.position,subtitle.position | One of  
 | 
| ticks | An  | 
| minor.ticks | An  | 
| mini.ticks | An  | 
| ticks.length,minor.ticks.length,mini.ticks.length | A
[ 
 | 
| spacing,group.spacing | A [ | 
| key | An  | 
| key.size,key.width,key.height | A  | 
| key.spacing,key.spacing.x,key.spacing.y | A [ | 
| key.margin | A  | 
| frame | An  | 
| byrow | A  | 
| background | An  | 
| margin | A  | 
| bracket | An  | 
| bracket.size | A [ | 
| box | An  | 
| fence,fence.post,fence.rail | An
 | 
Value
A <theme> object that can be provided to a guide.
Examples
red_ticks <- theme_guide(ticks = element_line(colour = "red", linewidth = 0.5))
# Both axis and colourbar gain red ticks
ggplot(mpg, aes(displ, hwy, colour = cty)) +
  geom_point() +
  guides(
    colour = guide_colourbar(theme = red_ticks),
    x = guide_axis(theme = red_ticks)
  )