我正在尝试创建以下数据框的条形图:
df <- structure(list(HCT_range = c("Low", "Low", "Low", "Low", "Low",
"Low"), HG1_range = c("High", "High", "Normal", "High", "High",
"Normal"), HG2_range = c("High", "Normal", "High", "High", "Normal",
"High"), n = c(17L, 54L, 66L, 15L, 61L, 60L), Type = c("LHH",
"LHN", "LNH", "LHH", "LHN", "LNH"), File = c("a", "a", "a", "b",
"b", "b"), Perc = c(0.0387, 0.123, 0.1503, 0.0342, 0.1389, 0.1366
)), row.names = c(NA, -6L), class = c("tbl_df", "tbl", "data.frame"
))
我正在尝试使用以下命令创建闪避条形图:
ggplot(data = df, aes(x = Type, y = n)) +
geom_col(aes(fill = File), position = position_dodge(width = 0.9)) +
geom_text(aes(label = Perc), position = position_dodge(0.9))
但由于某种原因,测试没有被躲避而是堆叠起来 - 尽管有特定的位置调用。
有什么想法吗?
您只需使用 fill 参数指定条形代表什么。否则 ggplot 不知道将文本放置在哪里。 这能解决您的问题吗?
ggplot(data = df, aes(x = Type, y = n, fill=File)) +
geom_col(aes(fill = File), position = position_dodge(width = 0.9)) +
geom_text(aes(label = Perc), position = position_dodge(0.9))
您也可以看看这个问题:Position geom_text on dodged barplot
我在复制 alex_555 的建议时遇到了麻烦,最终偶然发现了一个修复:我的 x 数据是日期类型,我必须将 x 更改为 as.factor(Date),然后 geom_text 才能正确对齐。
ggplot(aes(x=as.factor(Date), y=Cost, fill=Legend)) +
geom_col(aes(fill=Legend),position=position_dodge(), alpha=.75) +
geom_text(aes(label=format(round(Cost), nsmall=0, big.mark=",")), size=4, position=position_dodge(width=.9), vjust=-0.3)
抱歉,我没有足够的声誉,无法直接评论 alex_555 的帖子。