5

我正在寻找翻转 1 行和 5 列的多面面板上的标签,以便小平面标题出现在底部,而 x 轴出现在小平面的顶部。

原因是我想将这些标题重用于将在图表正下方的表格。

所以在这个例子中......

library(ggplot2)

my.hist<-ggplot(diamonds, aes(clarity)) + geom_bar()

my.hist + facet_wrap( ~ cut, ncol=5) + coord_flip()

我希望“剪切”标签显示在图表下方。我在想 facet_grid 可能是关键,但这只是一个猜测。

有谁知道如何做到这一点?

4

1 回答 1

7

获取情节下方的刻面条很容易,

library(gtable)
g <- ggplotGrob(p)

strips <- gtable_filter(g, "strip_t", trim=FALSE)
grid.newpage()
grid.draw(rbind(g, strips[3,], size="first"))

然而,轴需要更加小心,因为必须颠倒刻度线和标签的位置。你也许可以从这个开始,

tweak_axis <- function(a){
  inner <- a[["children"]]["axis"][[1]]
  inner[["grobs"]] <- rev(inner[["grobs"]])
  inner$grobs[[2]]$y <- inner$grobs[[2]]$y - unit(0.15, "cm")
  a[["children"]]["axis"][[1]] <- inner
  a
}

axes <- gtable_filter(g, "axis_b", trim=FALSE)
axes$grobs <- lapply(axes$grobs, tweak_axis)
grid.newpage()
grid.draw(axes)

编辑:基于上述,一个“完整”的解决方案可能是

grid.newpage()
g2 <- g
new_axes <- lapply(g2$grobs[grepl("axis_b", g2$layout$name)], tweak_axis)
g$grobs[grepl("strip_t", g$layout$name)] <- new_axes 
g$grobs[grepl("axis_b", g$layout$name)] <- g2$grobs[grepl("strip_t", g2$layout$name)] 
# heights should be changed too, but it's kind of ok here
xlab <- 7; title <- 1:2
grid.draw(rbind(g[xlab,], g[-c(title, xlab), ], size="last"))

在此处输入图像描述

(有明显的警告)

于 2013-08-05T18:50:57.643 回答