r - 通过拼凑对齐和缩放 ggplots

标签 r ggplot2 patchwork

我正在尝试使用 patchwork 包将一些图合并为一个图,但我对它不熟悉,并且无法弄清楚如何正确缩放图的大小。有一个核心图,即散点图,然后还有每个连续变量到某些分布的箱线图。下面是一个可重现的示例:

library(dplyr)
library(ggplot2)
library(patchwork)

set.seed(100)
dat1 <- tibble(x = runif(1000, 0, 10),
               y = runif(1000, 0, 20),
               group1 = sample(rep(letters[1:5], each = 200)),
               group2 = sample(rep(letters[-22:-1], each = 250)))

plot1 <- ggplot(data = dat1) +
  geom_point(aes(x = x, y = y, color = group1)) +
  facet_wrap(~group2) +
  theme(legend.position = 'bottom')

xbox <- ggplot(data = dat1) +
  geom_boxplot(aes(x = x, y = group1, fill = group1, color = group1)) +
  scale_x_continuous(position = 'top') +
  theme(legend.position = 'none',
        axis.title.y = element_blank(),
        axis.text.y = element_blank(),
        axis.ticks.y = element_blank(),
        title = element_blank())

ybox <- ggplot(data = dat1) +
  geom_boxplot(aes(x = group1, y = y, fill = group1, color = group1)) +
  scale_y_continuous(position = 'right') +
  theme(legend.position = 'none',
        axis.title.x = element_blank(),
        axis.text.x = element_blank(),
        axis.ticks.x = element_blank(),
        title = element_blank())

(xbox + plot_spacer()) / (plot1 + ybox)

enter image description here

这与我正在尝试的接近,但箱线图需要重新缩放,以使顶部箱线图约为其显示高度的 20%,右侧箱线图约为其显示宽度的 20%。我尝试使用 patchwork::plot_layout 来处理缩放,但我不断得到意想不到的结果。我插入了 patchwork::plot_spacer() ,以便右侧箱线图不会拉伸(stretch)图片的整个高度,但也许有更好的方法来做到这一点。箱线图应该看起来更像轴,因此右上角的空白不应该真正存在。

最佳答案

我不确定您会得到一个在边距中具有推论意义的图,但您可以使用 heights 更改 plot_layout 中边距图的宽度和高度widths 参数或 design 参数。请注意,括号中的图本身被视为“子图”,并且在使用 plot_layout 时被赋予自己的“区域”。因此,我将所有图添加在一起,而不是使用其他拼凑运算符来排列它们。

xbox + plot_spacer() + plot1 + ybox + plot_layout(design = c(area(t = 1, b = 1, l = 1, r = 6), # <== top column
                                                             area(t = 1, b = 1, l = 7, r = 7), # <== top right
                                                             area(t = 2, b = 7, l = 1, r = 6), # <== bottom left
                                                             area(t = 2, b = 7, l = 7, r = 7)  # <== bottom right
                                                             ))
# Alternative:
xbox + plot_spacer() + plot1 + ybox + plot_layout(ncol = 2, nrow = 2, 
                                                  heights = c(1, 6),
                                                  widths = c(6, 1))

enter image description here

关于r - 通过拼凑对齐和缩放 ggplots,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70499552/

相关文章:

r - 将 ASCII 文件导入 R

r - 如何将因子转换为数字

r - ggplot 为因子水平显示相同的颜色

r - 如何将表格添加到ggplot?

从 R 列表名称中删除重音符号 (`)

r - ggplot图例为什么显示 “colour”参数?

r - ggplot2直方图binwidth

r - 如何在ggplot2中跨时间线绘制多行

r - 在 x 轴刻度值上对齐不同宽度的图

用虚拟图替换 ggplots 列表中的 NA