У меня есть несколько графиков с тремя фреймами данных в ggplot2. Я хотел бы показать все три легенды.
Например, у меня есть этот набор данных: data('demo')
Group1 Group2 Y X
A A1 11.074 -20.0857819
A A1 11.046 -20.03366372
A A1 10.927 -19.37661633
A A1 10.872 -18.72542857
A A1 11.663 -17.51427049
A A2 4.608 -13.527
A A2 4.348 -13.419
A A2 5.754 -13.434
A A2 5.617 -12.687
A A2 5.46 -12.477
A A3 7.018 -16.91
A A3 7.41 -11.124
A A3 3.833 -18.669
A A3 6.49 -12.424
A A3 4.892 -20.618
B B1 7.146 -19.831
B B1 7.456 -20.128
B B1 7.562 -19.458
B B1 8.522 -20.352
B B1 5.374 -20.457
B B1 8.755 -19.113
B B2 9.032 -18.292
B B2 10.551 -15.258
B B2 11.276 -15.807
B B2 10.299 -18.214
B B2 9.283 -18.358
B B2 8.872 -17.775
B B3 9.698 -18.948
B B3 9.583 -19.007
B B3 9.356 -18.899
B B3 9.326 -19.022
B B3 9.438 -20.599
B B4 5.111 -19.632
B B4 2.609 -17.962
B B4 4.397 -17.973
B B4 5.079 -17.334
B B4 4.161 -17.76
C C1 3.208 -17.13
C C1 3.546 -16.892
C C1 3.917 -15.887
C C1 3.999 -16.274
C C1 4.592 -15.644
C C2 10.976 -14.554
C C2 9.673 -12.923
C C2 9.274 -10.903
C C2 9.227 -10.799
C C2 11.088 -11.222
Это мой рабочий код:
#subset data
GroupA <- dplyr::select(filter(demo, Group1=="A"), Group2, X, Y)
GroupB <- dplyr::select(filter(demo, Group1=="B"), Group2, X, Y)
GroupC <- dplyr::select(filter(demo, Group1=="C"), Group2, X, Y)
#summary GroupB
GroupB_YSE <- summarySE(GroupB, measurevar="Y", groupvars=c("Group2"))
GroupB_XSE <- summarySE(GroupB, measurevar="X", groupvars=c("Group2"))
GroupB_SE<-merge(GroupB_YSE, GroupB_XSE, by=c("Group2","N"))
#plot
ggplot(data=GroupB_SE, aes(x=X, y=Y))+
geom_point(aes(colour=Group2),size=4, alpha=1)+
geom_errorbar(aes(colour=Group2,ymax=Y+sd.y, ymin=Y-sd.y),alpha=1,size=1.5)+
geom_errorbarh(aes(colour=Group2,xmax=X+sd.x, xmin=X-sd.x), alpha=1,size=1.5)+
geom_text(data=GroupB_SE,aes(label=Group2, colour=Group2),check_overlap = F,
hjust=-0.5, vjust=-0.5, alpha=1, fontface="bold")+
#GroupB
geom_point(data=GroupB,aes(color=Group2), size=3, shape=21, alpha=0.2)+
#GroupA
geom_point(data=GroupA,aes(shape=Group2), size=2,alpha=0.2)+
#GroupC
geom_encircle(data=GroupC, aes(fill = Group2), s_shape = 1, expand = 0,
alpha = 0.2, color = "black",size=1.5, show.legend = F)+
geom_point(data=GroupC,aes(colour=Group2),size=2, alpha=0.3, shape= 0)+
scale_shape_manual(values=2:14)+
guides(colour = "none", shape = "legend")+
theme_bw()
Это вывод:
Вопрос:
в текущем выводе, легенда показывает только факторы из GroupA
, как я могу выбрать код для всех ключей легенды от GroupA
, GroupB
, GroupC
?