错误栏通过打开的符号显示

我有一对点略有偏移的点.每对点都有相关的误差线.我已经指定该对中第一个点的符号与第二个点的符号不同(闭合圆与开圆).我希望它可以通过打开的符号显示错误栏.

这是一个模拟数据集:

x = runif(4,-2,2)
x_1 = runif(4,-1,3)
dfr <- data.frame(
 x = c(x, x_1),
 y = rep(c("A","B","C","D"), 2),
 upper = c(x+2, x_1+1),
 lower = c(x-2, x_1-2),
 type = rep(c("alpha", "beta"), each = 4))

这是情节:

dodge=position_dodge(width=0.5)  
ggplot(dfr,aes(x=y,y=x,colour=type)) + 
    geom_point(size=8,aes(shape=type),position=dodge) +
    geom_errorbar(aes(ymax=upper,ymin=lower),position = dodge) + 
    scale_colour_manual(values = c('gray','black')) +
    scale_shape_manual(values = c(19,21)) +
    coord_flip() + 
    opts(legend.position="none")

感谢您的任何帮助,您可以提供!

最佳答案
我想不出一种方法来制作一个“开放”点,而不是让错误栏显示低谷.执行此操作的唯一方法是使用与背景相同的颜色填充点,但是通过该点将无法看到网格线.

要执行此操作,请将填充美学映射到type,并使用填充颜色grey90指定scale_fill_manual,这是theme_grey设置:

ggplot(dfr,aes(x=y,y=x,colour=type, fill=type)) + 
    geom_errorbar(aes(ymax=upper,ymin=lower),position = dodge) + 
    geom_point(size=8,aes(shape=type),position=dodge) +
    scale_colour_manual(values = c('gray','black')) +
    scale_fill_manual(values=c('grey', 'grey90')) +
    scale_shape_manual(values = c(19,21)) +
    coord_flip() + 
    opts(legend.position="none")

转载注明原文:错误栏通过打开的符号显示 - 代码日志