2017-09-08 2 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)) 

Ce code génère un diagramme à barres empilées.R et ggplot: Étiquetage des problèmes d'un diagramme à barres empilées à partir de la deuxième trame de données

Mon but est d'étiqueter ce tracé avec plot_labels$label sur le même axe y et l'échelle de la barre empilée.

en ligne commençant Enlever les commentaires avec geom_text dans la définition de l'intrigue jette l'erreur suivante:

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

valeurs plot_labels$label sont équivalentes à résumer plot_data$value par plot_data$year.

Nous apprécierions grandement l'aide pour le dépannage!

+1

Vous devez ajouter 'inherit.aes = FALSE' dans le' geom_text() 'la ligne, sinon il hérite' fill = type' de la cartographie esthétique définie dans 'ggplot()', et essaie de regarder pour une colonne nommée "type" dans "plot_labels". –

+0

Aussi, je pense que ce devrait être 'y = label' plutôt que' y = text' dans le mapping esthétique de 'geom_text()'? –

+0

'y = text' était une faute de frappe et une bonne prise de votre part. ajouter 'inherit.aes = FALSE' travaillé! Quel gonflement, merci! –

Répondre

1

Quelques problèmes: 1) le fill devrait être placé dans geom_bar, sinon il sera hérité par tous les geoms suivants. 2) le geom_col est meilleur que geom_bar lorsque vous fournissez à la fois x et y. 3) dans geom_text, x et y doivent être du même type que dans 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

doux, merci pour la réponse et des suggestions! Vraiment coincé sur cette intrigue pendant un moment. –