나는에 구글 그룹 해들리의 게시물을 발견에도 불구 POSIXct하고 geom_vline, 나는 그것을 할 수 없었다. 예를 들어 1998 년, 2005 년 및 2010 년의 시계열을 가지고 있으며 수직선을 그리고 싶습니다. ggplot및 qplot구문으로 시도 했지만 여전히 수직선이 전혀 보이지 않거나 수직선이 맨 처음 수직 그리드에 그려지고 전체 시리즈가 다소 이상하게 오른쪽으로 이동합니다.
gg <- ggplot(data=mydata,aes(y=somevalues,x=datefield,color=category)) +
      layer(geom="line")
gg + geom_vline(xintercept=mydata$datefield[120],linetype=4)
# returns just the time series plot I had before, 
# interestingly the legend contains dotted vertical lines내 날짜 필드의 형식은 “1993-07-01″이고 클래스 Date입니다.
답변
시도해보십시오 as.numeric(mydata$datefield[120]):
gg + geom_vline(xintercept=as.numeric(mydata$datefield[120]), linetype=4)간단한 테스트 예 :
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(xintercept=as.numeric(tmp$x[c(13, 24)]),
                linetype=4, colour="black")
print(p)
답변
geom_vline(xintercept = as.numeric(as.Date("2015-01-01")), linetype=4)날짜가 120 번째 행에 있는지 여부에 관계없이 줄이 그대로 유지되도록 할 수도 있습니다 .
답변
as.numeric은 나에게 작동합니다.
ggplot(data=bmelt)+
  geom_line(aes(x=day,y=value,colour=type),size=0.9)+
  scale_color_manual(labels = c("Observed","Counterfactual"),values = c("1","2"))+
  geom_ribbon(data=ita3,aes(x=day,
      y=expcumresponse, ymin=exp.cr.ll,ymax=exp.cr.uu),alpha=0.2) +
  labs(title="Italy Confirmed cases",
        y ="# Cases ", x = "Date",color="Output")+
  geom_vline(xintercept = as.numeric(ymd("2020-03-13")), linetype="dashed",
                color = "blue", size=1.5)+
  theme_minimal()