繁体   English   中英

每个组/ ggplot2等价于类型=“ o”的线前的绘图点

[英]plot points in front of lines for each group/ggplot2 equivalent of type=“o”

假设我想绘制一个包含点和线的图形,其中点出现在每组中相应线的前面 特别是,我希望用红色填充点绘制组1,其中的点通过线连接,但是要用(仅)蓝线绘制组2,但是我希望将组2绘制组1 之上 。例如,在基本图形中:

set.seed(101)
dd <- data.frame(x=rep(1:10,2),
         y=rep(1:10,2),
                 f=factor(rep(1:2,each=10)))
dd$y[11:20] <-     dd$y[11:20] + rnorm(10)
d1 <- subset(dd,f=="1")
d2 <- subset(dd,f=="2")

par(cex=1.5)
plot(y~x,data=d1,bg="red",pch=21,type="o")
lines(y~x,data=d2,col="blue",lwd=2)
legend("bottomright",c("group 1","group 2"),
       col=c("black","blue"),
       pch=c(21,NA),
       pt.bg=c("red",NA),
       lty=1,
       lwd=c(1,2))

在此处输入图片说明

(我的真实数据要复杂一些。)我ggplot2ggplot2干净地做到这ggplot2

如果我在线条之前画点,则第1组的点会被同一组中的线覆盖:

 library(ggplot2); theme_set(theme_bw())
 g0 <- ggplot(dd,aes(x,y,fill=f,colour=f,shape=f))+
     scale_fill_manual(values=c("red",NA))+
     scale_colour_manual(values=c("black","blue")) +
     scale_shape_manual(values=c(21,NA))
 g0 + geom_point()+  geom_line()
 ggsave("order2.png",width=3,height=3)

在此处输入图片说明

如果我在点之前画线,则第2组的线会被第1组的点覆盖:

 g0 + geom_line()+  geom_point()
 ggsave("order3.png",width=3,height=3)

在此处输入图片说明

所需的顺序是(第1组线),(第1组点),(第2组线)。 我可以通过手动覆盖再次geoms,每次一个组做到这一点,但这是丑陋的方式

 g0 +  geom_line() + geom_point()+ 
     geom_point(data=d1)+
     geom_line(data=d2,show.legend=FALSE)
 ggsave("order4.png",width=3,height=3)

我认为对此的“最佳”解决方案是编写一个可以geom_linepoint工作的低级geom_linepoint 我已经研究了一下,这并不完全是琐碎的事 ……谁能提出更清洁,更简单的解决方案?

在此处输入图片说明

这是“低技术含量” 1解决方案。 下面是为给定分组变量的每个级别依次添加线层和点层的函数。

linepoint = function(data, group.var, lsize=1.2, psize=4) {
  lapply(split(data, data[,group.var]), function(dg) {
    list(geom_line(data=dg, size=lsize),
         geom_point(data=dg, size=psize)) 
  })
}

ggplot(dd, aes(x,y, fill=f, colour=f,shape=f))+
  scale_fill_manual(values=c("red",NA))+
  scale_colour_manual(values=c("black","blue")) +
  scale_shape_manual(values=c(21,NA)) +
  linepoint(dd, "f")

在此处输入图片说明


1个 “低技术含量”与编写一个新的几何图形相比。 @baptiste(现在已删除)的答案确实创建了一个新的几何图形,似乎已经完成了工作,因此我不确定他为什么删除了它。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM