R:将 "vline" 和 "hline" 语句组合在一起 (ggplot2)

R: Combining "vline" and "hline" statements together (ggplot2)

我正在使用 R 编程语言。最近学习了如何用ggplot库“画”横线和竖线:

library(ggplot2)

# Simple scatter plot
sp <- ggplot(data=mtcars, aes(x=wt, y=mpg)) + geom_point()

# Add horizontal line at y = 2O

a = sp + geom_hline(yintercept=20) 

b = sp + geom_vline(xintercept = 3)

现在,我正在尝试将这些语句组合在一起 - 例如:

c = sp + geom_hline(yintercept=20) +  geom_hline(yintercept=15) + geom_vline(xintercept = 3) +
    geom_vline(xintercept = 5) + geom_vline(xintercept = 6) + geom_hline(yintercept=35)

问题:我正在尝试修改上面的情节,使其看起来像这样:

谁能告诉我怎么做?或者你必须手动将此图导出到 Microsoft Paint 并在那里更改它?

谢谢

您可以使用 annotate 添加图层。每个段都是下面四个向量的匹配元素。即第一段从 (-Inf,15) 开始到 (3,15) 结束。

ggplot(data=mtcars, aes(x=wt, y=mpg)) + geom_point() +
  annotate("segment", 
           x = c(-Inf, 3, -Inf, 5, -Inf, 6),
           y = c(15, 15, 20, 20, 35, 35),
           xend = c(3, 3, 5, 5, 6, 6),
           yend = c(15, -Inf, 20, -Inf, 35, -Inf))

或者定义一个从一个点到轴绘制两条线的函数可能会更容易(假设这里的点是正的,所以它应该指向 -Inf)。要使函数输出多个 ggplot2 元素,请将它们放在列表中:

draw_guides<- function(x, y) {
  list(geom_segment(aes(x = -Inf, xend = x, y = y, yend = y)),
       geom_segment(aes(x = x, xend = x, y = y, yend = -Inf)))
}

然后你可以调用每一个来更轻松地重新创建所需的图形:

ggplot(data=mtcars, aes(x=wt, y=mpg)) + geom_point() +
  draw_guides(3,15) +
  draw_guides(5,20) +
  draw_guides(6,35)