在ggplot2中的堆积条上方绘制总和值

draw the sum value above the stacked bar in ggplot2

如何在 ggplot2 的堆积条上方绘制每个 class 的总和值(在我的例子中:a=450,b=150,c=290,d=90)?这是我的代码:

#Data
hp=read.csv(textConnection(
"class,year,amount
a,99,100
a,100,200
a,101,150
b,100,50
b,101,100
c,102,70
c,102,80
c,103,90
c,104,50
d,102,90"))
hp$year=as.factor(hp$year)

#Plotting
p=ggplot(data=hp)  
p+geom_bar(binwidth=0.5,stat="identity")+  
aes(x=reorder(class,-value,sum),y=value,label=value,fill=year)+
theme()

您可以通过创建每个 class 总数的数据集来做到这一点(这可以通过多种方式完成,但我更喜欢 dplyr):

library(dplyr)
totals <- hp %>%
    group_by(class) %>%
    summarize(total = sum(value))

然后将 geom_text 图层添加到您的绘图中,使用 totals 作为数据集:

p + geom_bar(binwidth = 0.5, stat="identity") +  
    aes(x = reorder(class, -value, sum), y = value, label = value, fill = year) +
    theme() +
    geom_text(aes(class, total, label = total, fill = NULL), data = totals)

您可以使用 vjust 参数使文本高于或低于条形顶部,或者只需向 total 添加一些值:

p + geom_bar(binwidth = 0.5, stat = "identity") +  
    aes(x = reorder(class, -value, sum), y = value, label = value, fill = year) +
    theme() +
    geom_text(aes(class, total + 20, label = total, fill = NULL), data = totals)

您可以直接使用ggplot2内置的汇总功能:

ggplot(hp, aes(reorder(class, -amount, sum), amount, fill = year)) +
  geom_col() +
  geom_text(
    aes(label = after_stat(y), group = class), 
    stat = 'summary', fun = sum, vjust = -1
  )