ggplot2 密度图 分段设置线段颜色
2023-08-07 本文已影响0人
byejya
最终结果
![](https://img.haomeiwen.com/i18429961/4fdf3859c6ede276.png)
直接再密度图上是无法实现分段设置颜色的,要变成geom_line才能行
因此核心是得到geom_density作图使用的值
方法是先做出图p
再利用ggplot_build算出画图时候实际使用的值
![](https://img.haomeiwen.com/i18429961/708ae5b086fef6eb.png)
p <- ggplot(data,aes(x=log2FoldChange))+
geom_density()
pb <- ggplot_build(p)
data = pb[['data']][[1]]
ggplot(data,aes(x=x,y=y))+geom_line()
![](https://img.haomeiwen.com/i18429961/32a351356b90d42a.png)
![](https://img.haomeiwen.com/i18429961/1050bf19becf36d7.png)
添加分组信息
![](https://img.haomeiwen.com/i18429961/681e115d2cf1cc36.png)
![](https://img.haomeiwen.com/i18429961/f243b312d3cd2775.png)
能看到分组变量是group
颜色 分组信息都加上
p <- ggplot(data,aes(x = log2FoldChange, group=type,colour=type))+
geom_density()
pb <- ggplot_build(p)
Data = pb[['data']][[1]]
head(Data)
![](https://img.haomeiwen.com/i18429961/883ea218519d7650.png)
Data$colour=ifelse((Data$x<1 & Data$x> -1),'gray',Data$colour)
![](https://img.haomeiwen.com/i18429961/9c4bdf6c3e4a921b.png)
p <- ggplot(data,aes(x = log2FoldChange, group=type,colour=type))+
geom_density()
pb <- ggplot_build(p)
Data = pb[['data']][[1]]
head(Data)
Data$colour=ifelse((Data$x<1 & Data$x> -1),'#C0C0C0',Data$colour)
ggplot(Data,aes(x=x,y=y,group=group,colour=colour))+geom_line()+xlim(-5,5)+
geom_vline(xintercept=-1,linetype = "dashed",colour='#C0C0C0')+
geom_vline(xintercept=1,linetype = "dashed",colour='#C0C0C0')+
scale_colour_manual(values = c("#00BFC4","grey","#F8766D"))+theme_bw()+
theme(panel.grid.major = element_blank(),panel.grid.minor = element_blank())
![](https://img.haomeiwen.com/i18429961/4a4bdd2ae0317898.png)