In shape_plot()
and forest_plot()
use
base_size
to set the base font and line size (default:
11pts) and use base_line_size
to separately set the base
thickness of lines (default: base_size/22).
In forest_plot()
use plotcolour
to change
the colour for all parts of the plot. In shape_plot()
use
plotcolour
to change the colour for non-data aspects of the
plot.
In shape_plot()
and forest_plot()
several
arguments can be used to change visual properties for parts of the plot.
These can be names of columns in your data or single values. In
shape_plot()
use:
argument | controls | type |
---|---|---|
shape | plotting character for points | integer |
colour | colour of points | character |
cicolour | colour of CI lines | character |
fill | fill colour of points | character |
ciunder | if the CI line should be plotted before the point | logical |
In forest_plot()
use:
argument | controls | type |
---|---|---|
shape | plotting character for points | integer |
colour | colour of points and lines | character |
fill | fill colour of points | character |
ciunder | if the CI line should be plotted before the point | logical |
col.bold | if text is bold | logical |
col.diamond | if a diamond should be plotted | logical |
Note that col.bold
, and col.diamond
must be
column names in the supplied data frames, while the others can be fixed
values or column names. For diamonds, alternatively provide a character
vector of keys in the diamond
argument.
For fill
to have any effect, the shape will need to be a
shape with fill e.g. "square filled"
.
In forest_plot()
and shape_plot()
you can
add additional ggplot objects to the plot with the add
argument. The argument should be a named list, where the name
start
is an object to be included in the ggplot immediately
after ggplot()
(i.e. before anything else is added to the
ggplot) and the name end
will add to the end.
This argument can be used, for example, to add additional geoms to the plot:
hr_geom <- geom_text(aes(label = auto_estcolumn),
size = 3,
hjust = 0,
nudge_y = 0.25,
colour = "red")
forest_plot(my_results,
estcolumn = FALSE,
add = list(start = hr_geom))
Or to use theme
to customise the plot:
my_theme <- theme(axis.text.x = element_text(colour = "purple",
angle = 45,
hjust = 1))
forest_plot(my_results,
add = list(end = my_theme))
To add multiple objects, use a list:
Use the data.function
argument in
forest_plot()
to change the plot data immediately before
plotting.
For example, you can tweak the text in the generated estimates column:
The addaes and addarg arguments in shape_plot()
and
forest_plot()
can be used to add additional aesthetics and
arguments code to the ggplot layers created by the functions. These
arguments must be named lists of character strings, and the names of
elements defines where the aesthetics/arguments code is added.
In shape_plot()
the following names will add aesthetics
and arguments to layers:
name | layer that plots |
---|---|
lines | lines of linear fit through estimates |
point | point estimates |
estimates | text of estimates |
n | text of number of events (n) |
ci | confidence intervals |
In forest_plot()
the following names will add aesthetics
and arguments to layers:
name | layer that plots |
---|---|
ci | confidence intervals |
point | point estimates |
diamonds | diamonds |
col.right/col.left | col.right/col.left columns |
heading.col.right/heading.col.left | col.right/col.left column headings |
xlab | x-axis label |
panel.headings (or panel.name) | headings above panels |
nullline | line at null |
addtext | ‘addtext’ text |
Where duplicate aesthetics/arguments might be defined and created, they are kept with the priority:
This can be used to ‘overwrite’ some of the code that would otherwise
be produced by shape_plot()
and
forest_plot()
.
For example, adjusting the position and appearance of panel headings:
forest_plot(list("a) Observational" = my_resultsA,
"b) Genetic" = my_resultsB),
col.key = "subgroup",
row.labels = row_labels,
addaes = list(panel.headings = "x = 0.5"),
addarg = list(panel.headings = c("size = 4.5",
"colour = 'navyblue'",
"hjust = 0")))
Changing the appearance of the line at the ‘null’: