library( ggplot2 )
library( gridExtra )
p1 <- qplot( rnorm( 10 ), rnorm( 10 ) )
p2 <- qplot( rnorm( 10 ), rnorm( 10 ) )
p3 <- qplot( rnorm( 10 ), rnorm( 10 ) )
p4 <- qplot( rnorm( 10 ), rnorm( 10 ) )
p5 <- qplot( rnorm( 10 ), rnorm( 10 ) )
grid.arrange( p1, p2, p3, p4, p5, nrow=2 )
我想把底部的两个情节放在中心位置。怎么办呢?我可以使用split.screen
来完成,但我无法弄清楚如何使用ggplot2
执行此操作。 ggplot2
图形更酷。
提前致谢!
PK
答案 0 :(得分:12)
您可以使用gtable
包进行灵活方便的网格布局,或者只是嵌套两个arrangeGrobs,
ng = nullGrob()
grid.arrange(arrangeGrob(p1, p2, p3, nrow=1),
arrangeGrob(ng, p4, p5, ng, nrow=1, widths=c(0.5, 1, 1, 0.5)),
nrow=2)
编辑:对于覆盖整个宽度的底部图,您只需要删除上述解决方案中的虚拟nullGrobs():
grid.arrange(arrangeGrob(p1, p2, p3, nrow=1),
arrangeGrob(p4, p5, nrow=1),
nrow=2)
答案 1 :(得分:7)
以下是使用gtable
的替代方法:
library(gtable)
gtable_add_grobs <- gtable_add_grob #misleading name
g <- gtable(widths = unit(rep(1, 6), "null"), # need lcm(3,2)=6 for the matrix rows
heights = unit(rep(1, 2), "null"))
#gtable_show_layout(g)
g <- gtable_add_grobs(g, lapply(list(p1, p2, p3, p4, p5), ggplotGrob),
t = c(1, 1, 1, 2, 2),
l = c(1, 3, 5, 2, 4),
r = c(2, 4, 6, 3, 5))
grid.newpage()
grid.draw(g)
编辑:对于跨越整个宽度的底部图,您只需要更改相应的l和r索引,
g <- gtable_add_grobs(g, lapply(list(p1, p2, p3, p4, p5), ggplotGrob),
t = c(1, 1, 1, 2, 2),
l = c(1, 3, 5, 1, 4),
r = c(2, 4, 6, 3, 6))