为什么(通过linesGrob)没有在下面的图中画线?
require(gtable)
base <- gtable(widths=unit(rep(1, 2), "null"),
heights=unit(rep(1, 3), "null"))
grid.newpage()
g <- 1
for(i in 1:3) {
for(j in 1:2) {
base <- gtable_add_grob(base,
grobs=list(linesGrob(x=1:4, y=4:1),
rectGrob(gp=gpar(fill="#FF0000")),
textGrob(label=g)), i, j, name=1:3)
g <- g+1
}
}
grid.draw(base)发布于 2013-08-03 14:01:06
原因有二:
require(gtable)
# let's fix this name before it's too late
gtable_add_grobs <- gtable_add_grob
base <- gtable(widths=unit(rep(1, 2), "null"),
heights=unit(rep(1, 3), "null"))
grid.newpage()
g <- 1
for(i in 1:3) {
for(j in 1:2) {
base <- gtable_add_grobs(base,
grobs=list(rectGrob(gp=gpar(fill="#FF0000")),
linesGrob(x=1:4, y=4:1, def="native",
vp=dataViewport(1:4, 1:4)),
textGrob(label=g)), i, j, name=1:3)
g <- g+1
}
}
grid.draw(base)注gtable_add_grobs是矢量化的,这意味着您不应该使用循环,理想情况下。如果您首先将所有的grobs组合在一起(对于给定的单元格),在一个gTree中更容易一些。这是一个简化的版本,
library(gtable)
g <- gtable(widths = unit(c(1,1), "null"),
heights = unit(c(1,1), "null"))
cell <- function(ii)
grobTree(rectGrob(),
linesGrob(1:4, 1:4, default.units="native"),
textGrob(ii),
vp=dataViewport(c(1,4), c(1,4)))
gl <- lapply(1:4, cell)
xy <- expand.grid(1:2, 1:2)
g <- gtable_add_grobs(g, gl,
l=xy[,1],
r=xy[,1],
t=xy[,2],
b=xy[,2])
grid.newpage()
grid.draw(g)https://stackoverflow.com/questions/18033568
复制相似问题