假设我使用ggplot
和geom_line
绘制了一些行。我想标记这些线条。我可以使用geom_dl
包中的directlabels
来执行此操作,但即使使用提供的方法来避免重叠(例如"last.qp"
),我仍然认为标签是两个紧密相连的。
如何增加这些标签之间的间距(此处为y方向),不使用使用ggplot2::annotate
或类似方法手动指定每个位置?我愿意接受不涉及directlabels
包的答案,但是如果可能的话我会坚持使用它,因为它可以很好地完成标记行的95%的工作。
tiebreak.big
中可能有here提示,但我无法让它工作......
library(dplyr)
#>
#> Attaching package: 'dplyr'
#> The following objects are masked from 'package:stats':
#>
#> filter, lag
#> The following objects are masked from 'package:base':
#>
#> intersect, setdiff, setequal, union
library(ggplot2)
library(tibble)
library(directlabels)
library(tidyr)
data <- tibble(x = 1:10) %>%
mutate(y1 = x^2) %>%
mutate(y2 = y1+0.5) %>%
gather(key = var, value = value, y1, y2)
ggplot(data, aes(x = x, y = value, color = var)) +
geom_line() +
geom_dl(aes(label = var), method = list(cex = 1.2, dl.trans(x = x + 0.2), "last.qp"))
答案 0 :(得分:1)
这是使用ggrepel
包的解决方案。它有很多自定义选项。
library(dplyr)
library(ggplot2)
library(tibble)
library(tidyr)
library(ggrepel)
data <- tibble(x = 1:10) %>%
mutate(y1 = x^2) %>%
mutate(y2 = y1+0.5) %>%
gather(key = var, value = value, y1, y2)
ggplot(data, aes(x = x, y = value, color = var)) +
geom_line() +
geom_text_repel(aes(label = var),
nudge_x = 1,
force = 1,
box.padding = 1,
segment.alpha = .5,
data = data %>%
group_by(var) %>%
filter(x == max(x)))
您可能想要使用force
和box.padding
参数。