Текст в барплоте в R - PullRequest
0 голосов
/ 03 ноября 2018

У меня проблема при добавлении значений в барплотте в R. Проблема в том, что я не могу поместить значения в середину каждого бара

balance<- c(-4.3963714,0.2335795,-0.2777250,-2.0037130,-1.2526801, -6.4556516)
barnames<-c("E1","E11","E12","E5","E7","E9")
barplot(balance,ylim=c(-8,2),col=c(if ((balance[1])>0) "blue"  else "red",(if ((balance[2])>0) "blue"  else "red"),(if ((balance[3])>0) "blue"  else "red"), (if ((balance[4])>0) "blue"  else "red"),(if ((balance[5])>0) "blue"  else "red"), (if ((balance[6])>0) "blue"  else "red")),main="Balance del Stock de Carbono",names.arg= barnames,ylab="Variacion del Stock de C kg/m2")    
abline(h=0)
text((balance/2),labels=round(balance,digits=2))

Вот барплот:

Barplot

Ответы [ 2 ]

0 голосов
/ 03 ноября 2018

Если вы не возражаете против использования ggplot2, вы можете заставить ярлыки выглядеть немного лучше

library(tidyverse)

tibble(barnames, balance) %>% 
  mutate(lab_loc = balance/2
         , col = factor(sign(balance))) %>% 
  ggplot(aes(x = barnames, y = balance)) +
    geom_col(aes(fill = col)) +
    geom_label(aes(y = lab_loc, label = round(balance, 2))) +
    scale_fill_manual(name = 'sign', values = c('1' = 'blue', '-1' = 'red')) +
    ylab('Variacion del Stock de C kg/m2') +
    ggtitle('Balance del Stock de Carbono') +
    theme(plot.title = element_text(hjust = 0.5))

enter image description here

0 голосов
/ 03 ноября 2018

Все, что вам нужно, это сохранить x позиций столбцов, возвращаемых barplot.

Вы также можете сделать аргумент col намного проще. Используйте ifelse, векторизованную версию if.

bp <- barplot(balance, ylim = c(-8, 2), 
              col = ifelse(balance > 0, "blue", "red"),
              main = "Balance del Stock de Carbono",
              names.arg = barnames,
              ylab="Variacion del Stock de C kg/m2")

abline(h=0)
text(bp, balance/2, labels = round(balance, digits = 2))

enter image description here

...