Как выровнять метки geom_text выше уклоненного geom_col

Я не могу найти способ получить текстовые метки на этом (уклонено) geom_col выстроиться в соответствии с их соответствующими столбцами.

Я пробовал множество предложений решений на SO и других сайтах, и это самое близкое, что я мог получить:

Как это исправить?

Код:

ggplot(leads[leads$key_as_string <= max(leads$key_as_string) - 1, ], aes(fill = type)) +
  geom_col(aes(x = key_as_string, y = doc_count),
           colour = "black",
           position = position_dodge(1)) +
  scale_y_continuous(limits = c(0, max(leads$doc_count))) +
  geom_text(aes(x = key_as_string, y = doc_count, label = doc_count, group = key_as_string),
            hjust = 0.5,
            vjust = -0.5,
            size = 3,
            colour = "black",
            position = position_dodge(1)) +
  theme(panel.grid.minor.x = element_blank(),
        panel.grid.major.x = element_blank(),
        axis.text = element_text(colour = "black"))

1 ответ

Решение

Согласно моему комментарию, group = key_as_string виновник здесь Код по сути говорит ggplot, чтобы обе метки были одинаковыми key_as_string значение в той же группе, отрицая команду уклонения.

Иллюстрация с набором данных алмазов ниже. Мы видим, что удаление group Эстетическое картирование меняет положение этикеток:

p <- ggplot(diamonds %>%
              filter(cut %in% c("Fair", "Good")) %>%
              group_by(cut, clarity) %>%
              summarise(carat = mean(carat)), 
            aes(clarity, carat, fill = cut, label = round(carat, 2))) + 
  geom_col(position = position_dodge(1))

gridExtra::grid.arrange(
  p + geom_text(position = position_dodge(1), aes(group = clarity)),
  p + geom_text(position = position_dodge(1)),
  ncol = 1
)

сюжет

Другие вопросы по тегам