【问题标题】:Is it possible to create overlapping y-axes with a shared x-axis?是否可以使用共享的 x 轴创建重叠的 y 轴?
【发布时间】:2021-09-19 19:47:33
【问题描述】:

我经常看到具有相同共享 x 轴但不同 y 轴的图形。它们不能刻面,因为某些 y 轴需要复杂的名称和/或出于历史/解释原因而翻转坐标。

下面我绘制了一个这样的假记录示例,并展示了在 Inkscape 中对其进行调整后我希望该图的外观。有没有办法在 R/patchwork 中实现这个结果?

library(tidyverse)
library(patchwork)

set.seed(123)
dat <- tibble::tibble(a = 1:10,
                      b = c(0, 2, 5, 8, 5, 4, 6, 4, 3, 2),
                      c = -stats::rnorm(10, b, 3),
                      d = sample(letters[1:3], 10, TRUE))

shared_x <- c(0, 11)

pl1 <- dat %>%
  ggplot(aes(x = a, y = b)) +
  geom_point(colour = "indianred") +
  coord_cartesian(xlim = shared_x) +
  scale_y_continuous("B is awesome", position = "right")

pl2 <- dat %>%
  ggplot(aes(x = a, y = c)) +
  geom_point(colour = "steelblue") +
  scale_y_reverse("C is inversely related to B") +
  coord_cartesian(xlim = shared_x, ylim = c(3, -13))

theme_set(theme_classic())
(pl1 & theme(axis.title.x = element_blank(), axis.text.x = element_blank(), axis.ticks.x = element_blank(), axis.line.x = element_blank())) / pl2

ggsave("overlapping_axes.pdf", width = 10, height = 8, units = "cm")

reprex package (v2.0.0) 于 2021-07-09 创建

这是手动调整的版本:

【问题讨论】:

  • 请注意,我必须在此处使用theme_classic(),否则网格会重叠,从而很难很好地做到这一点。
  • 花了几年时间说服ggplot2 作者将sec_axis 添加到它的情节中,主要是因为拥有两个不同单位的轴很容易混淆。您的“手动调整版本”(在我看来)正是他们所谈论的混乱:红点和蓝点之间的垂直位置存在暗示相关性。这可以做到吗?也许,尽管可能需要手动绘制轴线,并且坐标都需要使用手动覆盖的轴标签进行归一化。
  • 话虽如此,我建议 facets 和 patchwork 对我来说更清楚。您已经在做patchwork 部分,我建议添加包含刻面的框会清楚地将两者分开。如果那是您不想要的,并且您希望蓝/红点混合,那么(再次,imo)将需要大量解释来证明这样做是合理的。 (主观的,我承认。)
  • 感谢您的回复!在我的领域(古海洋学)中,我们有许多不同类型的数据是针对相同的深度/年龄间隔(通常在 x 轴上)生成的。我们经常想研究重建的温度是否显示出与不同代理中相同的模式,例如二氧化碳。所以它们是完全不同的 y 轴,具有不同的含义,但我们希望将它们放在一起,以便更好地在视觉上比较模式。见for example
  • 或者another example image。但他们周围都有盒子……嗯

标签: r ggplot2 patchwork


【解决方案1】:

我看到 r2evans 已经给了你警告,每次人们可能认为辅助轴可以解决你的问题时都应该考虑这些警告。我同意他们的观点,但这并不意味着它不能完成。

只要您能想到一个转换并且它是逆向的,您就可以使用辅助轴来执行此操作(不要与“您应该这样做”混淆)。轴的截断外观可以用ggh4x::axis_truncated() 复制(免责声明,我是该函数的作者)。

在下面的示例中,辅助轴的转换为 -x * 0.5,因此倒数为 - x / 0.5,但您可能可以更好地满足您的需求。

library(ggplot2)
library(ggh4x)

set.seed(123)
dat <- tibble::tibble(a = 1:10,
                      b = c(0, 2, 5, 8, 5, 4, 6, 4, 3, 2),
                      c = -stats::rnorm(10, b, 3),
                      d = sample(letters[1:3], 10, TRUE))

ggplot(dat, aes(a)) +
  geom_point(aes(y = b, colour = "b")) +
  geom_point(aes(y = -c * 0.5, colour = "c")) +
  scale_y_continuous(
    position = "right", breaks = seq(0, 8, by = 2),
    guide = guide_axis_truncated(),
    name = "B is awesome",
    sec.axis = sec_axis(
      trans = ~ -.x/0.5, breaks = c(0, -5, -10),
      guide = guide_axis_truncated(trunc_lower = -Inf),
      name = "C is inversely related to B"
    )
  ) +
  scale_colour_manual(values = c("indianred", "steelblue")) +
  theme_classic() +
  theme(
    axis.title.y.left = element_text(colour = "steelblue"),
    axis.title.y.right = element_text(colour = "indianred")
  )

reprex package (v1.0.0) 于 2021-07-09 创建

您可以通过设置适当的hjusts 来更好地重新定位轴标题。

【讨论】:

  • 感谢您的解决方案。对于具有 >5 个面板的图来说,这似乎有点过于复杂,因为这些关系不是非常直观。我想我要么将它们按原样分开,要么根据需要在inkscape中手动调整它们。
猜你喜欢
  • 1970-01-01
  • 2020-03-28
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-02-04
  • 2021-01-19
  • 2018-07-12
相关资源
最近更新 更多