A wrapper around `theme()` which provides several shortcuts to setting common options and several defaults. See more in Details.
theme_ptrr(
  gridlines = c("y", "x", "both", "scatter", "none"),
  base_size = 11,
  family = "IBM Plex Sans Condensed",
  title_family = "IBM Plex Sans",
  multiplot = FALSE,
  tonecol = ptclr_l,
  margin_side = 6,
  margin_bottom = 6,
  plot.title.position = "plot",
  axis_titles = c("none", "y", "x", "both"),
  richtext = FALSE,
  richtext_style = NULL,
  map = FALSE,
  inverse = FALSE,
  ...
)Whether to display major gridlines along `"y"` (the default), `"x"`, `"both"`, or draw a `"scatter"`, which has both gridlines and inverted colours.
Numeric text size in pts, affects all text in plot. Defaults to 11.
font family to use for the (title of the) plot. Defaults to `"IBM Plex Sans"` for title and `"IBM Plex Sans Condensed"` for plot.
if set to TRUE, provides better styling for small multiples created using `facet_*`.
Color for panel/plot background.
size of left and right / bottom margin around plot, in pts. Defaults to 6. Set to 0 to align flush with text in a Word document.
where to align the title. Either "plot" (the default, difference from `theme()` default) or `"panel"`.
whether to display axis titles: `"none"` (default), `"x"`, `"y"`, or `"both"`.
Whether to render labels using marquee. Defaults to FALSE.
Marquee style object to use in richtext fields
if set to TRUE, provides better styling for maps created using `geom_sf()`. Overrides `gridlines`.
Create plot with plot background in tonecol and white panel bg.
Arguments passed on to ggplot2::theme
lineall line elements (element_line())
rectall rectangular elements (element_rect())
titleall title elements: plot, axes, legends (element_text();
inherits from text)
aspect.ratioaspect ratio of the panel
axis.text,axis.text.x,axis.text.y,axis.text.x.top,axis.text.x.bottom,axis.text.y.left,axis.text.y.right,axis.text.theta,axis.text.rtick labels along axes (element_text()). Specify all axis tick labels (axis.text),
tick labels by plane (using axis.text.x or axis.text.y), or individually
for each axis (using axis.text.x.bottom, axis.text.x.top,
axis.text.y.left, axis.text.y.right). axis.text.*.* inherits from
axis.text.* which inherits from axis.text, which in turn inherits
from text
axis.ticks,axis.ticks.x,axis.ticks.x.top,axis.ticks.x.bottom,axis.ticks.y,axis.ticks.y.left,axis.ticks.y.right,axis.ticks.theta,axis.ticks.rtick marks along axes (element_line()). Specify all tick marks (axis.ticks),
ticks by plane (using axis.ticks.x or axis.ticks.y), or individually
for each axis (using axis.ticks.x.bottom, axis.ticks.x.top,
axis.ticks.y.left, axis.ticks.y.right). axis.ticks.*.* inherits from
axis.ticks.* which inherits from axis.ticks, which in turn inherits
from line
axis.minor.ticks.x.top,axis.minor.ticks.x.bottom,axis.minor.ticks.y.left,axis.minor.ticks.y.right,axis.minor.ticks.theta,axis.minor.ticks.rminor tick marks along axes (element_line()). axis.minor.ticks.*.*
inherit from the corresponding major ticks axis.ticks.*.*.
axis.ticks.length,axis.ticks.length.x,axis.ticks.length.x.top,axis.ticks.length.x.bottom,axis.ticks.length.y,axis.ticks.length.y.left,axis.ticks.length.y.right,axis.ticks.length.theta,axis.ticks.length.rlength of tick marks (unit)
axis.minor.ticks.length,axis.minor.ticks.length.x,axis.minor.ticks.length.x.top,axis.minor.ticks.length.x.bottom,axis.minor.ticks.length.y,axis.minor.ticks.length.y.left,axis.minor.ticks.length.y.right,axis.minor.ticks.length.theta,axis.minor.ticks.length.rlength of minor tick marks (unit), or relative to axis.ticks.length when provided with rel().
axis.line,axis.line.x,axis.line.x.top,axis.line.x.bottom,axis.line.y,axis.line.y.left,axis.line.y.right,axis.line.theta,axis.line.rlines along axes (element_line()). Specify lines along all axes (axis.line),
lines for each plane (using axis.line.x or axis.line.y), or individually
for each axis (using axis.line.x.bottom, axis.line.x.top,
axis.line.y.left, axis.line.y.right). axis.line.*.* inherits from
axis.line.* which inherits from axis.line, which in turn inherits
from line
legend.backgroundbackground of legend (element_rect(); inherits
from rect)
legend.marginthe margin around each legend (margin())
legend.spacing,legend.spacing.x,legend.spacing.ythe spacing between legends (unit). legend.spacing.x & legend.spacing.y
inherit from legend.spacing or can be specified separately
legend.keybackground underneath legend keys (element_rect();
inherits from rect)
legend.key.size,legend.key.height,legend.key.widthsize of legend keys (unit); key background height & width inherit from
legend.key.size or can be specified separately
legend.key.spacing,legend.key.spacing.x,legend.key.spacing.yspacing
between legend keys given as a unit. Spacing in the horizontal (x) and
vertical (y) direction inherit from legend.key.spacing or can be
specified separately.
legend.frameframe drawn around the bar (element_rect()).
legend.tickstick marks shown along bars or axes (element_line())
legend.ticks.lengthlength of tick marks in legend (unit)
legend.axis.linelines along axes in legends (element_line())
legend.textlegend item labels (element_text(); inherits from
text)
legend.text.positionplacement of legend text relative to legend keys or bars ("top", "right", "bottom" or "left"). The legend text placement might be incompatible with the legend's direction for some guides.
legend.titletitle of legend (element_text(); inherits from
title)
legend.title.positionplacement of legend title relative to the main legend ("top", "right", "bottom" or "left").
legend.positionthe default position of legends ("none", "left", "right", "bottom", "top", "inside")
legend.position.insideA numeric vector of length two setting the
placement of legends that have the "inside" position.
legend.directionlayout of items in legends ("horizontal" or "vertical")
legend.byrowwhether the legend-matrix is filled by columns
(FALSE, the default) or by rows (TRUE).
legend.justificationanchor point for positioning legend inside plot ("center" or two-element numeric vector) or the justification according to the plot area when positioned outside the plot
legend.justification.top,legend.justification.bottom,legend.justification.left,legend.justification.right,legend.justification.insideSame as legend.justification but specified per legend.position option.
legend.locationRelative placement of legends outside the plot as a
string. Can be "panel" (default) to align legends to the panels or
"plot" to align legends to the plot as a whole.
legend.boxarrangement of multiple legends ("horizontal" or "vertical")
legend.box.justjustification of each legend within the overall bounding box, when there are multiple legends ("top", "bottom", "left", or "right")
legend.box.marginmargins around the full legend area, as specified
using margin()
legend.box.backgroundbackground of legend area (element_rect();
inherits from rect)
legend.box.spacingThe spacing between the plotting area and the
legend box (unit)
panel.borderborder around plotting area, drawn on top of plot so that
it covers tick marks and grid lines. This should be used with
fill = NA
(element_rect(); inherits from rect)
panel.spacing,panel.spacing.x,panel.spacing.yspacing between facet
panels (unit). panel.spacing.x & panel.spacing.y inherit from panel.spacing
or can be specified separately.
panel.ontopoption to place the panel (background, gridlines) over
the data layers (logical). Usually used with a transparent or blank
panel.background.
plot.backgroundbackground of the entire plot (element_rect();
inherits from rect)
plot.title.position,plot.caption.positionAlignment of the plot title/subtitle
and caption.  The setting for plot.title.position applies to both
the title and the subtitle. A value of "panel" (the default) means that
titles and/or caption are aligned to the plot panels. A value of "plot" means
that titles and/or caption are aligned to the entire plot (minus any space
for margins and plot tag).
plot.subtitleplot subtitle (text appearance) (element_text();
inherits from title) left-aligned by default
plot.captioncaption below the plot (text appearance)
(element_text(); inherits from title) right-aligned by default
plot.tagupper-left label to identify a plot (text appearance)
(element_text(); inherits from title) left-aligned by default
plot.tag.positionThe position of the tag as a string ("topleft",
"top", "topright", "left", "right", "bottomleft", "bottom", "bottomright")
or a coordinate. If a coordinate, can be a numeric vector of length 2 to
set the x,y-coordinate relative to the whole plot. The coordinate option
is unavailable for plot.tag.location = "margin".
plot.tag.locationThe placement of the tag as a string, one of
"panel", "plot" or "margin". Respectively, these will place the tag
inside the panel space, anywhere in the plot as a whole, or in the margin
around the panel space.
strip.clipshould strip background edges and strip labels be clipped
to the extend of the strip background? Options are "on" to clip, "off"
to disable clipping or "inherit" (default) to take the clipping setting
from the parent viewport.
strip.placementplacement of strip with respect to axes, either "inside" or "outside". Only important when axes and strips are on the same side of the plot.
strip.text,strip.text.x,strip.text.y,strip.text.x.top,strip.text.x.bottom,strip.text.y.left,strip.text.y.rightfacet labels (element_text(); inherits from  text). Horizontal facet labels (strip.text.x) & vertical
facet labels (strip.text.y) inherit from strip.text or can be specified
separately. Facet strips have dedicated position-dependent theme elements
(strip.text.x.top, strip.text.x.bottom, strip.text.y.left, strip.text.y.right)
that inherit from strip.text.x and strip.text.y, respectively.
As a consequence, some theme stylings need to be applied to
the position-dependent elements rather than to the parent elements
strip.switch.pad.gridspace between strips and axes when strips are
switched (unit)
strip.switch.pad.wrapspace between strips and axes when strips are
switched (unit)
completeset this to TRUE if this is a complete theme, such as
the one returned by theme_grey(). Complete themes behave
differently when added to a ggplot object. Also, when setting
complete = TRUE all elements will be set to inherit from blank
elements.
validateTRUE to run validate_element(), FALSE to bypass checks.
a ggtheme object
In particular, the theme: - displays only major gridlines, allowing you to quickly switch which ones; gridlines are thinner, panel has white background - provides quick option to draw a scatter with grey background - switches defaults for title alignment - turns axis labels off by default: in practice, x axes are often obvious and y axes are better documented in a subtitle - sets backgrounds to a ptrr-style shade - sets plot title in bold and 120
All the changed defaults can be overriden by another call to `theme()`.
The default fonts - IBM Plex Sans and IBM Plex Sans Condensed - are contained in this package and can be registered with the system using `import_fonts()`. You should then install them onto your system like any font, using files in the directories described in the `import_fonts()` messsage. You can also set the `ptrr.loadfonts` option to TRUE for the fonts to be registered at package load.
Other Making charts:
flush_axis
library(ggplot2)
# NB when `theme_ptrr()` is used in these examples, fonts
# are set to 'sans' to pass checks on computers without the
# sans included. If you have these fonts (see Note) you can
# leave these parameters at their default values.
# the basic plot for illustration, theme not used
p <- ggplot(mpg) +
  geom_bar(aes(y = class)) +
  labs(title = "Lots of cars", subtitle = "Count of numbers")
# using `theme_ptrr()` defaults
p +
  theme_ptrr("x", family = "sans", title_family = "sans")
# in combination with `flush_axis`:
p +
  theme_ptrr("x", family = "sans", title_family = "sans") +
  scale_x_continuous(expand = flush_axis)
# scatter
ggplot(mpg) +
  geom_point(aes(cty, hwy)) +
  theme_ptrr("scatter", family = "sans", title_family = "sans") +
  labs(title = "Lots of cars", subtitle = "Point by point")
# Smaller text, flush alignment
ggplot(mpg) +
  geom_point(aes(cty, hwy)) +
  theme_ptrr("scatter", base_size = 9, margin_side = 0,
                family = "sans", title_family = "sans") +
  labs(title = "Lots of cars", subtitle = "Point by point")
# Override defaults changed inside `theme_ptrr()`
ggplot(mpg) +
  geom_point(aes(cty, hwy)) +
  theme_ptrr("scatter", base_size = 9, margin_side = 0,
               family = "sans", title_family = "sans") +
  labs(title = "Lots of cars", subtitle = "Point by point") +
  theme(panel.background = element_rect(fill = "lightpink"))