2013-05-09 85 views
2

我有一个ggplot2图,其中x轴上的日期时间和y轴上的分类时间。我需要在x轴的特定日期放置9个文本注释,但是没有空间将注释放入图形本身。我想在x轴上保留自动生成的日期,并添加我的自定义标签。我不在乎他们是在顶部还是底部。在ggplot2中添加轴注释

下面的合成示例。我有9个活动,以及导致这些活动的大量活动。我想在每个事件下面放置一个文本标签,指出事件名称。例如,在2月11日午夜的这个数据中,我希望有一个标签在某处说“事件1”。

events <- data.frame(names=c("Event 1", "Event 2", "Event 3", "Event 4", "Event 5", "Event 6", "Event 7", "Event 8", "Event 9"), 
         dates=strptime(c("2013-02-10 11:59 pm", "2013-02-21 11:59 pm", "2013-03-02 11:59 pm", "2013-03-16 11:59 pm", "2013-03-26 12:00 pm", "2013-04-11 11:59 pm", "2013-04-24 11:59 pm", "2013-04-23 11:59 pm", "2013-05-08 12:00 pm") 
             , "%Y-%m-%d %I:%M %p")) 
units <- replicate(125, paste(sample(LETTERS, 8), collapse="")) 
n <- 2000 
df <- data.frame(name=sample(units, n, replace=TRUE), 
      d=(sample(events$dates, n, replace=TRUE)-rexp(n, 1/150000)), 
      value=rexp(n, 1/110)) 

ggplot(data=df, aes(x=d, y=name)) + 
    geom_point(alpha=I(1/2), aes(size=log(value))) + 
    ylab("Each row is one unit") + 
    xlab("Date") + 
    theme(legend.position="none", legend.direction="horizontal", 
      axis.text.y=element_blank(), 
      axis.ticks.y=element_blank(), 
      axis.line.y=element_blank(), 
      panel.grid.major.y=element_blank(), 
      panel.grid.minor.y=element_blank()) 

Generated synthetic image

+3

[这里](http://stackoverflow.com/questions/16279295/axis-labels-for-each-bar-and-each-group-in-bar-charts-with -dodged-groups/16279990#16279990)就是将文本置于特定位置下的示例。 – 2013-05-09 17:07:39

+0

@DidzisElferts谢谢!我解决了数据框问题,当时我错过了重命名,显然我的R会议仍然有它,所以我没有注意到。代码现在应该可以正常工作。 – chmullig 2013-05-09 17:48:44

回答

4

您可以使用geom_text()绘制里面的情节标签。由于x值使用dates在数据帧eventsy值设置一些负数来绘制点下的标签。 使用vjust=hjust=您可以调整标签的位置(日期的中心或左/右)。

ggplot(data=df, aes(x=d, y=name)) + 
    geom_point(alpha=I(1/2), aes(size=log(value))) + 
    geom_text(data=events,aes(x=dates,y=-5,label=names),inherit_aes=FALSE, 
      vjust=-1,hjust=0,size=3)+ 
    ylab("Each row is one unit") + 
    xlab("Date") + 
    theme(legend.position="none", legend.direction="horizontal", 
     axis.text.y=element_blank(), 
     axis.ticks.y=element_blank(), 
     axis.line.y=element_blank(), 
     panel.grid.major.y=element_blank(), 
     panel.grid.minor.y=element_blank()) 

enter image description here

+1

有用,但我真的更喜欢它低于(或高于)轴,因为我的真实数据比模拟更混乱。标签里面的内容非常意味着我必须将其放大,就像你在这里做的那样,看起来有点奇怪。 – chmullig 2013-05-09 18:40:45