Удалить пробел textGrob из grid.arrange - PullRequest
1 голос
/ 17 октября 2019

Я новичок в освоении и пытаюсь создать простой grid.arrange объект, но не могу понять, как создать компактную / плотную компоновку.

Ниже приведен простой пример того, что япытаясь запустить и гроб, который я получаю.

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)

Output of what I see when I run code

ОБНОВЛЕНИЕ: Используя найденный ответ здесь Я смогчтобы получить компактный текст, но я все еще изо всех сил пытаюсь сделать таблицу прямо под текстом.

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")))

1 Ответ

1 голос
/ 17 октября 2019

Обычно вы используете аргумент top= для одного гроба. С двумя подобными гробами было бы проще всего объединить их в таблицу;Основное препятствие заключается в том, что 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))
...