我试图使用lapply将函数ggplotGrob()应用于ggplots列表,但似乎无法从中获取grob对象列表 . 对于这个项目,根据用户输入生成可变数量的图,我需要一种动态方式来生成网格 . 我需要从图中定义grobs,以便在显示之前为所有图表指定相同的宽度 .
例如,我有p1和p2的图 . 如果我手动执行:
gp1 <- ggplotGrob(p1)
gp2 <- ggplotGrob(p2)
grid.arrange(gp1, gp2, ncol=1)
我得到了我的2个情节 .
现在,如果我这样做
gp_list <- list(gp1,gp2)
grid.arrange(gp_list, ncol=1)
我收到一条错误消息
arrangeGrob错误(...,as.table = as.table,clip = clip,main = main,:输入必须是grobs!
我试图使用unlist()但我得到了同样的错误
grid.arrange(unlist(gp_list), ncol=1)
最后,我想通过lapply Build grobs列表
gp_list <- lapply(plot_list, function(x) ggplotGrob(x))
并能够使用grid.arrange安排所有grobs . 我觉得我忘记了一个简单的步骤,从列表中检索每个对象作为grob . 有人解决了这个吗?
谢谢
> sessionInfo()
R version 3.1.1 (2014-07-10)
Platform: x86_64-apple-darwin13.1.0 (64-bit)
locale:
[1] en_US.UTF-8/en_US.UTF-8/en_US.UTF-8/C/en_US.UTF-8/en_US.UTF-8
attached base packages:
[1] grid parallel stats graphics grDevices utils datasets methods base
other attached packages:
[1] pryr_0.1 WGCNA_1.41-1 flashClust_1.01-2 dynamicTreeCut_1.62 gridExtra_0.9.1 ggplot2_1.0.0
[7] gplots_2.14.1 hash_2.2.6 shiny_0.10.1 Biobase_2.24.0 BiocGenerics_0.10.0