ggplot2箱图中的alpha和填充图例?

时间:2016-11-15 14:57:11

标签: r ggplot2 scale legend alpha

我试图将alpha和填充ggplot2结合起来。它适用于我使用geom_bar(或geom_points,用于颜色),但是当我使用geom_boxplot时,alpha图例不起作用。

library(data.table)
library(ggplot2)
dt = data.table(x = rep(1:5,6), y = rnorm(30), tag1 = rep(c('hey', 'what'), 15), tag2 = rep(c('yeah', 'yeah', 'so', 'so', 'so'), 6))

适用于酒吧:

ggplot(dt[, list(y=mean(y)), by=list(x, tag1, tag2)], aes(x=x, y=y, fill=tag1, alpha=tag2, group=interaction(x,tag1,tag2))) + geom_bar(stat = 'identity', position = 'dodge')

enter image description here

但不适用于boxplot - alpha图例为空。

ggplot(dt, aes(x=x, y=y, fill=tag1, alpha=tag2, group=interaction(x,tag1,tag2))) + geom_boxplot()

enter image description here

更简单的版本可以在没有填充的情况下完成 - 看起来条形图默认为灰色/浅灰色,而boxplot默认为白色/浅白色:

ggplot(dt[, list(y=mean(y)), by=list(x, tag2)], aes(x=x, y=y, alpha=tag2, group=interaction(x,tag2))) + geom_bar(stat = 'identity')

enter image description here

ggplot(dt, aes(x=x, y=y, alpha=tag2, group=interaction(x,tag2))) + geom_boxplot()

enter image description here

但我不确定如何解决这个问题。有什么想法吗?

1 个答案:

答案 0 :(得分:5)

我不确定为什么ggplot实际上没有在箱图的图例中提供alpha级别,但你可以使用override.aes对其进行硬编码。 (编者注:我发现对于箱形图或条形图而言,alpha美学有点令人困惑。难以在心理上将透明度与填充色分开,灰度alpha图例会加剧问题,因为没有任何内容映射到灰色情节。)

在下面的代码中,为了提高图例的可见性,我删除了alpha图例中的方框线并增加了图例键高度。我还编辑了美学以消除对group论证的需要。

ggplot(dt, aes(x=factor(x), y=y, fill=tag1, alpha=tag2)) + 
  geom_boxplot() +
  scale_alpha_manual(values=c(0.2,0.7)) +
  guides(alpha=guide_legend(override.aes=list(fill=hcl(c(15,195),100,0,alpha=c(0.2,0.7)),
                                              colour=NA))) +
  theme(legend.key.height=unit(1,"cm"))

enter image description here

另一种选择是将interaction用于填充和alpha美学,但事实证明ggplot在这种情况下不包含任何颜色:

ggplot(dt, aes(x=factor(x), y=y, alpha=interaction(tag1,tag2)), 
       fill=interaction(tag1,tag2)) + 
  geom_boxplot() +
  scale_fill_manual(values=rep(hcl(c(15,195),100,65), 2)) +
  scale_alpha_manual(values=rep(c(0.3, 1), each=2)) +
  theme(legend.key.height=unit(2,"cm")) 

enter image description here

因此,您可以使用填充美学来完成所有操作,但在颜色规范中包含透明度。这是有效的,但是,再次,因为透明度和颜色在视觉感知中有些混合,所以最好只选择四种不同的颜色。

ggplot(dt, aes(x=factor(x), y=y, fill=interaction(tag1,tag2,sep="-"))) + 
  geom_boxplot() +
  scale_fill_manual(values=hcl(c(15,195,15,195),100,65, alpha=c(0.4,0.4,1,1))) +
  theme(legend.key.height=unit(1,"cm")) +
  labs(fill="Tag 1 - Tag 2")

enter image description here