Próbuję wykreślić wiele działek za pomocą ggplot2
, układając je za pomocą grid.arrange()
. Ponieważ udało mi się znaleźć kogoś, opisujący dokładnie problem mam, mam cytat z opisu problemu z link:Zapisywanie grid.arrange() działki do pliku
Gdy używam ggsave()
po grid.arrange()
, tj
grid.arrange(sgcir1,sgcir2,sgcir3,ncol=2,nrow=2) ggsave("sgcirNIR.jpg")
nie zapisać wykres siatki ale ostatni indywidualny ggplot. Czy jest jakiś sposób na zapisanie wykresu w sposób przedstawiony przez grid.arrange()
przy użyciu ggsave()
lub czegoś podobnego? Inny niż przy użyciu starszych sposób
jpeg("sgcirNIR.jpg") grid.arrange(sgcir1,sgcir2,sgcir3,ncol=2,nrow=2) dev.off()
tym samym łączu daje rozwiązanie poniżej:
require(grid)
require(gridExtra)
p <- arrangeGrob(qplot(1,1), textGrob("test"))
grid.draw(p) # interactive device
ggsave("saving.pdf", p) # need to specify what to save explicitly
Jednak nie można dowiedzieć się, jak korzystać z ggsave()
zapisać wyjście rozmowy grid.arrange()
w ten kod, który jest pobierany z link:
library(ggplot2)
library(gridExtra)
dsamp <- diamonds[sample(nrow(diamonds), 1000), ]
p1 <- qplot(carat, price, data=dsamp, colour=clarity)
p2 <- qplot(carat, price, data=dsamp, colour=clarity, geom="path")
g_legend<-function(a.gplot){
tmp <- ggplot_gtable(ggplot_build(a.gplot))
leg <- which(sapply(tmp$grobs, function(x) x$name) == "guide-box")
legend <- tmp$grobs[[leg]]
return(legend)}
legend <- g_legend(p1)
lwidth <- sum(legend$width)
## using grid.arrange for convenience
## could also manually push viewports
grid.arrange(arrangeGrob(p1 + theme(legend.position="none"),
p2 + theme(legend.position="none"),
main ="this is a title",
left = "This is my global Y-axis title"), legend,
widths=unit.c(unit(1, "npc") - lwidth, lwidth), nrow=1)
# What code to put here to save output of grid.arrange()?
Użyj 'png(); grid.arrange(); ggplot(); ggplot(); dev.off() ' – Andrie
Nie' print (ggplot()) '? –
@DWin Tak, prawdopodobnie!:-) – Andrie