如何在GGPLOT2一般的标签添加到面?如何在GGPLOT2一般的标签添加到面?(How do yo

2019-06-14 15:19发布

我经常有刻面的数值。 我想提供足够的信息以补充标题,类似轴标题解释这些刻面的值。 贴标签机选项重复许多不必要的文字,并不能用于较长的变量冠军。

有什么建议?

默认:

test<-data.frame(x=1:20, y=21:40, facet.a=rep(c(1,2),10), facet.b=rep(c(1,2), each=20))
qplot(data=test, x=x, y=y, facets=facet.b~facet.a)

我会爱:

最好我能在ggplot做到:

qplot(data=test, x=x, y=y)+facet_grid(facet.b~facet.a, labeller=label_both)

正如@Hendy表示,类似于: 添加辅助y轴到GGPLOT2地块-使它完美

Answer 1:

由于采用了最新ggplot2使用gtable内部,这是很容易修改一个数字:

library(ggplot2)
test <- data.frame(x=1:20, y=21:40, 
                   facet.a=rep(c(1,2),10), 
                   facet.b=rep(c(1,2), each=20))
p <- qplot(data=test, x=x, y=y, facets=facet.b~facet.a)

# get gtable object
z <- ggplotGrob(p)

library(grid)
library(gtable)
# add label for right strip
z <- gtable_add_cols(z, unit(z$widths[[7]], 'cm'), 7)
z <- gtable_add_grob(z, 
                     list(rectGrob(gp = gpar(col = NA, fill = gray(0.5))),
                          textGrob("Variable 1", rot = -90, gp = gpar(col = gray(1)))),
                     4, 8, 6, name = paste(runif(2)))

# add label for top strip
z <- gtable_add_rows(z, unit(z$heights[[3]], 'cm'), 2)
z <- gtable_add_grob(z, 
                     list(rectGrob(gp = gpar(col = NA, fill = gray(0.5))),
                          textGrob("Variable 2", gp = gpar(col = gray(1)))),
                     3, 4, 3, 6, name = paste(runif(2)))

# add margins
z <- gtable_add_cols(z, unit(1/8, "line"), 7)
z <- gtable_add_rows(z, unit(1/8, "line"), 3)

# draw it
grid.newpage()
grid.draw(z)

当然,你可以写一个函数,自动添加条标签。 未来版本的ggplot2可能具有此功能; 虽然不能肯定。



Answer 2:

除了由kohske概括的方法,你可以添加边框通过改变添加的盒子

col=NA

col=gray(0.5), linetype=1

此外,变化

fill=gray(0.5)

对于

fill=grey(0.8)

gp=gpar(col=gray(1))

gp=gpar(col=gray(0))

如果你想在新的酒吧,以配合小标签

z <- gtable_add_grob(z, 
      list(rectGrob(gp = gpar(col = gray(0.5), linetype=1, fill = gray(0.8))),
      textGrob("Variable 1", rot = -90, gp = gpar(col = gray(0)))),
      4, 8, 6, name = paste(runif(2)))


Answer 3:

有可能是一个更好的办法来做到这一点,但您可以:

fac1 = factor(rep(c('a','b'),10))
fac2 = factor(rep(c('a','b'),10))
data = data.frame(x=1:10, y=1:10, fac1=fac1, fac2=fac2)
p = ggplot(data,aes(x,y)) + ggplot2::geom_point() + 
facet_grid(fac1~fac2)
p + theme(plot.margin = unit(c(1.5,1.5,0.2,0.2), "cm"))
grid::grid.text(unit(0.98,"npc"),0.5,label = 'label ar right', rot = 270) # right
grid::grid.text(unit(0.5,"npc"),unit(.98,'npc'),label = 'label at top', rot = 0)   # top


文章来源: How do you add a general label to facets in ggplot2?