Save plot objects as .pdf file after labeling with Source graphic and Source code labels.
mrggsave(x, ...)
# S3 method for class 'ggplot'
mrggsave(
x,
...,
ypad = 2,
arrange = FALSE,
ncol = 1,
onefile = TRUE,
envir = parent.frame()
)
# S3 method for class 'ggmatrix'
mrggsave(
x,
...,
ypad = 4,
arrange = FALSE,
onefile = TRUE,
envir = parent.frame()
)
# S3 method for class 'gList'
mrggsave(...)
# S3 method for class 'gtable'
mrggsave(...)
# S3 method for class 'trellis'
mrggsave(
x,
...,
ypad = 3,
arrange = FALSE,
ncol = 1,
onefile = TRUE,
envir = parent.frame()
)
# S3 method for class 'patchwork'
mrggsave(x, ..., envir = parent.frame())
# S3 method for class 'list'
mrggsave(x, ..., arrange = FALSE, use_names = FALSE, envir = parent.frame())
# S3 method for class 'gg'
mrggsave(x, ...)
# S3 method for class 'gTree'
mrggsave(x, ..., envir = parent.frame())
mrgglabel(..., draw = FALSE, .save = FALSE)
mrggsave_common(
x,
script = getOption("mrg.script", NULL),
tag = NULL,
width = 5,
height = 5,
stem = "Rplot",
dir = getOption("mrggsave.dir", "../deliv/figure"),
path.type = getOption("mrggsave.path.type", "proj"),
prefix = NULL,
onefile = TRUE,
arrange = FALSE,
draw = FALSE,
.save = TRUE,
ypad = 3,
labsep = "\n",
pre_label = NULL,
post_label = NULL,
fontsize = 7,
textGrob.x = 0.01,
textGrob.y = unit(0.1, "in"),
just = c("left", "bottom"),
dev = getOption("mrggsave.dev", "pdf"),
res = getOption("mrggsave.res", 150),
units = "in",
position = getOption("mrggsave.position", "default"),
labeller = getOption("mrggsave.label.fun", label.fun),
envir = parent.frame(sys.nframe()),
...
)
an object or list of objects of class gg
.
other arguments passed to mrggsave_common
and then
on to pdf()
and gridExtra::arrangeGrob()
.
integer number of newlines to separate annotation from x-axis title.
logical; if TRUE
, arrange the ggplot objects on a
single page with gridExtra::arrangeGrob()
.
passed to gridExtra::arrangeGrob()
.
passed to pdf()
.
environment to be used for string interpolation in stem and tag.
if TRUE
, the names from a list of plots will be used
as the stems for output file names.
if TRUE
, the plot is drawn using draw_newpage()
.
logical; if FALSE
, return the labeled objects.
the name of the script generating the gg
objects.
if specified, stem is overwritten by pasting script
and tag
together.
passed to pdf()
; should be less than 5 in.
for portrait figure.
passed to pdf()
; should be less than 7 in.
for portrait figure.
to form the name of the output .pdf
file.
output directory for .pdf
file.
a character string indicating how the path to the image
file should be rendered in the figure annotation; see format_path()
for details.
gets prepended to the output file path in the Source graphic, label.
character separator (or newline) for Source code and Source graphic labels.
text to include before annotation; separate lines prior to Source code label; see details.
text to include after annotation; separate lines after Source graphic; see details.
for Source graphic and Source code labels.
passed to grid::textGrob()
(as x
).
passed to textGrob
(as y
).
passed to grid::textGrob()
(as just
).
one or more devices to use; can pass a character vector or a
comma-separated string (e.g. c("pdf", "png")
or "pdf,png"
).
passed to png()
.
passed to png()
.
force the graphic annotation to locate to the left or right
a function that creates the plot annotation; the function
should receive a single argument (x
) which is an environment
containing various items that might go into the label; pass NULL
to
omit the label on the plot.
Methods are provided for ggplot
output, lattice
output, and ggmatrix
objects (produced by
GGally::ggpairs()
). Either a single plot object
or a list of objects can be passed in. If a list of objects
are passed in, the plots may be written to a single file (default)
or multiple files (if onefile
is FALSE
).
Alternatively, ggplots
and lattice plots
can be arranged on a single page when
arrange
is TRUE
. ggmatrix
objects
cannot be arranged. An error is generated if different
object types are passed in a single list.
By default, the output file name is generated from
the script name and the value in tag
. For example,
when the script is named vpc-figures
and the tag
is passed as by-dose-group
, the output file name
will be vpc-figures-by-dose-group.pdf
. Alternatively,
the user can specify the complete stem of the file
name with the stem
argument.
Output file names are generated by default with a hyphen (-
) separator.
This can be changed using the function output_file_sep()
. To
revert to previous behavior where the underscore was the separator, call
mrggsave:::output_file_sep("_")
.
When .save
is FALSE
, mrggsave
always returns a list of table grobs. If a single
plot was passed, the return value in this case
is a list of length 1.
mrgglabel()
calls mrggsave()
and
neither draws nor saves the plot, but
returns the annotated plots as table grob.
pre_label
and post_label
are collapsed with newline if
supplied by the user, allowing multiple lines to be added before or
after the standard annotation.
data(Theoph)
require(ggplot2)
#> Loading required package: ggplot2
x <- runif(1000,10,100)
y <- 0.3*x + rnorm(length(x),0,20)
data <- data.frame(x = x, y = y)
Script <- "example.R"
# NOTE: see default value for dir argument, which should be appropriate
# for project work
# Changing it here only for the example
options(mrggsave.dir = tempdir(),
mrggsave.path.type = "none")
p1 <- ggplot(data=Theoph) +
geom_line(aes(x=Time, y=conc, group=Subject))
p2 <- ggplot(data=Theoph) +
geom_line(aes(x=Time, y=conc)) +
facet_wrap(~Subject)
mrggsave(p1, Script, "_plot1")
if (FALSE) { # \dontrun{
mrggsave(p2, Script, "_plot2")
} # }
mrggsave(list(p1,p2), Script, "both_plots")
if (FALSE) { # \dontrun{
mrggsave(list(p1,p2), Script, "separate_files", onefile=FALSE)
} # }
mrggsave(p1, Script, "different_shape", width=10, height=4)
if (FALSE) { # \dontrun{
mrggsave(list(p1,p2), Script, "onepage", arrange=TRUE, ncol=2)
stopifnot(require(GGally))
p3 <- ggpairs(data)
mrggsave(p3, Script, "ggally_plot")
} # }