我试图用平均数的标准偏差来补充ggdotchart,但是,我不能以美观的方式来这样做。因此,我需要更改图层的顺序,但无法使其正常工作。
library(ggpubr)
# Load data
data("mtcars")
dfm <- mtcars
# Convert the cyl variable to a factor
dfm$cyl <- as.factor(dfm$cyl)
# Add the name colums
dfm$name <- rownames(dfm)
ggdotchart(dfm, x = "name", y = "mpg",
color = "cyl", # Color by groups
palette = c("#00AFBB", "#E7B800", "#FC4E07"), # Custom color palette
sorting = "descending", # Sort value in descending order
add = "segments", # Add segments from y = 0 to dots
rotate = TRUE, # Rotate vertically
group = "cyl", # Order by groups
dot.size = 6, # Large dot size
label = round(dfm$mpg), # Add mpg values as dot labels
font.label = list(color = "white", size = 9,
vjust = 0.5), # Adjust label parameters
ggtheme = theme_pubr() # ggplot2 theme
) + geom_errorbar(aes(x = name, ymin = mpg - sd(mpg), ymax = mpg + sd(mpg)), position = "identity")
这会导致点上出现错误栏,而我想将其显示在点后。我试图逆转这些层,但无法使其正常工作。在普通的ggplot中,它只是在更改顺序,但是,该软件包很难这样做。
答案 0 :(得分:1)
虽然我喜欢链接中的答案,但我认为这会使不必要的复杂化。我们可以按任何顺序保存该图,然后进行更改,而不必将其他geoms
连接到该图。
g$layers[c(4,1,2,3)] -> g$layers
其中g
是您的绘图,前三层来自ggdotchart
。
为完成起见:
如果要使用注释中链接的问题中建议的解决方案,则为:
g$layers <- c(geom_errorbar(aes(x = name, ymin = mpg - sd(mpg), ymax = mpg + sd(mpg)),
position = "identity"),
g$layers)
在这里,g
是代码中ggdotchart
的一部分,没有geom_errorbar
。