1

我是 grobbing 的新手,我正在尝试创建一个简单的grid.arrange对象,但无法弄清楚如何实现紧凑/紧凑的布局。

下面是一个简单的例子,说明我正在尝试运行什么以及我得到的 grob。

library(grid)
library(gridExtra)
name = textGrob("My Name", gp=gpar(fontsize = 20, fontface = "bold"))
name2 = textGrob("Second Name", gp=gpar(fontsize = 16))
tbl = tableGrob(head(iris))
grid.arrange(name, name2, tbl)

运行代码时看到的输出

更新:使用此处 找到的答案,我能够使文本紧凑,但我仍在努力使表格位于文本下方。

library(grid)
library(gridExtra)
name = textGrob("My Name", gp=gpar(fontsize = 20, fontface = "bold"))
name2 = textGrob("Second Name", gp=gpar(fontsize = 16))
tbl = tableGrob(head(iris))
margin = unit(0.5, "line")
grid.newpage()
grid.arrange(name, name2, tbl, 
             heights = unit.c(grobHeight(name) + 1.2*margin, 
                              grobHeight(name2) + margin, 
                              unit(1,"null")))
4

1 回答 1

1

通常,您top=会将参数用于单个 grob。有了这样的两个 grobs,将它们组合在一个表中可能是最简单的;主要障碍是 gtable 不考虑理由所以你必须自己调整位置,

library(gtable)
justify <- function(x, hjust="center", vjust="top", draw=FALSE){
  w <- sum(x$widths)
  h <- sum(x$heights)
  xj <- switch(hjust,
               center = 0.5,
               left = 0.5*w,
               right=unit(1,"npc") - 0.5*w)
  yj <- switch(vjust,
               center = 0.5,
               bottom = 0.5*h,
               top=unit(1,"npc") - 0.5*h)
  x$vp <- viewport(x=xj, y=yj)
  if(draw) grid.draw(x)
  return(x)
}
title <- gtable_col('title', grobs = list(name,name2), 
                    heights = unit.c(grobHeight(name) + 1.2*margin, 
                                   grobHeight(name2) + margin))

grid.newpage()
grid.arrange(justify(title, vjust='bottom'), justify(tbl))
于 2019-10-17T20:43:18.120 回答