geom_bars 下方的重要字母
Significant letters beneath geom_bars
这是 iris
数据集的条形图。每个柱上方的字母表示显着差异,从 kruskal-wallis
测试中获得。 虽然在这个示例图中它们并不太乱,但我的真实数据有更大的误差条和条长度差异。因此,字母到处都是,变得难以阅读。我想知道是否可以将字母放在每个条的下方,就在 x 轴上方。这样他们就会全部对齐并且易于阅读。你怎么看?
代码:
library(reshape2)
library(ggplot2)
library(agricolae)
library(Rmisc)
file<-iris
melt <- melt(file, id=c("Species"))
x1 <- summarySE(melt, measurevar = "value", groupvars = c("variable", "Species"), na.rm=TRUE)
d=list()
tmp=list()
for(i in 1:4){
if(var(file[,i]) > 0){
tmp<-c(tmp,colnames(file[i]))
krusk <- kruskal(file[,i],file[,5],group=TRUE)
krusk$groups<-krusk$groups[order(krusk$groups[,'trt']),]
d[[i]]<-as.data.frame(krusk$groups)
}
}
big_data=do.call(rbind,d)
plot<- ggplot(x1, aes(x = variable, y = value, fill = Species)) +
coord_flip()+
geom_bar(stat = "identity", position =position_dodge(),colour="black",width=.7,size=.5)+
geom_errorbar(aes(ymin=value-se, ymax=value+se), width=.1,size=.5,position=position_dodge(.7))+
theme(
axis.text = element_text(angle=0, vjust=1,size=8,face="bold"),legend.title=element_blank(),legend.position="bottom",
legend.text=element_text(face="italic"))+
labs(title=NULL,x=NULL,y=NULL)+
geom_text(aes(label=big_data$M,colour=Species),position=position_dodge(width=1),vjust=.8,hjust=-1,size=3)
plot
像这样:
对于 geom_text
,设置 y = 0
和 hjust = 1.5
。
请注意,条形、误差线和文本的闪避宽度是相同的。另请注意,条形的宽度等于躲避宽度,因此条形在每个变量内相互对接。
plot <- ggplot(x1, aes(x = variable, y = value, fill = Species)) +
coord_flip() +
geom_bar(stat = "identity", position = position_dodge(width = .7),
colour = "black", width = .7, size = .5) +
geom_errorbar(aes(ymin = value-se, ymax = value+se), position=position_dodge(width = .7),
width = .1, size = .5) +
geom_text(aes(y = 0, label = big_data$M, colour = Species),
position=position_dodge(width = .7), hjust = 1.5, size = 3) +
theme(
axis.text = element_text(angle=0, vjust=1,size=8,face="bold"),legend.title=element_blank(),legend.position="bottom",
legend.text=element_text(face="italic")) +
labs(title=NULL,x=NULL,y=NULL)
plot
这是 iris
数据集的条形图。每个柱上方的字母表示显着差异,从 kruskal-wallis
测试中获得。
代码:
library(reshape2)
library(ggplot2)
library(agricolae)
library(Rmisc)
file<-iris
melt <- melt(file, id=c("Species"))
x1 <- summarySE(melt, measurevar = "value", groupvars = c("variable", "Species"), na.rm=TRUE)
d=list()
tmp=list()
for(i in 1:4){
if(var(file[,i]) > 0){
tmp<-c(tmp,colnames(file[i]))
krusk <- kruskal(file[,i],file[,5],group=TRUE)
krusk$groups<-krusk$groups[order(krusk$groups[,'trt']),]
d[[i]]<-as.data.frame(krusk$groups)
}
}
big_data=do.call(rbind,d)
plot<- ggplot(x1, aes(x = variable, y = value, fill = Species)) +
coord_flip()+
geom_bar(stat = "identity", position =position_dodge(),colour="black",width=.7,size=.5)+
geom_errorbar(aes(ymin=value-se, ymax=value+se), width=.1,size=.5,position=position_dodge(.7))+
theme(
axis.text = element_text(angle=0, vjust=1,size=8,face="bold"),legend.title=element_blank(),legend.position="bottom",
legend.text=element_text(face="italic"))+
labs(title=NULL,x=NULL,y=NULL)+
geom_text(aes(label=big_data$M,colour=Species),position=position_dodge(width=1),vjust=.8,hjust=-1,size=3)
plot
像这样:
对于 geom_text
,设置 y = 0
和 hjust = 1.5
。
请注意,条形、误差线和文本的闪避宽度是相同的。另请注意,条形的宽度等于躲避宽度,因此条形在每个变量内相互对接。
plot <- ggplot(x1, aes(x = variable, y = value, fill = Species)) +
coord_flip() +
geom_bar(stat = "identity", position = position_dodge(width = .7),
colour = "black", width = .7, size = .5) +
geom_errorbar(aes(ymin = value-se, ymax = value+se), position=position_dodge(width = .7),
width = .1, size = .5) +
geom_text(aes(y = 0, label = big_data$M, colour = Species),
position=position_dodge(width = .7), hjust = 1.5, size = 3) +
theme(
axis.text = element_text(angle=0, vjust=1,size=8,face="bold"),legend.title=element_blank(),legend.position="bottom",
legend.text=element_text(face="italic")) +
labs(title=NULL,x=NULL,y=NULL)
plot