library(tidyverse)
## ── Attaching core tidyverse packages ──────────────────────── tidyverse 2.0.0 ──
## ✔ dplyr 1.1.0 ✔ readr 2.1.4
## ✔ forcats 1.0.0 ✔ stringr 1.5.0
## ✔ ggplot2 3.4.1 ✔ tibble 3.2.0
## ✔ lubridate 1.9.2 ✔ tidyr 1.3.0
## ✔ purrr 1.0.1
## ── Conflicts ────────────────────────────────────────── tidyverse_conflicts() ──
## ✖ dplyr::filter() masks stats::filter()
## ✖ dplyr::lag() masks stats::lag()
## ℹ Use the conflicted package (<http://conflicted.r-lib.org/>) to force all conflicts to become errors
remove_layers <- function(plot, index = NULL){
if(is.null(index)){
plot$layers <- NULL
}else{
plot$layers[[index]] <- NULL
}
plot
}
last_plot_wiped <- function(index = NULL){
plot <- ggplot2::last_plot()
if(is.null(index)){
plot$layers <- NULL
}else{
plot$layers[[index]] <- NULL
}
plot
}
ggplot(mtcars) +
aes(x = cyl, fill = factor(vs)) +
geom_bar()
last_plot_wiped() +
geom_bar(position = "fill")