2013-01-02 16 views
11

Wykreślam dwie półprzezroczyste wstążki. Używając poniższego kodu, bez części scale_fill_manual, otrzymuję w zasadzie to, co chcę, z legendą o nazwie "red" i etykietami blue i red. Dodanie części scale_fill_manual pozwala mi nazwać legendę i jej wpisy, czego chcę, ale tracę przezroczystość kolorowych prostokątów w legendzie.legenda ggplot pokazująca przezroczystość i kolor wypełnienia

x=1:10 
y1=1:10 
y2=2:11 
y3=10:1 
y4=9:0 
dt=data.frame(x,y1,y2,y3,y4) 
library(ggplot2)  
ggplot(dt)+ 
    geom_ribbon(aes(x=x,ymin=y1,ymax=y2,fill='red'), 
       alpha=0.4,)+ 
    geom_ribbon(aes(x=x,ymin=y3,ymax=y4,fill='blue'), 
       alpha=0.5)+ 
    scale_fill_manual(name='legendname', 
        values=c('red','blue'), 
        labels=c('one','two')) 

wyjście sessionInfo()

R version 2.15.2 (2012-10-26) 
Platform: x86_64-apple-darwin9.8.0/x86_64 (64-bit) 

locale: 
[1] en_US.UTF-8/en_US.UTF-8/en_US.UTF-8/C/en_US.UTF-8/en_US.UTF-8 

attached base packages: 
[1] stats  graphics grDevices utils  datasets methods base  

other attached packages: 
[1] scales_0.2.3 ggplot2_0.9.3 plyr_1.8  reshape2_1.2.2 

loaded via a namespace (and not attached): 
[1] colorspace_1.2-0 dichromat_1.2-4 digest_0.6.0  grid_2.15.2  gtable_0.1.2  labeling_0.1  
[7] MASS_7.3-22  munsell_0.4  proto_0.3-10  RColorBrewer_1.0-5 rstudio_0.97.248 stringr_0.6.2  
[13] tools_2.15.2 

Istnieje wiele rozwiązań podobnych problemów (Customize legend in ggplot, https://stats.stackexchange.com/questions/5007/how-can-i-change-the-title-of-a-legend-in-ggplot2, etc.), ale nie mogę znaleźć niczego, co odnosi się do tego specjalnie.

Dzięki z góry

Odpowiedz

14

można zastąpić estetykę w legendzie dodając:

+ guides(fill = guide_legend(override.aes= list(alpha = 0.4))) 

do rozmowy ggplot.

Ale jak większość rzeczy w ggplot, to chyba prościej zorganizować swoje dane w sposób, który sprawia, że ​​wielokrotność geom_ribbon wywołuje niepotrzebny:

dt1 <- data.frame(x = c(x,x), 
        ymin = c(y1,y3), 
        ymax = c(y2,y4), 
        grp = rep(c('red','blue'),each = 10)) 
ggplot(data = dt1,aes(x = x,ymin = ymin, ymax = ymax,fill = grp)) + 
    geom_ribbon(alpha = 0.4) + 
    scale_fill_manual(name = "legendname", 
         values = c('red','blue'), 
         labels = c('one','two')) 

enter image description here

+1

Rozwiązanie to działa na mnie, tak jak ja wymaga tylko 1 poziomu przejrzystości [0.4]. Czy możesz skomentować, jak zmieni się rozwiązanie, jeśli każda wstążka ma unikalną przezroczystość? – RyanStochastic

+0

@RyanStochastic 'alpha' jest estetyką, która sama może być odwzorowana na zmienną tak jak każda inna. Więc zamapujesz 'alpha = grp' i prawdopodobnie dodasz komponent' scale_alpha_manual'. – joran

+0

Dzięki za całą pomoc. – RyanStochastic