ВЕРОЯТНО, вы не можете сделать это с помощью layout.pos.row и layout.pos.col.
Простой обходной путь - указать позицию и размер:
grid.newpage()
pushViewport(viewport(layout=grid.layout(2, 2)))
grid.rect(gp=gpar(fill=1),vp=viewport(layout.pos.col=1,layout.pos.row=1))
grid.rect(gp=gpar(fill=2),vp=viewport(layout.pos.col=1,layout.pos.row=2))
grid.rect(gp=gpar(fill=3),vp=viewport(layout.pos.col=2,layout.pos.row=1))
grid.rect(gp=gpar(fill=4),vp=viewport(layout.pos.col=2,layout.pos.row=2))
pushViewport(viewport(x=unit(0.5, "npc"), width=unit(0.5, "npc"),
y=unit(0.75, "npc"), height=unit(0.5, "npc")))
grid.rect(gp=gpar(fill="white"))
также, я думаю, вы можете написать функцию-обертку для этого, указав pos.col и pos.row в двойном виде, например:
vpvp <- function(pos.col, pos.row){
cvp <- current.viewport()
nrow <- cvp$layout$nrow
ncol <- cvp$layout$ncol
w <- unit(1/ncol, "npc")
h <- unit(1/nrow, "npc")
x <- unit((pos.col-0.5)/ncol, "npc")
y <- unit(1-(pos.row-0.5)/nrow, "npc")
viewport(x=x, y=y, width=w, height=h)
}
grid.newpage()
pushViewport(viewport(layout=grid.layout(2, 3)))
grid.rect(gp=gpar(fill=1),vp=viewport(layout.pos.col=1,layout.pos.row=1))
grid.rect(gp=gpar(fill=2),vp=viewport(layout.pos.col=1,layout.pos.row=2))
grid.rect(gp=gpar(fill=3),vp=viewport(layout.pos.col=2,layout.pos.row=1))
grid.rect(gp=gpar(fill=4),vp=viewport(layout.pos.col=2,layout.pos.row=2))
grid.rect(gp=gpar(fill=5),vp=viewport(layout.pos.col=3,layout.pos.row=1))
grid.rect(gp=gpar(fill=6),vp=viewport(layout.pos.col=3,layout.pos.row=2))
pushViewport(vpvp(pos.col=2.5, pos.row=1.5))
grid.rect(gp=gpar(fill="white"))