r - 将文本框添加到 ggplot2 中的分面包装布局

标签 r plot ggplot2 annotate

我知道可以注释 ggplot2 创建的绘图,甚至可以组合大小视口(viewport),如 ggplot2-book 中所述。然而,这些似乎只适用于实际的情节区域,而不是“最终情节”。

例如我有一个这样的情节:
enter image description here

在这里,我们看到十个面板显示了应用于二项式数据集的线性回归平滑器,但这不是重点。现在我想要一个摘要(存储在数据框中),在图的右下角以文本的形式出现,比如这个......
enter image description here

我没有找到任何接近的例子。
非常感谢任何提示、帮助或评论!

最佳答案

游戏已经很晚了,但我还没有看到任何扩展到多个空白刻面空间的解决方案,所以就这样吧。

步骤 0 .示例 ggplot 具有 2 个未填充的面,使用内置的 diamonds 数据集:

library(ggplot2)

p <- ggplot(diamonds,
       aes(x = carat, y = price)) +
  geom_point() +
  geom_smooth() +
  facet_wrap(~color)
p

step 0

第一步 .使用 ggplotGrob 将绘图转换为 gtable
gp <- ggplotGrob(p)

library(gtable)

# visual check of gp's layout (in this case, it has 21 rows, 15 columns)
gtable_show_layout(gp)

step 1

第二步 . (可选)获取用于文本框的未填充单元格的单元格坐标。如果您喜欢阅读上面的布局,您可以跳过此步骤。在这种情况下,左上角的单元格为 (16, 8),右下角的单元格为 (18, 12)。
# get coordinates of empty panels to be blanked out
empty.area <- gtable_filter(gp, "panel", trim = F)
empty.area <- empty.area$layout[sapply(empty.area$grob,
                                       function(x){class(x)[[1]]=="zeroGrob"}),]

empty.area$t <- empty.area$t - 1 #extend up by 1 cell to cover facet header
empty.area$b <- empty.area$b + 1 #extend down by 1 cell to cover x-axis

> empty.area
   t  l  b  r z clip      name
6 16  8 18  8 1   on panel-3-2
9 16 12 18 12 1   on panel-3-3

第三步 .将文本框叠加为 tableGrob
library(gridExtra)

gp0 <- gtable_add_grob(x = gp,
                       grobs = tableGrob("some text",
                                         theme = ttheme_minimal()),
                       t = min(empty.area$t), #16 in this case
                       l = min(empty.area$l), #8
                       b = max(empty.area$b), #18
                       r = max(empty.area$r), #12
                       name = "textbox")
grid::grid.draw(gp0)

step 3

展示一些变化:
gp1 <- gtable_add_grob(x = gp,
                       grobs = tableGrob("Simple line of comment that can go on & on for the sake of demonstration. Automatic line wrap not included.",
                                         theme = ttheme_minimal()),
                       t = min(empty.area$t),
                       l = min(empty.area$l),
                       b = max(empty.area$b),
                       r = max(empty.area$r),
                       name = "textbox")
grid::grid.draw(gp1)

demo 1
gp2 <- gtable_add_grob(x = gp,
                       grobs = tableGrob("Simple line of comment that can go on & on. 
Automatic line wrap not included. \nAt least it understands the concept of line breaks.",
                                         theme = ttheme_minimal()),
                       t = min(empty.area$t),
                       l = min(empty.area$l),
                       b = max(empty.area$b),
                       r = max(empty.area$r),
                       name = "textbox")
grid::grid.draw(gp2)

demo 2
gp3 <- gtable_add_grob(x = gp,
                       grobs = tableGrob(tibble::tribble(~col1, ~col2,
                                                         "a.", "This is a line in a table",
                                                         "b.", "This is another line in a table"),
                                         rows = NULL,
                                         theme = ttheme_minimal()),
                       t = min(empty.area$t),
                       l = min(empty.area$l),
                       b = max(empty.area$b),
                       r = max(empty.area$r),
                       name = "textbox")
grid::grid.draw(gp3)

demo 3

关于r - 将文本框添加到 ggplot2 中的分面包装布局,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28496764/

相关文章:

python - 导入 CIFAR - 10 数据集到 R

r - 穿过 x 轴的堆叠条形图

r - 计算列中的出现次数并在 R 中创建变量

r - 如何使 qplot 用一个数据向量生成线图

r - 在 ggplot2 中注释箱线图

r - 有没有一种有效的方法可以使用 ggplot2 在堆积条形图中的不同元素之间绘制线条?

plot - 有 "automatic"x

python - 使用 matplotlib 堆积条形图

python - 如何在 seaborn 情节中重新标记条形图?

r - 在 ggplot2 中按因子级别设置轴中断