r - 使用 ggplot2 在分面躲避条形图上添加文本

标签 r text ggplot2 bar-chart facet

我想绘制两个不同年份的躲避条形图,并相应地将收入数字放在条形图的顶部。 在尝试了我在这里找到的一些建议之后,我仍然无法得到我想要的(所有数字都显示在中间条/列的中间,而不是平均分布)。任何建议将不胜感激。谢谢!

我最近的尝试

# 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 output**

最佳答案

您还需要躲避文本值。尝试

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=所以它知道要躲避哪些值。

关于r - 使用 ggplot2 在分面躲避条形图上添加文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26660525/

相关文章:

r:在 Flexdashboard 中使用 Shiny 渲染 Kable

r - 如何在 slidify 中打印表格?

css - 文本适合我网页中的框

c++ - INFO 解析器,属性树 - 我如何根据单个键收集所有值

r - 如何使用ggplot2修改multiple-ggproto中标签的背景颜色

使用小平面和翻转坐标删除 ggplot boxplot 中未使用的级别?

r - 将字符串解析为更新 ggplot theme() 的参数

r - 如何在 R 中绘制预测子集?

r - 将一个矩阵与一组标量相乘

jquery - 使用 .text() 仅检索未嵌套在子标签中的文本