在 R 中使用 ggplot2 创建多项目时间线

med*_*is6 2 r ggplot2 boxplot

我正在尝试创建一个多项目时间表,其中包含项目的各个阶段,以便在一个易于可视化的地方组织我们当前的所有项目。

我最初找到了这个timeline()包,并且能够半创建我所希望的。然而,这个包似乎不是很可定制,所以我希望能完成我的时间线ggplot2()

这是我的假数据:

Phase Project StartDate EndDate  
SD Test1 2015-08-01 2015-08-31  
DD Test1 2015-08-31 2015-09-30  
CD Test1 2015-09-30 2015-11-14  
PC Test1 2015-11-14 2015-12-14  
CA Test1 2015-12-14 2016-08-10  
SD Test2 2015-09-01 2015-10-01  
DD Test2 2015-10-01 2015-10-31  
CD Test2 2015-10-31 2015-12-15  
PC Test2 2015-12-15 2016-01-14  
CA Test2 2016-01-14 2017-01-08  
SD Test3 2016-01-01 2016-01-13  
DD Test3 2016-01-13 2016-01-25  
CD Test3 2016-01-25 2016-02-12  
PC Test3 2016-02-12 2016-03-13  
CA Test3 2016-03-13 2017-01-07  
SD Test4 2015-06-01 2015-06-01  
DD Test4 2015-06-01 2015-06-01  
CD Test4 2015-06-01 2015-06-01  
PC Test4 2015-06-01 2015-07-01  
CA Test4 2015-07-01 2015-07-01  
SD Test5 2015-05-01 2015-05-25  
DD Test5 2015-05-25 2015-06-18  
CD Test5 2015-06-18 2015-07-24  
PC Test5 2015-07-24 2015-08-23  
CA Test5 2015-08-23 2015-08-23  
Run Code Online (Sandbox Code Playgroud)

如您所见,每个项目都列出了 5 个阶段(SD、DD、CD、PC、CA),即使某些项目(Test4)不会有几个阶段,因为它们目前列出的日期周期相同。

当我用 运行我的代码时timeline(),这就是我得到的:

    data$StartDate<- as.Date(data$StartDate)
    data$EndDate<- as.Date(data$EndDate)
    timeline(data, text.size=4)
Run Code Online (Sandbox Code Playgroud)

结果

如您所见,在某些情况下,阶段会重叠,我无法调整字体或将文本居中放置在各自的框中。

正因为如此,我试图转向 ggplot,但无法弄清楚如何使其与此时间线相似。

到目前为止,这是我的新代码:

ggplot(data,aes(x=data$StartDate, y=data$Project)) +
  geom_line()+
  geom_point()+
  geom_text(aes(label=data$Phase), hjust=0,vjust=0)
Run Code Online (Sandbox Code Playgroud)

结果2

就目前而言,xlim 太小,无法显示我的几个项目的整个 CA 阶段。另外,我希望能够自定义文本,按最近的开始日期重新排序到最新,更改 xlab 和 ylab 以及我认为timleline()包中不可能的其他图形更改。

感谢您的任何帮助,如果您需要任何说明,请告诉我!

Her*_*oka 5

我选择使用线段而不是功能区,因为它是直线,并且线段使用离散的 y 轴更容易使用。

#make ordered factor so that sequence in legend matches sequence in plot
data$Phase_ordered <- factor(data$Phase,levels=c("SD","DD","CD","PC","CA"))

p1 <- ggplot(data,aes(x=StartDate, y=Project, color=Phase_ordered)) +
  geom_segment(aes(x=StartDate,xend=EndDate,yend=Project),size=15) +
 scale_colour_discrete(guide=guide_legend(override.aes=list(size=7))) #or legend will be too big
p1
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明