我想做的和here解释的完全一样,这个被接受的答案因为某些原因对我不起作用。
library("ggplot2")
tmp <- data.frame(x=rep(seq(as.Date(0, origin="1970-01-01"),
length=36, by="1 month"), 2),
y=rnorm(72),
category=gl(2,36))
p <- ggplot(tmp, aes(x, y, colour=category)) +
geom_line() +
geom_vline(aes(xintercept=as.numeric(x[c(13, 24)])),
linetype=4, colour="black")
print(p)我与geom_line()交换了层(geom_line“line”),以使绘图工作。但是,当添加vline时,我会得到以下错误:
Error: Aesthetics must be either length 1 or the same as the data (72): xintercept
10: stop("Aesthetics must be either length 1 or the same as the data (",
n, "): ", paste(names(!good), collapse = ", "), call. = FALSE)
9: check_aesthetics(evaled, n)
8: f(..., self = self)
7: l$compute_aesthetics(d, plot)
6: f(l = layers[[i]], d = data[[i]])
5: by_layer(function(l, d) l$compute_aesthetics(d, plot))
4: ggplot_build(x)
3: print.ggplot(p)
2: print(p)
1: print(p)发布于 2016-06-29 08:43:11
以下几点对我有用:
ggplot(tmp,aes(x, y, colour=category)) +
geom_line() +
geom_vline(data=tmp[c(13,26),],aes(xintercept=as.numeric(x)))https://stackoverflow.com/questions/38092998
复制相似问题