#' Saving plot, automatically annotating the status and denoting the filenames
#'
#' @param width width of plot
#' @param height height of plot
#' @param dirs list of directories. If NULL or if directories missing, there
#' is default behavior below
#'
#' \enumerate{
#' \item parent_dir = Parent directory containing the Rscript and the Results
#' folder, default getwd()
#' \item rscript_dir = Subdirectory of parent_dir that contains the Rscript
#' used to generate the figure, default "./"
#' \item rscript_name= Name of the Rscript used to generate the figure,
#' default "Name_Of_Script_Here.R"
#' \item results_dir = Subdirectory ofparent_dir where the figure is stored,
#' default "./"
#' \item filename_prefix = prefix of filename to be appended to filename_main
#' }
#'
#' @param filename_main main part of the filename, excluding prefix and suffix.
#' no default
#' @param status status to be annotated
#' @param g ggplot plot object, default is ggplot::last_plot()
#' @param filetype file extension (e.g. "pdf","csv" etc.)
#' @param status_x x location of the status in plot
#' @param status_y y location of the status in plot
#' @param status_fontcolor font color for status in plot
#' @param status_fontsize font size for status in plot
#' @param filenames_fontcolor font color for filenames info in plot
#' @param filenames_fontsize font size for filenames info in plot
#'
#' @return ggplot2 plot object
#'
#' @examples
#' directory = tempdir()
#' dirs <- list(parent_dir = directory,
#' rscript_dir = directory,
#' rscript_name = "example.R",
#' results_dir = directory,
#' filename_prefix = "example_")
#' data <- data.frame(x = 1:1000, y = stats::rnorm(1000))
#' ggplot2::ggplot(data = data, ggplot2::aes(x = x, y = y)) +
#' ggplot2::geom_point()
#' xgx_save(4, 4, dirs, "Example", "DRAFT")
#'
#' @importFrom ggplot2 last_plot
#' @importFrom ggplot2 ggsave
#' @importFrom ggplot2 ggplot
#' @importFrom ggplot2 aes
#' @importFrom ggplot2 geom_point
#' @importFrom stats rnorm
#' @export
xgx_save <- function(width,
height,
dirs = NULL,
filename_main = NULL,
status = "DRAFT",
g = ggplot2::last_plot(),
filetype = "png",
status_x = Inf,
status_y = Inf,
status_fontsize = 7,
status_fontcolor = "grey",
filenames_fontsize = 11,
filenames_fontcolor = "black") {
if (typeof(dirs)!="list") {
stop("dirs variable must be a list")
}
if (is.null(dirs$parent_dir)) {
stop("The parent directory for your programs and results must be specified: dirs$parent_dir")
}
if (is.null(dirs$rscript_dir)) {
stop("The project directory where your R scripts are stored must be specified: dirs$rscript_dir")
}
if (is.null(dirs$rscript_name)) {
stop("The name of the R script that saves this plot must be specified: dirs$rscript_name")
}
if (is.null(dirs$results_dir)) {
stop("The results directory where your outputs are stored must be specified: dirs$results_dir")
}
if (is.null(dirs$filename_prefix)) {
dirs$filename_prefix <- ""
}
if (is.null(filename_main)) {
filename_main <- "unnamed_graph_"
}
filedir <- file.path(dirs$results_dir)
dirs$filename <- paste0(dirs$filename_prefix, filename_main, ".", filetype)
g <- g + xgx_annotate_filenames(dirs,
color = filenames_fontcolor,
size = filenames_fontsize)
g <- g + xgx_annotate_status(status, x = status_x, y = status_y,
color = status_fontcolor,
fontsize = status_fontsize)
ggplot2::ggsave(plot = g, width = width, height = height,
file.path(filedir, dirs$filename))
return(g)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.