2017-02-15 41 views
1

使用下面的数据,我想创建一个演示图:炼油ggplot R代码里面出现的背后剧情点

name = c("Phil", "Ian", "Leslie", "Darla", "Silvia", "Ron", "Emily", "Jack") 
score = c(73.8, 73.5, 70.3, 68.9, 65.3, 61.4, 55.2, 54.3) 
tx = c(0,0,1,0,0,0,0,0) 
test1 <- data.frame(name, score, tx) 

该图是为了显示每个点作为一个大圈圆内的绘图点的值。红色虚线代表绘制值的平均值。灰色矩形代表均值附近的标准偏差。下面是我使用来创建图表的代码:

library(ggplot2) 
library(scales) 

cols <- c("1" = "#ff7f0e", "0" = "#1f77b4") 
txctrl <- c("1" = "#ffffff", "0" = "#000000") 

ggplot(test1, aes(x=score, y=reorder(name,score))) + 
    geom_vline(aes(xintercept=mean(score)), colour="red", linetype="dashed", size=1) + 
    geom_point(aes(colour = factor(tx), size=0), show.legend = FALSE) + 
    annotate("rect", xmin=(mean(test1$score)-sd(test1$score)), xmax=(mean(test1$score)+sd(test1$score)), ymin=-Inf, ymax=Inf, alpha=0.5, fill="grey90") + 
    # geom_label(aes(label=score), colour=txctrl, fontface = "bold") + 
    scale_colour_manual(values=cols) + 
    scale_size(range=c(11,11)) + 
    xlim(52,78) + 
    geom_text(aes(label=score), hjust=0.5, vjust=0.5, size=5, label=round(test1$score, digits = 0)) + 
    labs(y='Name', x='Score') + 
    theme_bw() + 
    theme(panel.border = element_blank(), 
     panel.grid.major = element_blank(), 
     panel.grid.minor = element_blank(), 
     axis.line = element_line(color=NA), 
     axis.ticks = element_blank(), 
     axis.text.x = element_blank(), 
     axis.title.x = element_blank(), 
     axis.text.y = element_text(size=14), 
     axis.title.y = element_blank()) 

这里是上面的代码的结果:

Resulting graph of preceding code.

我遇到的问题是该矩形衰落情节点的颜色。 如何让灰色矩形出现在绘图点和值标签后面?

一层接一层地工作,我设法让虚线的平均线坐在绘图点后面。当我尝试在标识绘图点的图层之前的任何位置移动带注释的矩形时,出现错误。

+1

您将图层添加到ggplot的顺序是它们的绘制顺序。在'geom_point()'之前移动注解。不要在问题中添加“奖金”。一次提出一个问题。 – MrFlick

+0

这可能会有所帮助:http://stackoverflow.com/questions/20249653/insert-layer-underneath-existing-layers-in-ggplot2-object – jesstme

回答

1

尝试使用geom_rect而不是注释。然后,你会想从aes功能中删除你的美学。我不能说为什么会产生一个错误,但它确实如此。

你可以在下面看看我的意思。

ggplot(test1, aes(x=score, y=reorder(name,score))) + 
geom_rect(xmin=(mean(score)-sd(score)), xmax=(mean(score)+sd(score)),ymin=-Inf, ymax=Inf, alpha=0.5,fill="grey90") + 
geom_vline(aes(xintercept=mean(score)), colour="red", linetype="dashed", size=1) + 
geom_point(aes(colour = factor(tx), size=0), show.legend = FALSE) + 
scale_colour_manual(values=cols) + 
scale_size(range=c(11,11)) + 
xlim(52,78) + 
geom_text(aes(label=score), hjust=0.5, vjust=0.5, size=5, label=round(test1$score, digits = 0)) + 
labs(y='Name', x='Score') + 
theme_bw() + 
theme(panel.border = element_blank(), 
    panel.grid.major = element_blank(), 
    panel.grid.minor = element_blank(), 
    axis.line = element_line(color=NA), 
    axis.ticks = element_blank(), 
    axis.text.x = element_blank(), 
    axis.title.x = element_blank(), 
    axis.text.y = element_text(size=14), 
    axis.title.y = element_blank()) 
+0

谢谢你提供了额外的方向。我尝试过使用geom_rect,但没有从aes函数中删除审美。这提供了我坚持的解决方案。 – Vondredi