使用ggplot和geom_rect

时间:2016-10-27 19:46:53

标签: r ggplot2

我有这3个时间序列:

a<-rnorm(357)
b<-rnorm(357)
c<-rnorm(357)

a_ts<-ts(a, start=c(1980, 1), frequency=12)
b_ts<-ts(b, start=c(1980, 1), frequency=12)
c_ts<-ts(c, start=c(1980, 1), frequency=12)

a_time<-time(a_ts)
a_series<-ts.union(month=a_time,a=a_ts)
a_series_df<-as.data.frame(a_series)
a_series_df["b"] <- b_ts
a_series_df["c"] <- c_ts

使用ggplot函数i melted

melted = melt(a_series_df, id.vars="month")

情节顺利:

ggplot(data=melted, aes(x=month, y=2*value)) + geom_line(aes(colour = variable))

但是当我想要在下面这些间隔之间的棚图时,它会显示以下错误信息:

shade = data.frame(x1=c(1980.333 ,2009.167), x2=c(2007.333 ,2009.667), y1=c(0,3), y2=c(0,4))

ggplot(data=melted, aes(x=month, y=2*value)) + geom_line(aes(colour = variable))+
geom_rect(data=shade, mapping=aes(xmin=x1, xmax=x2, ymin=y1, ymax=y2), color='grey', alpha=0.2)

Error in eval(expr, envir, enclos) : object 'month' not found

我错过了什么?

1 个答案:

答案 0 :(得分:2)

您的inherit.aes = FALSE图层中缺少geom_rect。它期望能够从ggplot初始化中找到所有映射变量,除非你告诉它不要继承那些美学。

这有效:

ggplot(data = melted, aes(x = month, y = 2 * value)) +
    geom_line(aes(colour = variable))+
    geom_rect(data = shade,
              mapping = aes(xmin = x1, xmax = x2, ymin = y1, ymax = y2),
              color = 'grey',
              alpha = 0.2,
              inherit.aes = FALSE)

第一个矩形不会显示,因为矩形的数据同时包含y1y2 0 - 所以它只是一条线。第二个矩形在那里,但它非常小。

shade
#         x1       x2 y1 y2
# 1 1980.333 2007.333  0  0
# 2 2009.167 2009.667  3  4

为矩形的轮廓设置color,为矩形的填充颜色设置fill