2017-09-08 93 views
0
plot_data <- rbind(
         data.frame(year = seq(2018,2027), value = seq(1000,10000,1000), type = 'Type A'), 
         data.frame(year = seq(2018,2027), value = seq(500,5000,500), type = 'Type B') 
        ) 
plot_labels  <- data.frame(year = seq(2018,2027), label = seq(1500,15000,1500)) 

ggplot(plot_data, aes(x=as.character(year), y=value, fill=type)) + 
geom_bar(width = .6, stat='identity') + 
# geom_text(data = plot_labels, aes(x = year, y = text, label = label)) + 
scale_x_discrete(name = '') + 
scale_y_continuous(name = 'My Label\n') + 
scale_fill_manual(name = '', values = c('red', 'blue')) + 
theme(
    plot.title = element_text(size = 10, hjust = .5), 
    panel.grid.major = element_line(colour = 'white', size = 1), 
    panel.grid.minor = element_line(colour = 'white'), 
    plot.background = element_rect(fill = 'white'), 
    panel.background = element_rect(fill = 'white'), 
    axis.text.x = element_text(colour = 'grey20', size = 7, angle = 45, hjust = 1), 
    axis.title.y = element_text(color = 'grey20', size = 9), 
    axis.text.y = element_text(colour = 'grey20', size = 7), 
    legend.position='bottom', 
    legend.key.size=unit(5,'mm'), 
    legend.text = element_text(size = 7)) 

这段代码将产生一个堆积条形图。R和ggplot:麻烦标记来自第二个数据框的堆积条形图

我的目标是在相同的y轴上标记这个图,标记为plot_labels$label,比例尺与堆积条相同。

在取消了线的情节定义与geom_text开始引发以下错误:

Error in eval(expr, envir, enclos) : object 'type' not found

plot_labels$label值等同于plot_data$year总结plot_data$value

非常感谢帮助排除故障!

+1

你必须添加'inherit.aes = FALSE'在'geom_text()'线,否则它继承'从()''中定义ggplot审美映射填充= type',&尝试查找用于'plot_labels'中名为“type”的列。 –

+0

另外,我认为在'geom_text()'的审美映射中它应该是'y = label'而不是'y = text'? –

+0

'y = text'是你的错误和很好的补充。加入'inherit.aes = FALSE'工作!多么膨胀的家伙,谢谢! –

回答

1

的几个问题: 1)fill应放置在geom_bar,由以下所有geoms否则将被继承。 2)当您同时提供xy时,geom_col优于geom_bar。 3)in geom_text,xy需要与ggplot中的类型相同。

ggplot(plot_data, aes(x=as.character(year), y=value)) + 
    geom_col(aes(fill=type), width = .6) + 
    geom_text(data = plot_labels, aes(x = as.character(year), y = label, label = label), vjust = 0) + 
    scale_x_discrete(name = '') + 
    scale_y_continuous(name = 'My Label\n') + 
    scale_fill_manual(name = '', values = c('red', 'blue')) + 
    theme(
     plot.title = element_text(size = 10, hjust = .5), 
     panel.grid.major = element_line(colour = 'white', size = 1), 
     panel.grid.minor = element_line(colour = 'white'), 
     plot.background = element_rect(fill = 'white'), 
     panel.background = element_rect(fill = 'white'), 
     axis.text.x = element_text(colour = 'grey20', size = 7, angle = 45, hjust = 1), 
     axis.title.y = element_text(color = 'grey20', size = 9), 
     axis.text.y = element_text(colour = 'grey20', size = 7), 
     legend.position='bottom', 
     legend.key.size=unit(5,'mm'), 
     legend.text = element_text(size = 7)) 
+0

甜蜜,谢谢你的回答和建议!真的被困在这个阴谋一段时间。 –