1

考虑一个示例数据框和相对geom_bar

data = data.frame(method=LETTERS[sample(x=c(1,2,3),size=100,replace=T)], 
                  x1=sample(x=c(1,2,3,4,5,6),size=100,replace=T), 
                  x2=sample(x=c(1,2,3,4,5,6),size=100,replace=T),
                  d =letters[sample(c(1,2,3,4),size=100,replace=T)] )

ggplot()+
  geom_bar(data=data, aes(x=method, y=x1),stat="identity") +
  facet_wrap(~d, ncol=2)

我想为每个红色图的较小列着色。我怎样才能做到这一点?

4

1 回答 1

4

我不确定如何在不折叠数据以创建一个新列来指定哪个值是最小值的情况下做到这一点。然后,您可以将美学附加到该价值上。这是使用您的数据的折叠策略

collapsed < -as.data.frame(xtabs(x1~d+method, data))
collapsed$ismin <- with(collapsed, ave(Freq,d,FUN=function(x) x==min(x)))

现在我们用

ggplot(collapsed, aes(x=method, y=Freq, fill=as.factor(ismin)))+
  geom_bar(stat="identity") +
  facet_wrap(~d, ncol=2) + 
  scale_fill_manual(breaks=c("0","1"), values=c("black","red"), guide="none")

这导致

bar char 与 min mbar 在每个事实中涂成红色

于 2014-06-03T01:08:00.123 回答