在分面并列条形图上添加文字

11

我想为两个不同的年份绘制一个分组柱状图,并相应地在柱子顶部放置收入数字。尝试了这里提供的很多建议后,我仍然没有得到我想要的结果(所有数字都显示在中间的中间柱/列上,而不是平均分布)。任何建议都将不胜感激。谢谢!

我最新的尝试

# Disable scientific notation
options("scipen" = 100, "digits" = 1)

censusData <- structure(list(Year = c(2012L, 2007L, 2012L, 2007L, 2012L, 2007L, 
                                      2012L, 2007L, 2012L, 2007L, 2012L, 2007L, 2012L, 2007L, 2012L, 
                                      2007L, 2012L, 2007L, 2012L, 2007L, 2012L, 2007L, 2012L, 2007L
                                      ), 
                             County = c("A", "A", "B", "B", "C", "C", "Sum", "Sum", "A", 
                                      "A", "B", "B", "C", "C", "Sum", "Sum", "A", "A", "B", "B", "C", 
                                      "C", "Sum", "Sum"), 
                             variable = structure(c(1L, 1L, 1L, 1L, 1L, 
                                      1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 3L, 3L, 3L, 3L, 3L, 
                                      3L, 3L, 3L), .Label = c("Total_Revenue", "Crop_Revenue", "Livestock_Revenue"
                                      ), class = "factor"), 
                             value = c(1645.51, 1203.806, 68.911, 60.949, 
                                      923.163, 525.918, 2637.584, 1790.673, 1069.497, 787.459, 47.157, 
                                      38.735, 825.050228, 470.024, 1941.704228, 1296.218, 576.013, 
                                      416.347, 21.754, 22.214, 98.112772, 55.894, 695.879772, 494.455)), 
                        row.names = c(NA, -24L), 
                        .Names = c("Year", "County", "variable", "value"), 
                        class = "data.frame")

# Dodged barplot
qbarplot_yr_1 <- ggplot(censusData, aes(County, value)) + 
  facet_grid(. ~ Year) +  
  geom_bar(aes(fill = variable), position = "dodge", stat = "identity") +
  xlab("County") + 
  ylab("Revenue (Million USD)") +
  scale_fill_discrete(name = 'Legend', labels = c("Total", "Crop", "Livestocks")) +
  theme(axis.ticks.x = element_blank()) +
  theme(panel.background = element_rect(colour = 'dark grey')) +
  theme(strip.text.x = element_text(size = 20, face = "bold"),
        strip.background = element_rect(colour = "dark grey"))

# Add text on top of the bar
qbarplot_yr_1 + 
  geom_text(data = censusData,
            aes(x = County, y = value + 150, label = format(value, nsmall = 0, scientific = FALSE)), 
            color = "blue")

ggplot2 输出

2个回答

29
你需要避开文本值。尝试:

qbarplot_yr_1 + geom_text(data = censusData,
         aes(x = County, group=variable, y = value + 150, 
         label = format(value, nsmall = 0, digits=1, scientific = FALSE)), 
         color="blue", position=position_dodge(.9), hjust=.5)

我们还需要group=以便它知道在哪些值上躲避。


2
谢谢。不知道为什么我忽略了在我的geom_text()调用中包括group,但这个救了我! - Steven

1

使用ggfittex包添加另一种解决方案

library(ggplot2)
library(ggfittext)

ggplot(censusData, 
       aes(County, value,
           fill = variable,
           label = format(value, 
                          nsmall = 0, 
                          big.mark   = ",",
                          scientific = FALSE))) + 
  facet_grid(. ~ Year) +  
  geom_col(position = "dodge") +

  # from `ggfittext`
  geom_bar_text(position = "dodge") +

  scale_fill_discrete(name = 'Legend', labels = c("Total", "Crop", "Livestocks")) +
  theme_minimal(base_size = 14) +
  theme(axis.text.y = element_blank(),
        strip.text = element_text(face = 'bold'))

output

此文档由reprex包 (v0.3.0)于2021-01-20创建


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接